brakeman 4.4.0 → 4.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of brakeman might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CHANGES.md +17 -0
- data/bundle/load.rb +7 -8
- data/bundle/ruby/2.5.0/gems/{ruby2ruby-2.4.1 → ruby2ruby-2.4.2}/History.rdoc +8 -0
- data/bundle/ruby/2.5.0/gems/{ruby2ruby-2.4.1 → ruby2ruby-2.4.2}/Manifest.txt +0 -0
- data/bundle/ruby/2.5.0/gems/{ruby2ruby-2.4.1 → ruby2ruby-2.4.2}/README.rdoc +0 -0
- data/bundle/ruby/2.5.0/gems/{ruby2ruby-2.4.1 → ruby2ruby-2.4.2}/lib/ruby2ruby.rb +34 -36
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/History.rdoc +47 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/Manifest.txt +5 -4
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/README.rdoc +0 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/compare/normalize.rb +29 -2
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/debugging.md +18 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/lib/rp_extensions.rb +0 -7
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/lib/rp_stringscanner.rb +0 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/lib/ruby20_parser.rb +6874 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/lib/ruby20_parser.y +284 -201
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/lib/ruby21_parser.rb +6952 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/lib/ruby21_parser.y +281 -197
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/lib/ruby22_parser.rb +6983 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0/lib/ruby_parser.yy → ruby_parser-3.13.0/lib/ruby22_parser.y} +280 -306
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/lib/ruby23_parser.rb +6982 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/lib/ruby23_parser.y +282 -203
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/lib/ruby24_parser.rb +6982 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/lib/ruby24_parser.y +282 -203
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/lib/ruby25_parser.rb +6981 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/lib/ruby25_parser.y +282 -203
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/lib/ruby26_parser.rb +6999 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/lib/ruby26_parser.y +2469 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/lib/ruby_lexer.rb +116 -118
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/lib/ruby_lexer.rex +10 -8
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/lib/ruby_lexer.rex.rb +8 -8
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0 → ruby_parser-3.13.0}/lib/ruby_parser.rb +5 -7
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/lib/ruby_parser.yy +2571 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/lib/ruby_parser_extras.rb +1360 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/tools/munge.rb +216 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.13.0/tools/ripper.rb +23 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-legacy-1.0.0/History.rdoc +6 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-legacy-1.0.0/Manifest.txt +19 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-legacy-1.0.0/README.rdoc +54 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-legacy-1.0.0/lib/ruby_parser/legacy.rb +5 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0/lib → ruby_parser-legacy-1.0.0/lib/ruby_parser/legacy}/ruby18_parser.rb +7 -6
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0/lib → ruby_parser-legacy-1.0.0/lib/ruby_parser/legacy}/ruby18_parser.y +5 -4
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0/lib → ruby_parser-legacy-1.0.0/lib/ruby_parser/legacy}/ruby19_parser.rb +7 -6
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0/lib → ruby_parser-legacy-1.0.0/lib/ruby_parser/legacy}/ruby19_parser.y +5 -4
- data/bundle/ruby/2.5.0/gems/ruby_parser-legacy-1.0.0/lib/ruby_parser/legacy/ruby_lexer.rb +1412 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-legacy-1.0.0/lib/ruby_parser/legacy/ruby_lexer.rex +179 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-legacy-1.0.0/lib/ruby_parser/legacy/ruby_lexer.rex.rb +323 -0
- data/bundle/ruby/2.5.0/gems/ruby_parser-legacy-1.0.0/lib/ruby_parser/legacy/ruby_parser.rb +30 -0
- data/bundle/ruby/2.5.0/gems/{ruby_parser-3.12.0/lib → ruby_parser-legacy-1.0.0/lib/ruby_parser/legacy}/ruby_parser_extras.rb +43 -33
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/CHANGES.md +5 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/Gemfile +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/LICENSE.txt +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/README.md +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/bundle_install_all_ruby_versions.sh +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/deep.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/libyaml_checker.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/load.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/parse/date.rb +2 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/parse/hexadecimal.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/parse/sexagesimal.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/psych_handler.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/psych_resolver.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/resolver.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/safe_to_ruby_visitor.rb +0 -0
- data/bundle/ruby/2.5.0/gems/safe_yaml-1.0.5/lib/safe_yaml/store.rb +39 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/syck_hack.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/syck_node_monkeypatch.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/syck_resolver.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/transform.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/transform/to_boolean.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/transform/to_date.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/transform/to_float.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/transform/to_integer.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/transform/to_nil.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/transform/to_symbol.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/transform/transformation_map.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/lib/safe_yaml/version.rb +1 -1
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/run_specs_all_ruby_versions.sh +0 -0
- data/bundle/ruby/2.5.0/gems/{safe_yaml-1.0.4 → safe_yaml-1.0.5}/safe_yaml.gemspec +0 -0
- data/bundle/ruby/2.5.0/gems/{sexp_processor-4.11.0 → sexp_processor-4.12.0}/History.rdoc +8 -0
- data/bundle/ruby/2.5.0/gems/{sexp_processor-4.11.0 → sexp_processor-4.12.0}/Manifest.txt +0 -0
- data/bundle/ruby/2.5.0/gems/{sexp_processor-4.11.0 → sexp_processor-4.12.0}/README.rdoc +0 -0
- data/bundle/ruby/2.5.0/gems/{sexp_processor-4.11.0 → sexp_processor-4.12.0}/lib/composite_sexp_processor.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{sexp_processor-4.11.0 → sexp_processor-4.12.0}/lib/pt_testcase.rb +2 -2
- data/bundle/ruby/2.5.0/gems/{sexp_processor-4.11.0 → sexp_processor-4.12.0}/lib/sexp.rb +4 -4
- data/bundle/ruby/2.5.0/gems/{sexp_processor-4.11.0 → sexp_processor-4.12.0}/lib/sexp_processor.rb +1 -1
- data/bundle/ruby/2.5.0/gems/{sexp_processor-4.11.0 → sexp_processor-4.12.0}/lib/strict_sexp.rb +3 -3
- data/bundle/ruby/2.5.0/gems/{sexp_processor-4.11.0 → sexp_processor-4.12.0}/lib/unique.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/CHANGES +6 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/EXPRESSIONS.md +1 -1
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/Gemfile +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/LICENSE +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/README.md +1 -1
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/engine.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/erb/engine.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/erb/parser.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/erb/template.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/erb/trimming.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/exceptions.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filter.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/code_merger.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/control_flow.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/dynamic_inliner.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/encoding.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/eraser.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/escapable.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/multi_flattener.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/remove_bom.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/static_analyzer.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/static_merger.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/string_splitter.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/filters/validator.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/generator.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/generators/array.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/generators/array_buffer.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/generators/erb.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/generators/rails_output_buffer.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/generators/string_buffer.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/grammar.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/html/attribute_merger.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/html/attribute_remover.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/html/attribute_sorter.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/html/dispatcher.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/html/fast.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/html/filter.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/html/pretty.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/html/safe.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/map.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/mixins/dispatcher.rb +2 -1
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/mixins/engine_dsl.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/mixins/grammar_dsl.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/mixins/options.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/mixins/template.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/parser.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/static_analyzer.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/templates.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/templates/rails.rb +2 -2
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/templates/tilt.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/lib/temple/utils.rb +0 -0
- data/bundle/ruby/2.5.0/gems/temple-0.8.1/lib/temple/version.rb +3 -0
- data/bundle/ruby/2.5.0/gems/{temple-0.8.0 → temple-0.8.1}/temple.gemspec +0 -0
- data/bundle/ruby/2.5.0/gems/{unicode-display_width-1.4.1 → unicode-display_width-1.5.0}/CHANGELOG.md +4 -0
- data/bundle/ruby/2.5.0/gems/{unicode-display_width-1.4.1 → unicode-display_width-1.5.0}/MIT-LICENSE.txt +1 -1
- data/bundle/ruby/2.5.0/gems/{unicode-display_width-1.4.1 → unicode-display_width-1.5.0}/README.md +10 -10
- data/bundle/ruby/2.5.0/gems/unicode-display_width-1.5.0/data/display_width.marshal.gz +0 -0
- data/bundle/ruby/2.5.0/gems/{unicode-display_width-1.4.1 → unicode-display_width-1.5.0}/lib/unicode/display_width.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{unicode-display_width-1.4.1 → unicode-display_width-1.5.0}/lib/unicode/display_width/constants.rb +2 -2
- data/bundle/ruby/2.5.0/gems/{unicode-display_width-1.4.1 → unicode-display_width-1.5.0}/lib/unicode/display_width/index.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{unicode-display_width-1.4.1 → unicode-display_width-1.5.0}/lib/unicode/display_width/no_string_ext.rb +0 -0
- data/bundle/ruby/2.5.0/gems/{unicode-display_width-1.4.1 → unicode-display_width-1.5.0}/lib/unicode/display_width/string_ext.rb +0 -0
- data/lib/brakeman/checks/base_check.rb +16 -0
- data/lib/brakeman/checks/check_content_tag.rb +12 -0
- data/lib/brakeman/checks/check_cross_site_scripting.rb +6 -6
- data/lib/brakeman/checks/check_evaluation.rb +0 -1
- data/lib/brakeman/checks/check_execute.rb +18 -0
- data/lib/brakeman/checks/check_send.rb +0 -1
- data/lib/brakeman/checks/check_session_manipulation.rb +0 -1
- data/lib/brakeman/checks/check_sql.rb +12 -3
- data/lib/brakeman/file_parser.rb +8 -4
- data/lib/brakeman/parsers/haml_embedded.rb +44 -0
- data/lib/brakeman/parsers/slim_embedded.rb +44 -0
- data/lib/brakeman/parsers/template_parser.rb +2 -4
- data/lib/brakeman/processors/alias_processor.rb +23 -1
- data/lib/brakeman/processors/lib/call_conversion_helper.rb +4 -0
- data/lib/brakeman/processors/slim_template_processor.rb +16 -0
- data/lib/brakeman/processors/template_alias_processor.rb +2 -2
- data/lib/brakeman/scanner.rb +11 -10
- data/lib/brakeman/tracker.rb +5 -1
- data/lib/brakeman/tracker/config.rb +32 -7
- data/lib/brakeman/util.rb +17 -0
- data/lib/brakeman/version.rb +1 -1
- metadata +157 -320
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.12.0/lib/ruby20_parser.rb +0 -6687
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.12.0/lib/ruby21_parser.rb +0 -6767
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.12.0/lib/ruby22_parser.rb +0 -6803
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.12.0/lib/ruby22_parser.y +0 -2376
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.12.0/lib/ruby23_parser.rb +0 -6818
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.12.0/lib/ruby24_parser.rb +0 -6818
- data/bundle/ruby/2.5.0/gems/ruby_parser-3.12.0/lib/ruby25_parser.rb +0 -6818
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/CODE_OF_CONDUCT.md +0 -10
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/CONTRIBUTING.md +0 -148
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/MIT-LICENSE +0 -20
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/README.md +0 -227
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/REVISION +0 -1
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/VERSION +0 -1
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/VERSION_DATE +0 -1
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/VERSION_NAME +0 -1
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/extra/sass-spec-ref.sh +0 -32
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/extra/update_watch.rb +0 -13
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/init.rb +0 -18
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass.rb +0 -109
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/cache_stores.rb +0 -15
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/cache_stores/base.rb +0 -88
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/cache_stores/chain.rb +0 -34
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/cache_stores/filesystem.rb +0 -60
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/cache_stores/memory.rb +0 -46
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/cache_stores/null.rb +0 -25
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/callbacks.rb +0 -67
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/css.rb +0 -408
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/deprecation.rb +0 -55
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/engine.rb +0 -1226
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/environment.rb +0 -215
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/error.rb +0 -198
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/exec.rb +0 -9
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/exec/base.rb +0 -199
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/exec/sass_convert.rb +0 -283
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/exec/sass_scss.rb +0 -440
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/features.rb +0 -47
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/importers.rb +0 -23
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/importers/base.rb +0 -182
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/importers/deprecated_path.rb +0 -51
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/importers/filesystem.rb +0 -219
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/logger.rb +0 -17
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/logger/base.rb +0 -36
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/logger/delayed.rb +0 -50
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/logger/log_level.rb +0 -45
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/media.rb +0 -210
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/plugin.rb +0 -134
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/plugin/compiler.rb +0 -582
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/plugin/configuration.rb +0 -134
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/plugin/generic.rb +0 -15
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/plugin/merb.rb +0 -48
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/plugin/rack.rb +0 -60
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/plugin/rails.rb +0 -47
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/plugin/staleness_checker.rb +0 -199
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/railtie.rb +0 -10
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/repl.rb +0 -57
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/root.rb +0 -7
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script.rb +0 -66
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/css_lexer.rb +0 -33
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/css_parser.rb +0 -33
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/css_variable_warning.rb +0 -52
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/functions.rb +0 -2693
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/lexer.rb +0 -464
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/parser.rb +0 -832
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree.rb +0 -16
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree/funcall.rb +0 -313
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree/interpolation.rb +0 -223
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree/list_literal.rb +0 -104
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree/literal.rb +0 -49
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree/map_literal.rb +0 -64
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree/node.rb +0 -127
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree/operation.rb +0 -156
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree/selector.rb +0 -26
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree/string_interpolation.rb +0 -125
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree/unary_operation.rb +0 -69
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/tree/variable.rb +0 -57
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/value.rb +0 -11
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/value/arg_list.rb +0 -36
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/value/base.rb +0 -241
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/value/bool.rb +0 -35
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/value/color.rb +0 -698
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/value/helpers.rb +0 -272
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/value/list.rb +0 -113
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/value/map.rb +0 -70
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/value/null.rb +0 -44
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/value/number.rb +0 -563
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/script/value/string.rb +0 -138
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/scss.rb +0 -14
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/scss/css_parser.rb +0 -56
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/scss/parser.rb +0 -1254
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/scss/rx.rb +0 -140
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/scss/static_parser.rb +0 -373
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/selector.rb +0 -323
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/selector/abstract_sequence.rb +0 -111
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/selector/comma_sequence.rb +0 -191
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/selector/pseudo.rb +0 -266
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/selector/sequence.rb +0 -636
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/selector/simple.rb +0 -117
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/selector/simple_sequence.rb +0 -344
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/shared.rb +0 -76
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/source/map.rb +0 -213
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/source/position.rb +0 -39
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/source/range.rb +0 -41
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/stack.rb +0 -120
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/supports.rb +0 -225
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/at_root_node.rb +0 -83
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/charset_node.rb +0 -22
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/comment_node.rb +0 -82
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/content_node.rb +0 -9
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/css_import_node.rb +0 -68
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/debug_node.rb +0 -18
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/directive_node.rb +0 -59
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/each_node.rb +0 -24
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/error_node.rb +0 -18
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/extend_node.rb +0 -43
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/for_node.rb +0 -36
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/function_node.rb +0 -44
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/if_node.rb +0 -52
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/import_node.rb +0 -75
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/keyframe_rule_node.rb +0 -15
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/media_node.rb +0 -48
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/mixin_def_node.rb +0 -38
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/mixin_node.rb +0 -52
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/node.rb +0 -240
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/prop_node.rb +0 -170
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/return_node.rb +0 -19
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/root_node.rb +0 -44
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/rule_node.rb +0 -155
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/supports_node.rb +0 -38
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/trace_node.rb +0 -33
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/variable_node.rb +0 -36
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/visitors/base.rb +0 -72
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/visitors/check_nesting.rb +0 -173
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/visitors/convert.rb +0 -351
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/visitors/cssize.rb +0 -373
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/visitors/deep_copy.rb +0 -107
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/visitors/extend.rb +0 -70
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/visitors/perform.rb +0 -564
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/visitors/set_options.rb +0 -139
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/visitors/to_css.rb +0 -409
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/warn_node.rb +0 -18
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/tree/while_node.rb +0 -18
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/util.rb +0 -1375
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/util/cross_platform_random.rb +0 -19
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/util/multibyte_string_scanner.rb +0 -155
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/util/normalized_map.rb +0 -129
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/util/ordered_hash.rb +0 -192
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/util/subset_map.rb +0 -109
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/util/test.rb +0 -9
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/lib/sass/version.rb +0 -124
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/rails/init.rb +0 -1
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/CHANGELOG.md +0 -1
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/CONTRIBUTING.md +0 -38
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/Gemfile +0 -20
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/Guardfile +0 -8
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/LICENSE +0 -20
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/README.md +0 -349
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/Rakefile +0 -5
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/Vagrantfile +0 -96
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/lib/listen.rb +0 -54
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/lib/listen/adapter.rb +0 -327
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/lib/listen/adapters/bsd.rb +0 -75
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/lib/listen/adapters/darwin.rb +0 -48
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/lib/listen/adapters/linux.rb +0 -81
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/lib/listen/adapters/polling.rb +0 -58
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/lib/listen/adapters/windows.rb +0 -91
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/lib/listen/directory_record.rb +0 -406
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/lib/listen/listener.rb +0 -323
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/lib/listen/turnstile.rb +0 -32
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/lib/listen/version.rb +0 -3
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/listen.gemspec +0 -28
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/listen/adapter_spec.rb +0 -149
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/listen/adapters/bsd_spec.rb +0 -36
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/listen/adapters/darwin_spec.rb +0 -37
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/listen/adapters/linux_spec.rb +0 -47
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/listen/adapters/polling_spec.rb +0 -68
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/listen/adapters/windows_spec.rb +0 -30
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/listen/directory_record_spec.rb +0 -1250
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/listen/listener_spec.rb +0 -258
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/listen/turnstile_spec.rb +0 -56
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/listen_spec.rb +0 -67
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/spec_helper.rb +0 -25
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/support/adapter_helper.rb +0 -666
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/support/directory_record_helper.rb +0 -57
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/support/fixtures_helper.rb +0 -29
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/support/listeners_helper.rb +0 -179
- data/bundle/ruby/2.5.0/gems/sass-3.4.25/vendor/listen/spec/support/platform_helper.rb +0 -15
- data/bundle/ruby/2.5.0/gems/temple-0.8.0/lib/temple/version.rb +0 -3
- data/bundle/ruby/2.5.0/gems/unicode-display_width-1.4.1/data/display_width.marshal.gz +0 -0
@@ -1,140 +0,0 @@
|
|
1
|
-
# -*- coding: utf-8 -*-
|
2
|
-
module Sass
|
3
|
-
module SCSS
|
4
|
-
# A module containing regular expressions used
|
5
|
-
# for lexing tokens in an SCSS document.
|
6
|
-
# Most of these are taken from [the CSS3 spec](http://www.w3.org/TR/css3-syntax/#lexical),
|
7
|
-
# although some have been modified for various reasons.
|
8
|
-
module RX
|
9
|
-
# Takes a string and returns a CSS identifier
|
10
|
-
# that will have the value of the given string.
|
11
|
-
#
|
12
|
-
# @param str [String] The string to escape
|
13
|
-
# @return [String] The escaped string
|
14
|
-
def self.escape_ident(str)
|
15
|
-
return "" if str.empty?
|
16
|
-
return "\\#{str}" if str == '-' || str == '_'
|
17
|
-
out = ""
|
18
|
-
value = str.dup
|
19
|
-
out << value.slice!(0...1) if value =~ /^[-_]/
|
20
|
-
if value[0...1] =~ NMSTART
|
21
|
-
out << value.slice!(0...1)
|
22
|
-
else
|
23
|
-
out << escape_char(value.slice!(0...1))
|
24
|
-
end
|
25
|
-
out << value.gsub(/[^a-zA-Z0-9_-]/) {|c| escape_char c}
|
26
|
-
out
|
27
|
-
end
|
28
|
-
|
29
|
-
# Escapes a single character for a CSS identifier.
|
30
|
-
#
|
31
|
-
# @param c [String] The character to escape. Should have length 1
|
32
|
-
# @return [String] The escaped character
|
33
|
-
# @private
|
34
|
-
def self.escape_char(c)
|
35
|
-
return "\\%06x" % (Sass::Util.ord(c)) unless c =~ %r{[ -/:-~]}
|
36
|
-
"\\#{c}"
|
37
|
-
end
|
38
|
-
|
39
|
-
# Creates a Regexp from a plain text string,
|
40
|
-
# escaping all significant characters.
|
41
|
-
#
|
42
|
-
# @param str [String] The text of the regexp
|
43
|
-
# @param flags [Integer] Flags for the created regular expression
|
44
|
-
# @return [Regexp]
|
45
|
-
# @private
|
46
|
-
def self.quote(str, flags = 0)
|
47
|
-
Regexp.new(Regexp.quote(str), flags)
|
48
|
-
end
|
49
|
-
|
50
|
-
H = /[0-9a-fA-F]/
|
51
|
-
NL = /\n|\r\n|\r|\f/
|
52
|
-
UNICODE = /\\#{H}{1,6}[ \t\r\n\f]?/
|
53
|
-
s = if Sass::Util.ruby1_8?
|
54
|
-
'\200-\377'
|
55
|
-
elsif Sass::Util.macruby?
|
56
|
-
'\u0080-\uD7FF\uE000-\uFFFD\U00010000-\U0010FFFF'
|
57
|
-
else
|
58
|
-
'\u{80}-\u{D7FF}\u{E000}-\u{FFFD}\u{10000}-\u{10FFFF}'
|
59
|
-
end
|
60
|
-
NONASCII = /[#{s}]/
|
61
|
-
ESCAPE = /#{UNICODE}|\\[ -~#{s}]/
|
62
|
-
NMSTART = /[_a-zA-Z]|#{NONASCII}|#{ESCAPE}/
|
63
|
-
NMCHAR = /[a-zA-Z0-9_-]|#{NONASCII}|#{ESCAPE}/
|
64
|
-
STRING1 = /\"((?:[^\n\r\f\\"]|\\#{NL}|#{ESCAPE})*)\"/
|
65
|
-
STRING2 = /\'((?:[^\n\r\f\\']|\\#{NL}|#{ESCAPE})*)\'/
|
66
|
-
|
67
|
-
IDENT = /-*#{NMSTART}#{NMCHAR}*/
|
68
|
-
NAME = /#{NMCHAR}+/
|
69
|
-
STRING = /#{STRING1}|#{STRING2}/
|
70
|
-
URLCHAR = /[#%&*-~]|#{NONASCII}|#{ESCAPE}/
|
71
|
-
URL = /(#{URLCHAR}*)/
|
72
|
-
W = /[ \t\r\n\f]*/
|
73
|
-
VARIABLE = /(\$)(#{Sass::SCSS::RX::IDENT})/
|
74
|
-
|
75
|
-
# This is more liberal than the spec's definition,
|
76
|
-
# but that definition didn't work well with the greediness rules
|
77
|
-
RANGE = /(?:#{H}|\?){1,6}/
|
78
|
-
|
79
|
-
##
|
80
|
-
|
81
|
-
S = /[ \t\r\n\f]+/
|
82
|
-
|
83
|
-
COMMENT = %r{/\*([^*]|\*+[^/*])*\**\*/}
|
84
|
-
SINGLE_LINE_COMMENT = %r{//.*(\n[ \t]*//.*)*}
|
85
|
-
|
86
|
-
CDO = quote("<!--")
|
87
|
-
CDC = quote("-->")
|
88
|
-
INCLUDES = quote("~=")
|
89
|
-
DASHMATCH = quote("|=")
|
90
|
-
PREFIXMATCH = quote("^=")
|
91
|
-
SUFFIXMATCH = quote("$=")
|
92
|
-
SUBSTRINGMATCH = quote("*=")
|
93
|
-
|
94
|
-
HASH = /##{NAME}/
|
95
|
-
|
96
|
-
IMPORTANT = /!#{W}important/i
|
97
|
-
|
98
|
-
# A unit is like an IDENT, but disallows a hyphen followed by a digit.
|
99
|
-
# This allows "1px-2px" to be interpreted as subtraction rather than "1"
|
100
|
-
# with the unit "px-2px". It also allows "%".
|
101
|
-
UNIT = /-?#{NMSTART}(?:[a-zA-Z0-9_]|#{NONASCII}|#{ESCAPE}|-(?!\.?\d))*|%/
|
102
|
-
|
103
|
-
UNITLESS_NUMBER = /(?:[0-9]+|[0-9]*\.[0-9]+)(?:[eE][+-]?\d+)?/
|
104
|
-
NUMBER = /#{UNITLESS_NUMBER}(?:#{UNIT})?/
|
105
|
-
PERCENTAGE = /#{UNITLESS_NUMBER}%/
|
106
|
-
|
107
|
-
URI = /url\(#{W}(?:#{STRING}|#{URL})#{W}\)/i
|
108
|
-
FUNCTION = /#{IDENT}\(/
|
109
|
-
|
110
|
-
UNICODERANGE = /u\+(?:#{H}{1,6}-#{H}{1,6}|#{RANGE})/i
|
111
|
-
|
112
|
-
# Defined in http://www.w3.org/TR/css3-selectors/#lex
|
113
|
-
PLUS = /#{W}\+/
|
114
|
-
GREATER = /#{W}>/
|
115
|
-
TILDE = /#{W}~/
|
116
|
-
NOT = quote(":not(", Regexp::IGNORECASE)
|
117
|
-
|
118
|
-
# Defined in https://developer.mozilla.org/en/CSS/@-moz-document as a
|
119
|
-
# non-standard version of http://www.w3.org/TR/css3-conditional/
|
120
|
-
URL_PREFIX = /url-prefix\(#{W}(?:#{STRING}|#{URL})#{W}\)/i
|
121
|
-
DOMAIN = /domain\(#{W}(?:#{STRING}|#{URL})#{W}\)/i
|
122
|
-
|
123
|
-
# Custom
|
124
|
-
HEXCOLOR = /\#[0-9a-fA-F]+/
|
125
|
-
INTERP_START = /#\{/
|
126
|
-
ANY = /:(-[-\w]+-)?any\(/i
|
127
|
-
OPTIONAL = /!#{W}optional/i
|
128
|
-
IDENT_START = /-|#{NMSTART}/
|
129
|
-
|
130
|
-
IDENT_HYPHEN_INTERP = /-(#\{)/
|
131
|
-
STRING1_NOINTERP = /\"((?:[^\n\r\f\\"#]|#(?!\{)|#{ESCAPE})*)\"/
|
132
|
-
STRING2_NOINTERP = /\'((?:[^\n\r\f\\'#]|#(?!\{)|#{ESCAPE})*)\'/
|
133
|
-
STRING_NOINTERP = /#{STRING1_NOINTERP}|#{STRING2_NOINTERP}/
|
134
|
-
|
135
|
-
STATIC_COMPONENT = /#{IDENT}|#{STRING_NOINTERP}|#{HEXCOLOR}|[+-]?#{NUMBER}|\!important/i
|
136
|
-
STATIC_VALUE = %r(#{STATIC_COMPONENT}(\s*[\s,/]\s*#{STATIC_COMPONENT})*([;}]))i
|
137
|
-
STATIC_SELECTOR = /(#{NMCHAR}|[ \t]|[,>+*]|[:#.]#{NMSTART}){1,50}([{])/i
|
138
|
-
end
|
139
|
-
end
|
140
|
-
end
|
@@ -1,373 +0,0 @@
|
|
1
|
-
require 'sass/script/css_parser'
|
2
|
-
|
3
|
-
module Sass
|
4
|
-
module SCSS
|
5
|
-
# A parser for a static SCSS tree.
|
6
|
-
# Parses with SCSS extensions, like nested rules and parent selectors,
|
7
|
-
# but without dynamic SassScript.
|
8
|
-
# This is useful for e.g. \{#parse\_selector parsing selectors}
|
9
|
-
# after resolving the interpolation.
|
10
|
-
class StaticParser < Parser
|
11
|
-
# Parses the text as a selector.
|
12
|
-
#
|
13
|
-
# @param filename [String, nil] The file in which the selector appears,
|
14
|
-
# or nil if there is no such file.
|
15
|
-
# Used for error reporting.
|
16
|
-
# @return [Selector::CommaSequence] The parsed selector
|
17
|
-
# @raise [Sass::SyntaxError] if there's a syntax error in the selector
|
18
|
-
def parse_selector
|
19
|
-
init_scanner!
|
20
|
-
seq = expr!(:selector_comma_sequence)
|
21
|
-
expected("selector") unless @scanner.eos?
|
22
|
-
seq.line = @line
|
23
|
-
seq.filename = @filename
|
24
|
-
seq
|
25
|
-
end
|
26
|
-
|
27
|
-
# Parses a static at-root query.
|
28
|
-
#
|
29
|
-
# @return [(Symbol, Array<String>)] The type of the query
|
30
|
-
# (`:with` or `:without`) and the values that are being filtered.
|
31
|
-
# @raise [Sass::SyntaxError] if there's a syntax error in the query,
|
32
|
-
# or if it doesn't take up the entire input string.
|
33
|
-
def parse_static_at_root_query
|
34
|
-
init_scanner!
|
35
|
-
tok!(/\(/); ss
|
36
|
-
type = tok!(/\b(without|with)\b/).to_sym; ss
|
37
|
-
tok!(/:/); ss
|
38
|
-
directives = expr!(:at_root_directive_list); ss
|
39
|
-
tok!(/\)/)
|
40
|
-
expected("@at-root query list") unless @scanner.eos?
|
41
|
-
return type, directives
|
42
|
-
end
|
43
|
-
|
44
|
-
def parse_keyframes_selector
|
45
|
-
init_scanner!
|
46
|
-
sel = expr!(:keyframes_selector)
|
47
|
-
expected("keyframes selector") unless @scanner.eos?
|
48
|
-
sel
|
49
|
-
end
|
50
|
-
|
51
|
-
# @see Parser#initialize
|
52
|
-
# @param allow_parent_ref [Boolean] Whether to allow the
|
53
|
-
# parent-reference selector, `&`, when parsing the document.
|
54
|
-
# @comment
|
55
|
-
# rubocop:disable ParameterLists
|
56
|
-
def initialize(str, filename, importer, line = 1, offset = 1, allow_parent_ref = true)
|
57
|
-
# rubocop:enable ParameterLists
|
58
|
-
super(str, filename, importer, line, offset)
|
59
|
-
@allow_parent_ref = allow_parent_ref
|
60
|
-
end
|
61
|
-
|
62
|
-
private
|
63
|
-
|
64
|
-
def moz_document_function
|
65
|
-
val = tok(URI) || tok(URL_PREFIX) || tok(DOMAIN) || function(false)
|
66
|
-
return unless val
|
67
|
-
ss
|
68
|
-
[val]
|
69
|
-
end
|
70
|
-
|
71
|
-
def variable; nil; end
|
72
|
-
def script_value; nil; end
|
73
|
-
def interpolation(warn_for_color = false); nil; end
|
74
|
-
def var_expr; nil; end
|
75
|
-
def interp_string; (s = tok(STRING)) && [s]; end
|
76
|
-
def interp_uri; (s = tok(URI)) && [s]; end
|
77
|
-
def interp_ident(ident = IDENT); (s = tok(ident)) && [s]; end
|
78
|
-
def use_css_import?; true; end
|
79
|
-
|
80
|
-
def special_directive(name, start_pos)
|
81
|
-
return unless %w(media import charset -moz-document).include?(name)
|
82
|
-
super
|
83
|
-
end
|
84
|
-
|
85
|
-
def selector_comma_sequence
|
86
|
-
sel = selector
|
87
|
-
return unless sel
|
88
|
-
selectors = [sel]
|
89
|
-
ws = ''
|
90
|
-
while tok(/,/)
|
91
|
-
ws << str {ss}
|
92
|
-
next unless (sel = selector)
|
93
|
-
selectors << sel
|
94
|
-
if ws.include?("\n")
|
95
|
-
selectors[-1] = Selector::Sequence.new(["\n"] + selectors.last.members)
|
96
|
-
end
|
97
|
-
ws = ''
|
98
|
-
end
|
99
|
-
Selector::CommaSequence.new(selectors)
|
100
|
-
end
|
101
|
-
|
102
|
-
def selector_string
|
103
|
-
sel = selector
|
104
|
-
return unless sel
|
105
|
-
sel.to_s
|
106
|
-
end
|
107
|
-
|
108
|
-
def selector
|
109
|
-
start_pos = source_position
|
110
|
-
# The combinator here allows the "> E" hack
|
111
|
-
val = combinator || simple_selector_sequence
|
112
|
-
return unless val
|
113
|
-
nl = str {ss}.include?("\n")
|
114
|
-
res = []
|
115
|
-
res << val
|
116
|
-
res << "\n" if nl
|
117
|
-
|
118
|
-
while (val = combinator || simple_selector_sequence)
|
119
|
-
res << val
|
120
|
-
res << "\n" if str {ss}.include?("\n")
|
121
|
-
end
|
122
|
-
seq = Selector::Sequence.new(res.compact)
|
123
|
-
|
124
|
-
if seq.members.any? {|sseq| sseq.is_a?(Selector::SimpleSequence) && sseq.subject?}
|
125
|
-
location = " of #{@filename}" if @filename
|
126
|
-
Sass::Util.sass_warn <<MESSAGE
|
127
|
-
DEPRECATION WARNING on line #{start_pos.line}, column #{start_pos.offset}#{location}:
|
128
|
-
The subject selector operator "!" is deprecated and will be removed in a future release.
|
129
|
-
This operator has been replaced by ":has()" in the CSS spec.
|
130
|
-
For example: #{seq.subjectless}
|
131
|
-
MESSAGE
|
132
|
-
end
|
133
|
-
|
134
|
-
seq
|
135
|
-
end
|
136
|
-
|
137
|
-
def combinator
|
138
|
-
tok(PLUS) || tok(GREATER) || tok(TILDE) || reference_combinator
|
139
|
-
end
|
140
|
-
|
141
|
-
def reference_combinator
|
142
|
-
return unless tok(%r{/})
|
143
|
-
res = '/'
|
144
|
-
ns, name = expr!(:qualified_name)
|
145
|
-
res << ns << '|' if ns
|
146
|
-
res << name << tok!(%r{/})
|
147
|
-
|
148
|
-
location = " of #{@filename}" if @filename
|
149
|
-
Sass::Util.sass_warn <<MESSAGE
|
150
|
-
DEPRECATION WARNING on line #{@line}, column #{@offset}#{location}:
|
151
|
-
The reference combinator #{res} is deprecated and will be removed in a future release.
|
152
|
-
MESSAGE
|
153
|
-
|
154
|
-
res
|
155
|
-
end
|
156
|
-
|
157
|
-
def simple_selector_sequence
|
158
|
-
start_pos = source_position
|
159
|
-
e = element_name || id_selector || class_selector || placeholder_selector || attrib ||
|
160
|
-
pseudo || parent_selector
|
161
|
-
return unless e
|
162
|
-
res = [e]
|
163
|
-
|
164
|
-
# The tok(/\*/) allows the "E*" hack
|
165
|
-
while (v = id_selector || class_selector || placeholder_selector ||
|
166
|
-
attrib || pseudo || (tok(/\*/) && Selector::Universal.new(nil)))
|
167
|
-
res << v
|
168
|
-
end
|
169
|
-
|
170
|
-
pos = @scanner.pos
|
171
|
-
line = @line
|
172
|
-
if (sel = str? {simple_selector_sequence})
|
173
|
-
@scanner.pos = pos
|
174
|
-
@line = line
|
175
|
-
begin
|
176
|
-
# If we see "*E", don't force a throw because this could be the
|
177
|
-
# "*prop: val" hack.
|
178
|
-
expected('"{"') if res.length == 1 && res[0].is_a?(Selector::Universal)
|
179
|
-
throw_error {expected('"{"')}
|
180
|
-
rescue Sass::SyntaxError => e
|
181
|
-
e.message << "\n\n\"#{sel}\" may only be used at the beginning of a compound selector."
|
182
|
-
raise e
|
183
|
-
end
|
184
|
-
end
|
185
|
-
|
186
|
-
Selector::SimpleSequence.new(res, tok(/!/), range(start_pos))
|
187
|
-
end
|
188
|
-
|
189
|
-
def parent_selector
|
190
|
-
return unless @allow_parent_ref && tok(/&/)
|
191
|
-
Selector::Parent.new(tok(NAME))
|
192
|
-
end
|
193
|
-
|
194
|
-
def class_selector
|
195
|
-
return unless tok(/\./)
|
196
|
-
@expected = "class name"
|
197
|
-
Selector::Class.new(tok!(IDENT))
|
198
|
-
end
|
199
|
-
|
200
|
-
def id_selector
|
201
|
-
return unless tok(/#(?!\{)/)
|
202
|
-
@expected = "id name"
|
203
|
-
Selector::Id.new(tok!(NAME))
|
204
|
-
end
|
205
|
-
|
206
|
-
def placeholder_selector
|
207
|
-
return unless tok(/%/)
|
208
|
-
@expected = "placeholder name"
|
209
|
-
Selector::Placeholder.new(tok!(IDENT))
|
210
|
-
end
|
211
|
-
|
212
|
-
def element_name
|
213
|
-
ns, name = Sass::Util.destructure(qualified_name(:allow_star_name))
|
214
|
-
return unless ns || name
|
215
|
-
|
216
|
-
if name == '*'
|
217
|
-
Selector::Universal.new(ns)
|
218
|
-
else
|
219
|
-
Selector::Element.new(name, ns)
|
220
|
-
end
|
221
|
-
end
|
222
|
-
|
223
|
-
def qualified_name(allow_star_name = false)
|
224
|
-
name = tok(IDENT) || tok(/\*/) || (tok?(/\|/) && "")
|
225
|
-
return unless name
|
226
|
-
return nil, name unless tok(/\|/)
|
227
|
-
|
228
|
-
return name, tok!(IDENT) unless allow_star_name
|
229
|
-
@expected = "identifier or *"
|
230
|
-
return name, tok(IDENT) || tok!(/\*/)
|
231
|
-
end
|
232
|
-
|
233
|
-
def attrib
|
234
|
-
return unless tok(/\[/)
|
235
|
-
ss
|
236
|
-
ns, name = attrib_name!
|
237
|
-
ss
|
238
|
-
|
239
|
-
op = tok(/=/) ||
|
240
|
-
tok(INCLUDES) ||
|
241
|
-
tok(DASHMATCH) ||
|
242
|
-
tok(PREFIXMATCH) ||
|
243
|
-
tok(SUFFIXMATCH) ||
|
244
|
-
tok(SUBSTRINGMATCH)
|
245
|
-
if op
|
246
|
-
@expected = "identifier or string"
|
247
|
-
ss
|
248
|
-
val = tok(IDENT) || tok!(STRING)
|
249
|
-
ss
|
250
|
-
end
|
251
|
-
flags = tok(IDENT) || tok(STRING)
|
252
|
-
tok!(/\]/)
|
253
|
-
|
254
|
-
Selector::Attribute.new(name, ns, op, val, flags)
|
255
|
-
end
|
256
|
-
|
257
|
-
def attrib_name!
|
258
|
-
if (name_or_ns = tok(IDENT))
|
259
|
-
# E, E|E
|
260
|
-
if tok(/\|(?!=)/)
|
261
|
-
ns = name_or_ns
|
262
|
-
name = tok(IDENT)
|
263
|
-
else
|
264
|
-
name = name_or_ns
|
265
|
-
end
|
266
|
-
else
|
267
|
-
# *|E or |E
|
268
|
-
ns = tok(/\*/) || ""
|
269
|
-
tok!(/\|/)
|
270
|
-
name = tok!(IDENT)
|
271
|
-
end
|
272
|
-
return ns, name
|
273
|
-
end
|
274
|
-
|
275
|
-
SELECTOR_PSEUDO_CLASSES = %w(not matches current any has host host-context).to_set
|
276
|
-
|
277
|
-
PREFIXED_SELECTOR_PSEUDO_CLASSES = %w(nth-child nth-last-child).to_set
|
278
|
-
|
279
|
-
def pseudo
|
280
|
-
s = tok(/::?/)
|
281
|
-
return unless s
|
282
|
-
@expected = "pseudoclass or pseudoelement"
|
283
|
-
name = tok!(IDENT)
|
284
|
-
if tok(/\(/)
|
285
|
-
ss
|
286
|
-
deprefixed = deprefix(name)
|
287
|
-
if s == ':' && SELECTOR_PSEUDO_CLASSES.include?(deprefixed)
|
288
|
-
sel = selector_comma_sequence
|
289
|
-
elsif s == ':' && PREFIXED_SELECTOR_PSEUDO_CLASSES.include?(deprefixed)
|
290
|
-
arg, sel = prefixed_selector_pseudo
|
291
|
-
else
|
292
|
-
arg = expr!(:pseudo_args)
|
293
|
-
end
|
294
|
-
|
295
|
-
tok!(/\)/)
|
296
|
-
end
|
297
|
-
Selector::Pseudo.new(s == ':' ? :class : :element, name, arg, sel)
|
298
|
-
end
|
299
|
-
|
300
|
-
def pseudo_args
|
301
|
-
arg = expr!(:pseudo_expr)
|
302
|
-
while tok(/,/)
|
303
|
-
arg << ',' << str {ss}
|
304
|
-
arg.concat expr!(:pseudo_expr)
|
305
|
-
end
|
306
|
-
arg
|
307
|
-
end
|
308
|
-
|
309
|
-
def pseudo_expr
|
310
|
-
res = pseudo_expr_token
|
311
|
-
return unless res
|
312
|
-
res << str {ss}
|
313
|
-
while (e = pseudo_expr_token)
|
314
|
-
res << e << str {ss}
|
315
|
-
end
|
316
|
-
res
|
317
|
-
end
|
318
|
-
|
319
|
-
def pseudo_expr_token
|
320
|
-
tok(PLUS) || tok(/[-*]/) || tok(NUMBER) || tok(STRING) || tok(IDENT)
|
321
|
-
end
|
322
|
-
|
323
|
-
def prefixed_selector_pseudo
|
324
|
-
prefix = str do
|
325
|
-
expr = str {expr!(:a_n_plus_b)}
|
326
|
-
ss
|
327
|
-
return expr, nil unless tok(/of/)
|
328
|
-
ss
|
329
|
-
end
|
330
|
-
return prefix, expr!(:selector_comma_sequence)
|
331
|
-
end
|
332
|
-
|
333
|
-
def a_n_plus_b
|
334
|
-
if (parity = tok(/even|odd/i))
|
335
|
-
return parity
|
336
|
-
end
|
337
|
-
|
338
|
-
if tok(/[+-]?[0-9]+/)
|
339
|
-
ss
|
340
|
-
return true unless tok(/n/)
|
341
|
-
else
|
342
|
-
return unless tok(/[+-]?n/i)
|
343
|
-
end
|
344
|
-
ss
|
345
|
-
|
346
|
-
return true unless tok(/[+-]/)
|
347
|
-
ss
|
348
|
-
@expected = "number"
|
349
|
-
tok!(/[0-9]+/)
|
350
|
-
true
|
351
|
-
end
|
352
|
-
|
353
|
-
def keyframes_selector
|
354
|
-
ss
|
355
|
-
str do
|
356
|
-
return unless keyframes_selector_component
|
357
|
-
ss
|
358
|
-
while tok(/,/)
|
359
|
-
ss
|
360
|
-
expr!(:keyframes_selector_component)
|
361
|
-
ss
|
362
|
-
end
|
363
|
-
end
|
364
|
-
end
|
365
|
-
|
366
|
-
def keyframes_selector_component
|
367
|
-
tok(IDENT) || tok(PERCENTAGE)
|
368
|
-
end
|
369
|
-
|
370
|
-
@sass_script_parser = Class.new(Sass::Script::CssParser)
|
371
|
-
end
|
372
|
-
end
|
373
|
-
end
|