expressir 0.2.4-x64-mingw32 → 0.2.10-x64-mingw32
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/.cross_rubies +30 -0
- data/.github/workflows/rake.yml +45 -46
- data/.github/workflows/release.yml +83 -75
- data/.gitignore +17 -15
- data/.gitmodules +3 -3
- data/.rspec +2 -2
- data/.rubocop.yml +508 -508
- data/Gemfile +4 -6
- data/README.adoc +147 -147
- data/Rakefile +11 -17
- data/bin/console +12 -12
- data/bin/rspec +29 -29
- data/bin/setup +8 -8
- data/demo.rb +18 -18
- data/docs/development.md +90 -90
- data/exe/expressir +20 -20
- data/exe/generate-parser +47 -47
- data/expressir.gemspec +43 -40
- data/lib/expressir.rb +21 -21
- data/lib/expressir/cli.rb +27 -27
- data/lib/expressir/cli/ui.rb +36 -36
- data/lib/expressir/config.rb +23 -23
- data/lib/expressir/express.rb +11 -11
- data/lib/expressir/express/aggregate_dimension.rb +38 -38
- data/lib/expressir/express/attribute.rb +15 -15
- data/lib/expressir/express/comment.rb +7 -7
- data/lib/expressir/express/defined_type.rb +36 -36
- data/lib/expressir/express/derived.rb +65 -65
- data/lib/expressir/express/derived_aggregate.rb +43 -43
- data/lib/expressir/express/entity.rb +137 -137
- data/lib/expressir/express/explicit.rb +70 -70
- data/lib/expressir/express/explicit_aggregate.rb +46 -46
- data/lib/expressir/express/explicit_or_derived.rb +16 -16
- data/lib/expressir/express/global_rule.rb +44 -44
- data/lib/expressir/express/interface_specification.rb +51 -51
- data/lib/expressir/express/interfaced_item.rb +38 -38
- data/lib/expressir/express/inverse.rb +46 -46
- data/lib/expressir/express/inverse_aggregate.rb +37 -37
- data/lib/expressir/express/model_element.rb +7 -7
- data/lib/expressir/express/named_type.rb +19 -19
- data/lib/expressir/express/remark.rb +8 -8
- data/lib/expressir/express/repository.rb +306 -306
- data/lib/expressir/express/schema_definition.rb +96 -96
- data/lib/expressir/express/subtype_constraint.rb +14 -14
- data/lib/expressir/express/type.rb +26 -26
- data/lib/expressir/express/type_aggregate.rb +42 -42
- data/lib/expressir/express/type_enum.rb +29 -29
- data/lib/expressir/express/type_parser.rb +45 -45
- data/lib/expressir/express/type_select.rb +82 -82
- data/lib/expressir/express/unique_rule.rb +35 -35
- data/lib/expressir/express/where_rule.rb +32 -32
- data/lib/expressir/express_exp/2.4/express_parser.so +0 -0
- data/lib/expressir/express_exp/2.5/express_parser.so +0 -0
- data/lib/expressir/express_exp/2.6/express_parser.so +0 -0
- data/lib/expressir/express_exp/2.7/express_parser.so +0 -0
- data/lib/expressir/express_exp/3.0/express_parser.so +0 -0
- data/lib/expressir/express_exp/formatter.rb +1500 -1449
- data/lib/expressir/express_exp/parser.rb +53 -35
- data/lib/expressir/express_exp/visitor.rb +2555 -2450
- data/lib/expressir/express_parser.rb +30 -30
- data/lib/expressir/model.rb +67 -64
- data/lib/expressir/model/attribute.rb +28 -26
- data/lib/expressir/model/constant.rb +18 -16
- data/lib/expressir/model/entity.rb +38 -45
- data/lib/expressir/model/enumeration_item.rb +12 -10
- data/lib/expressir/model/expressions/aggregate_initializer.rb +12 -12
- data/lib/expressir/model/expressions/aggregate_item.rb +14 -14
- data/lib/expressir/model/expressions/attribute_reference.rb +14 -14
- data/lib/expressir/model/expressions/binary_expression.rb +39 -39
- data/lib/expressir/model/expressions/call.rb +14 -14
- data/lib/expressir/model/expressions/entity_constructor.rb +14 -14
- data/lib/expressir/model/expressions/group_reference.rb +14 -14
- data/lib/expressir/model/expressions/index_reference.rb +16 -16
- data/lib/expressir/model/expressions/interval.rb +20 -20
- data/lib/expressir/model/expressions/query_expression.rb +27 -25
- data/lib/expressir/model/expressions/simple_reference.rb +12 -12
- data/lib/expressir/model/expressions/unary_expression.rb +18 -18
- data/lib/expressir/model/function.rb +55 -61
- data/lib/expressir/model/identifier.rb +9 -8
- data/lib/expressir/model/informal_proposition.rb +13 -0
- data/lib/expressir/model/interface.rb +17 -17
- data/lib/expressir/model/literals/binary.rb +12 -12
- data/lib/expressir/model/literals/integer.rb +12 -12
- data/lib/expressir/model/literals/logical.rb +16 -16
- data/lib/expressir/model/literals/real.rb +12 -12
- data/lib/expressir/model/literals/string.rb +14 -14
- data/lib/expressir/model/model_element.rb +67 -0
- data/lib/expressir/model/parameter.rb +18 -16
- data/lib/expressir/model/procedure.rb +53 -59
- data/lib/expressir/model/renamed_ref.rb +12 -12
- data/lib/expressir/model/repository.rb +18 -18
- data/lib/expressir/model/rule.rb +58 -61
- data/lib/expressir/model/schema.rb +55 -66
- data/lib/expressir/model/scope.rb +62 -16
- data/lib/expressir/model/statements/alias.rb +27 -25
- data/lib/expressir/model/statements/assignment.rb +14 -14
- data/lib/expressir/model/statements/call.rb +14 -14
- data/lib/expressir/model/statements/case.rb +16 -16
- data/lib/expressir/model/statements/case_action.rb +14 -14
- data/lib/expressir/model/statements/compound.rb +12 -12
- data/lib/expressir/model/statements/escape.rb +7 -7
- data/lib/expressir/model/statements/if.rb +16 -16
- data/lib/expressir/model/statements/null.rb +7 -7
- data/lib/expressir/model/statements/repeat.rb +35 -33
- data/lib/expressir/model/statements/return.rb +12 -12
- data/lib/expressir/model/statements/skip.rb +7 -7
- data/lib/expressir/model/subtype_constraint.rb +28 -26
- data/lib/expressir/model/type.rb +33 -23
- data/lib/expressir/model/types/aggregate.rb +18 -16
- data/lib/expressir/model/types/array.rb +20 -20
- data/lib/expressir/model/types/bag.rb +16 -16
- data/lib/expressir/model/types/binary.rb +14 -14
- data/lib/expressir/model/types/boolean.rb +7 -7
- data/lib/expressir/model/types/enumeration.rb +18 -18
- data/lib/expressir/model/types/generic.rb +14 -12
- data/lib/expressir/model/types/generic_entity.rb +14 -12
- data/lib/expressir/model/types/integer.rb +7 -7
- data/lib/expressir/model/types/list.rb +18 -18
- data/lib/expressir/model/types/logical.rb +7 -7
- data/lib/expressir/model/types/number.rb +7 -7
- data/lib/expressir/model/types/real.rb +12 -12
- data/lib/expressir/model/types/select.rb +20 -20
- data/lib/expressir/model/types/set.rb +16 -16
- data/lib/expressir/model/types/string.rb +14 -14
- data/lib/expressir/model/unique.rb +16 -14
- data/lib/expressir/model/variable.rb +18 -16
- data/lib/expressir/model/where.rb +16 -14
- data/lib/expressir/parser.rb +6 -6
- data/lib/expressir/parser/owl_parser.rb +8 -8
- data/lib/expressir/version.rb +3 -3
- data/original/examples/ap233/ap233e1_arm_lf_stepmod-2010-11-12.exp +9589 -9589
- data/original/examples/ap233/ap233e1_arm_lf_stepmod-2010-11-12.owl +36619 -36619
- data/original/examples/ap233/ap233e1_arm_lf_stepmod-2010-11-12.xml +13293 -13293
- data/original/examples/employment/eclipse/.project +17 -17
- data/original/examples/employment/eclipse/Express/employment_schema.exp +33 -33
- data/original/examples/employment/eclipse/Express/employment_schema.xmi +77 -77
- data/original/examples/employment/eclipse/Express/employment_schema.xml +92 -92
- data/original/examples/employment/eclipse/Models/Employment.uml +4 -4
- data/original/examples/employment/eclipse/Models/Employment.umldi +240 -240
- data/original/examples/employment/eclipse/readme.txt +6 -6
- data/original/examples/employment/employment_schema.exp +33 -33
- data/original/examples/employment/employment_schema.rb +232 -232
- data/original/examples/employment/employment_schema.xml +92 -92
- data/original/examples/employment/employment_schema___module.rb +46 -46
- data/original/examples/employment/employment_schema___p28attr.rb +126 -126
- data/original/examples/employment/employment_schema___p28inst.rb +26 -26
- data/original/examples/employment/example_employment_data.xml +1 -1
- data/original/examples/employment/example_employment_data_copy.xml +1 -1
- data/original/examples/employment/example_employment_reader.rb +30 -30
- data/original/examples/employment/example_employment_writer.rb +51 -51
- data/original/examples/plcs/ap239e1_arm_lf_dexlib_2010-01-06.exp +3710 -3710
- data/original/examples/plcs/ap239e1_arm_lf_dexlib_2010-01-06.owl +35880 -35880
- data/original/examples/plcs/ap239e1_arm_lf_dexlib_2010-01-06.xmi +15357 -15357
- data/original/examples/plcs/ap239e1_arm_lf_dexlib_2010-01-06.xml +9467 -9467
- data/original/examples/plcs/ap239e2_arm_lf_stepmod-2010-01-25.exp +8404 -8404
- data/original/examples/plcs/ap239e2_arm_lf_stepmod-2010-01-25.owl +43147 -43147
- data/original/examples/plcs/ap239e2_arm_lf_stepmod-2010-01-25.xmi +18341 -18341
- data/original/examples/plcs/ap239e2_arm_lf_stepmod-2010-01-25.xml +11631 -11631
- data/original/examples/syntax/remark.exp +189 -145
- data/original/examples/syntax/remark_formatted.exp +213 -174
- data/original/examples/syntax/simple.exp +3 -0
- data/original/examples/syntax/source.exp +16 -0
- data/original/examples/syntax/syntax.exp +323 -310
- data/original/examples/syntax/syntax_formatted.exp +753 -1186
- data/original/exp2ruby.rb +525 -525
- data/original/expsm.rb +34 -34
- data/original/mapping_owl.rb +1018 -1018
- data/original/mapping_sysml.rb +2281 -2281
- data/original/mapping_uml2.rb +598 -598
- data/original/mapping_uml2_eclipse.rb +433 -433
- data/original/reeper.rb +134 -134
- data/rakelib/cross-ruby.rake +308 -0
- data/spec/acceptance/express_to_owl_spec.rb +18 -18
- data/spec/acceptance/version_spec.rb +12 -12
- data/spec/expressir/express/repository_spec.rb +25 -25
- data/spec/expressir/express_exp/ap233_spec.rb +22 -22
- data/spec/expressir/express_exp/format_remark_spec.rb +28 -28
- data/spec/expressir/express_exp/format_syntax_spec.rb +28 -28
- data/spec/expressir/express_exp/head_source_spec.rb +38 -0
- data/spec/expressir/express_exp/parse_multiple_spec.rb +32 -0
- data/spec/expressir/express_exp/parse_remark_spec.rb +411 -345
- data/spec/expressir/express_exp/parse_syntax_spec.rb +3048 -2998
- data/spec/expressir/express_exp/source_spec.rb +29 -0
- data/spec/expressir/model/model_element_spec.rb +59 -0
- data/spec/expressir/model/{find_spec.rb → scope_spec.rb} +123 -110
- data/spec/expressr_spec.rb +5 -5
- data/spec/spec_helper.rb +17 -17
- data/spec/support/console_helper.rb +29 -29
- metadata +41 -371
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/CMakeLists.txt +0 -118
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2013.vcxproj +0 -637
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2013.vcxproj.filters +0 -984
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2015.vcxproj +0 -652
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2015.vcxproj.filters +0 -990
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2017.vcxproj +0 -652
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2017.vcxproj.filters +0 -990
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2019.vcxproj +0 -652
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2019.vcxproj.filters +0 -990
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp-ios/Info.plist +0 -26
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp-ios/antlrcpp_ios.h +0 -17
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/project.pbxproj +0 -3024
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +0 -8
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/xcshareddata/xcschemes/antlr4.xcscheme +0 -76
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/xcshareddata/xcschemes/antlr4_ios.xcscheme +0 -80
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/xcshareddata/xcschemes/antlr4_static.xcscheme +0 -80
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorListener.cpp +0 -10
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorListener.h +0 -167
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorStrategy.cpp +0 -10
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorStrategy.h +0 -121
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRFileStream.cpp +0 -34
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRFileStream.h +0 -27
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRInputStream.cpp +0 -155
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRInputStream.h +0 -69
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BailErrorStrategy.cpp +0 -61
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BailErrorStrategy.h +0 -59
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BaseErrorListener.cpp +0 -25
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BaseErrorListener.h +0 -36
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BufferedTokenStream.cpp +0 -414
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BufferedTokenStream.h +0 -200
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CharStream.cpp +0 -11
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CharStream.h +0 -37
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonToken.cpp +0 -195
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonToken.h +0 -158
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenFactory.cpp +0 -39
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenFactory.h +0 -74
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenStream.cpp +0 -78
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenStream.h +0 -79
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ConsoleErrorListener.cpp +0 -15
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ConsoleErrorListener.h +0 -35
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/DefaultErrorStrategy.cpp +0 -333
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/DefaultErrorStrategy.h +0 -466
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/DiagnosticErrorListener.cpp +0 -84
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/DiagnosticErrorListener.h +0 -80
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Exceptions.cpp +0 -64
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Exceptions.h +0 -99
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/FailedPredicateException.cpp +0 -51
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/FailedPredicateException.h +0 -32
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/InputMismatchException.cpp +0 -18
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/InputMismatchException.h +0 -24
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/IntStream.cpp +0 -12
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/IntStream.h +0 -218
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/InterpreterRuleContext.cpp +0 -19
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/InterpreterRuleContext.h +0 -45
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Lexer.cpp +0 -295
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Lexer.h +0 -196
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerInterpreter.cpp +0 -75
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerInterpreter.h +0 -52
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerNoViableAltException.cpp +0 -36
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerNoViableAltException.h +0 -31
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ListTokenSource.cpp +0 -92
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ListTokenSource.h +0 -88
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/NoViableAltException.cpp +0 -46
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/NoViableAltException.h +0 -42
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Parser.cpp +0 -648
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Parser.h +0 -467
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserInterpreter.cpp +0 -306
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserInterpreter.h +0 -179
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserRuleContext.cpp +0 -141
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserRuleContext.h +0 -147
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ProxyErrorListener.cpp +0 -53
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ProxyErrorListener.h +0 -38
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RecognitionException.cpp +0 -66
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RecognitionException.h +0 -98
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Recognizer.cpp +0 -167
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Recognizer.h +0 -164
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContext.cpp +0 -143
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContext.h +0 -137
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContextWithAltNum.cpp +0 -27
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContextWithAltNum.h +0 -32
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuntimeMetaData.cpp +0 -53
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuntimeMetaData.h +0 -155
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Token.cpp +0 -9
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Token.h +0 -92
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenFactory.h +0 -30
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenSource.cpp +0 -9
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenSource.h +0 -85
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStream.cpp +0 -11
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStream.h +0 -137
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStreamRewriter.cpp +0 -425
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStreamRewriter.h +0 -293
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedCharStream.cpp +0 -211
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedCharStream.h +0 -123
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedTokenStream.cpp +0 -270
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedTokenStream.h +0 -115
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Vocabulary.cpp +0 -104
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Vocabulary.h +0 -193
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/WritableToken.cpp +0 -9
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/WritableToken.h +0 -23
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/antlr4-common.h +0 -137
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/antlr4-runtime.h +0 -167
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATN.cpp +0 -209
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATN.h +0 -112
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfig.cpp +0 -113
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfig.h +0 -148
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfigSet.cpp +0 -228
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfigSet.h +0 -110
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializationOptions.cpp +0 -64
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializationOptions.h +0 -50
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializer.cpp +0 -758
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializer.h +0 -85
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSerializer.cpp +0 -621
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSerializer.h +0 -61
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSimulator.cpp +0 -63
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSimulator.h +0 -87
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNState.cpp +0 -72
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNState.h +0 -133
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNType.h +0 -20
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AbstractPredicateTransition.cpp +0 -14
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AbstractPredicateTransition.h +0 -24
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ActionTransition.cpp +0 -33
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ActionTransition.h +0 -33
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AmbiguityInfo.cpp +0 -16
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AmbiguityInfo.h +0 -68
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ArrayPredictionContext.cpp +0 -82
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ArrayPredictionContext.h +0 -43
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AtomTransition.cpp +0 -31
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AtomTransition.h +0 -30
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicBlockStartState.cpp +0 -12
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicBlockStartState.h +0 -22
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicState.cpp +0 -12
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicState.h +0 -21
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockEndState.cpp +0 -15
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockEndState.h +0 -24
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockStartState.cpp +0 -9
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockStartState.h +0 -21
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ContextSensitivityInfo.cpp +0 -14
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ContextSensitivityInfo.h +0 -47
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionEventInfo.cpp +0 -14
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionEventInfo.h +0 -70
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionInfo.cpp +0 -25
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionInfo.h +0 -227
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionState.cpp +0 -17
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionState.h +0 -30
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EmptyPredictionContext.cpp +0 -35
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EmptyPredictionContext.h +0 -27
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EpsilonTransition.cpp +0 -35
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EpsilonTransition.h +0 -39
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ErrorInfo.cpp +0 -15
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ErrorInfo.h +0 -43
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LL1Analyzer.cpp +0 -158
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LL1Analyzer.h +0 -109
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNConfig.cpp +0 -84
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNConfig.h +0 -44
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNSimulator.cpp +0 -628
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNSimulator.h +0 -210
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerAction.cpp +0 -9
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerAction.h +0 -66
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionExecutor.cpp +0 -107
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionExecutor.h +0 -115
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionType.h +0 -55
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerChannelAction.cpp +0 -55
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerChannelAction.h +0 -63
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerCustomAction.cpp +0 -62
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerCustomAction.h +0 -87
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerIndexedCustomAction.cpp +0 -63
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerIndexedCustomAction.h +0 -82
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerModeAction.cpp +0 -56
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerModeAction.h +0 -61
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerMoreAction.cpp +0 -47
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerMoreAction.h +0 -57
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPopModeAction.cpp +0 -47
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPopModeAction.h +0 -57
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPushModeAction.cpp +0 -56
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPushModeAction.h +0 -61
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerSkipAction.cpp +0 -47
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerSkipAction.h +0 -55
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerTypeAction.cpp +0 -56
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerTypeAction.h +0 -55
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LookaheadEventInfo.cpp +0 -16
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LookaheadEventInfo.h +0 -42
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LoopEndState.cpp +0 -12
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LoopEndState.h +0 -22
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Makefile +0 -67
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/NotSetTransition.cpp +0 -27
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/NotSetTransition.h +0 -25
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/OrderedATNConfigSet.cpp +0 -12
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/OrderedATNConfigSet.h +0 -20
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParseInfo.cpp +0 -102
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParseInfo.h +0 -102
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulator.cpp +0 -1366
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulator.h +0 -904
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusBlockStartState.cpp +0 -12
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusBlockStartState.h +0 -25
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusLoopbackState.cpp +0 -12
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusLoopbackState.h +0 -22
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PrecedencePredicateTransition.cpp +0 -32
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PrecedencePredicateTransition.h +0 -29
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateEvalInfo.cpp +0 -17
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateEvalInfo.h +0 -62
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateTransition.cpp +0 -34
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateTransition.h +0 -39
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContext.cpp +0 -662
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContext.h +0 -254
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionMode.cpp +0 -201
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionMode.h +0 -436
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ProfilingATNSimulator.cpp +0 -179
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ProfilingATNSimulator.h +0 -60
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RangeTransition.cpp +0 -30
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RangeTransition.h +0 -29
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStartState.cpp +0 -16
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStartState.h +0 -25
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStopState.cpp +0 -12
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStopState.h +0 -25
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleTransition.cpp +0 -37
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleTransition.h +0 -40
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContext.cpp +0 -377
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContext.h +0 -222
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SetTransition.cpp +0 -32
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SetTransition.h +0 -30
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SingletonPredictionContext.cpp +0 -81
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SingletonPredictionContext.h +0 -36
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarBlockStartState.cpp +0 -12
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarBlockStartState.h +0 -21
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopEntryState.cpp +0 -15
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopEntryState.h +0 -35
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopbackState.cpp +0 -19
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopbackState.h +0 -21
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TokensStartState.cpp +0 -12
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TokensStartState.h +0 -21
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Transition.cpp +0 -44
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Transition.h +0 -76
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/WildcardTransition.cpp +0 -25
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/WildcardTransition.h +0 -25
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFA.cpp +0 -127
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFA.h +0 -91
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFASerializer.cpp +0 -67
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFASerializer.h +0 -32
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFAState.cpp +0 -100
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFAState.h +0 -144
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/LexerDFASerializer.cpp +0 -20
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/LexerDFASerializer.h +0 -23
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/InterpreterDataReader.cpp +0 -124
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/InterpreterDataReader.h +0 -31
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Interval.cpp +0 -89
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Interval.h +0 -84
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/IntervalSet.cpp +0 -521
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/IntervalSet.h +0 -198
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/MurmurHash.cpp +0 -134
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/MurmurHash.h +0 -76
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Predicate.cpp +0 -4
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Predicate.h +0 -21
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Any.cpp +0 -13
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Any.h +0 -170
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Arrays.cpp +0 -43
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Arrays.h +0 -110
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/BitSet.h +0 -76
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/CPPUtils.cpp +0 -248
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/CPPUtils.h +0 -78
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Declarations.h +0 -163
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/StringUtils.cpp +0 -36
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/StringUtils.h +0 -54
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/guid.cpp +0 -303
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/guid.h +0 -112
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/AbstractParseTreeVisitor.h +0 -128
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNode.cpp +0 -9
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNode.h +0 -19
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNodeImpl.cpp +0 -23
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNodeImpl.h +0 -33
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/IterativeParseTreeWalker.cpp +0 -71
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/IterativeParseTreeWalker.h +0 -53
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTree.cpp +0 -15
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTree.h +0 -102
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeListener.cpp +0 -9
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeListener.h +0 -39
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeProperty.h +0 -50
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeVisitor.cpp +0 -9
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeVisitor.h +0 -57
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeWalker.cpp +0 -49
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeWalker.h +0 -31
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNode.cpp +0 -9
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNode.h +0 -32
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNodeImpl.cpp +0 -57
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNodeImpl.h +0 -33
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/Trees.cpp +0 -241
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/Trees.h +0 -78
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/Chunk.cpp +0 -9
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/Chunk.h +0 -44
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreeMatch.cpp +0 -69
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreeMatch.h +0 -132
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePattern.cpp +0 -64
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePattern.h +0 -105
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePatternMatcher.cpp +0 -371
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePatternMatcher.h +0 -185
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/RuleTagToken.cpp +0 -77
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/RuleTagToken.h +0 -117
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TagChunk.cpp +0 -39
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TagChunk.h +0 -86
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TextChunk.cpp +0 -28
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TextChunk.h +0 -51
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TokenTagToken.cpp +0 -36
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TokenTagToken.h +0 -80
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPath.cpp +0 -154
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPath.h +0 -86
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathElement.cpp +0 -31
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathElement.h +0 -40
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.cpp +0 -173
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.g4 +0 -64
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.h +0 -56
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.tokens +0 -12
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexerErrorListener.cpp +0 -13
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexerErrorListener.h +0 -22
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleAnywhereElement.cpp +0 -20
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleAnywhereElement.h +0 -27
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleElement.cpp +0 -30
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleElement.h +0 -26
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenAnywhereElement.cpp +0 -20
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenAnywhereElement.h +0 -25
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenElement.cpp +0 -33
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenElement.h +0 -26
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardAnywhereElement.cpp +0 -23
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardAnywhereElement.h +0 -23
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardElement.cpp +0 -24
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardElement.h +0 -23
- data/ext/express-parser/antlrgen/Express.interp +0 -532
- data/ext/express-parser/antlrgen/Express.tokens +0 -190
- data/ext/express-parser/antlrgen/ExpressBaseListener.cpp +0 -7
- data/ext/express-parser/antlrgen/ExpressBaseListener.h +0 -623
- data/ext/express-parser/antlrgen/ExpressBaseVisitor.cpp +0 -7
- data/ext/express-parser/antlrgen/ExpressBaseVisitor.h +0 -816
- data/ext/express-parser/antlrgen/ExpressLexer.cpp +0 -1169
- data/ext/express-parser/antlrgen/ExpressLexer.h +0 -85
- data/ext/express-parser/antlrgen/ExpressLexer.interp +0 -534
- data/ext/express-parser/antlrgen/ExpressLexer.tokens +0 -190
- data/ext/express-parser/antlrgen/ExpressListener.cpp +0 -7
- data/ext/express-parser/antlrgen/ExpressListener.h +0 -616
- data/ext/express-parser/antlrgen/ExpressParser.cpp +0 -17284
- data/ext/express-parser/antlrgen/ExpressParser.h +0 -3696
- data/ext/express-parser/antlrgen/ExpressVisitor.cpp +0 -7
- data/ext/express-parser/antlrgen/ExpressVisitor.h +0 -422
- data/ext/express-parser/express_parser.cpp +0 -17931
- data/ext/express-parser/extconf.rb +0 -34
- data/lib/express_parser.so +0 -0
@@ -1,84 +0,0 @@
|
|
1
|
-
/* Copyright (c) 2012-2017 The ANTLR Project. All rights reserved.
|
2
|
-
* Use of this file is governed by the BSD 3-clause license that
|
3
|
-
* can be found in the LICENSE.txt file in the project root.
|
4
|
-
*/
|
5
|
-
|
6
|
-
#include "misc/MurmurHash.h"
|
7
|
-
#include "atn/DecisionState.h"
|
8
|
-
#include "atn/PredictionContext.h"
|
9
|
-
#include "SemanticContext.h"
|
10
|
-
#include "atn/LexerActionExecutor.h"
|
11
|
-
|
12
|
-
#include "support/CPPUtils.h"
|
13
|
-
|
14
|
-
#include "atn/LexerATNConfig.h"
|
15
|
-
|
16
|
-
using namespace antlr4::atn;
|
17
|
-
using namespace antlrcpp;
|
18
|
-
|
19
|
-
LexerATNConfig::LexerATNConfig(ATNState *state, int alt, Ref<PredictionContext> const& context)
|
20
|
-
: ATNConfig(state, alt, context, SemanticContext::NONE), _passedThroughNonGreedyDecision(false) {
|
21
|
-
}
|
22
|
-
|
23
|
-
LexerATNConfig::LexerATNConfig(ATNState *state, int alt, Ref<PredictionContext> const& context,
|
24
|
-
Ref<LexerActionExecutor> const& lexerActionExecutor)
|
25
|
-
: ATNConfig(state, alt, context, SemanticContext::NONE), _lexerActionExecutor(lexerActionExecutor),
|
26
|
-
_passedThroughNonGreedyDecision(false) {
|
27
|
-
}
|
28
|
-
|
29
|
-
LexerATNConfig::LexerATNConfig(Ref<LexerATNConfig> const& c, ATNState *state)
|
30
|
-
: ATNConfig(c, state, c->context, c->semanticContext), _lexerActionExecutor(c->_lexerActionExecutor),
|
31
|
-
_passedThroughNonGreedyDecision(checkNonGreedyDecision(c, state)) {
|
32
|
-
}
|
33
|
-
|
34
|
-
LexerATNConfig::LexerATNConfig(Ref<LexerATNConfig> const& c, ATNState *state, Ref<LexerActionExecutor> const& lexerActionExecutor)
|
35
|
-
: ATNConfig(c, state, c->context, c->semanticContext), _lexerActionExecutor(lexerActionExecutor),
|
36
|
-
_passedThroughNonGreedyDecision(checkNonGreedyDecision(c, state)) {
|
37
|
-
}
|
38
|
-
|
39
|
-
LexerATNConfig::LexerATNConfig(Ref<LexerATNConfig> const& c, ATNState *state, Ref<PredictionContext> const& context)
|
40
|
-
: ATNConfig(c, state, context, c->semanticContext), _lexerActionExecutor(c->_lexerActionExecutor),
|
41
|
-
_passedThroughNonGreedyDecision(checkNonGreedyDecision(c, state)) {
|
42
|
-
}
|
43
|
-
|
44
|
-
Ref<LexerActionExecutor> LexerATNConfig::getLexerActionExecutor() const {
|
45
|
-
return _lexerActionExecutor;
|
46
|
-
}
|
47
|
-
|
48
|
-
bool LexerATNConfig::hasPassedThroughNonGreedyDecision() {
|
49
|
-
return _passedThroughNonGreedyDecision;
|
50
|
-
}
|
51
|
-
|
52
|
-
size_t LexerATNConfig::hashCode() const {
|
53
|
-
size_t hashCode = misc::MurmurHash::initialize(7);
|
54
|
-
hashCode = misc::MurmurHash::update(hashCode, state->stateNumber);
|
55
|
-
hashCode = misc::MurmurHash::update(hashCode, alt);
|
56
|
-
hashCode = misc::MurmurHash::update(hashCode, context);
|
57
|
-
hashCode = misc::MurmurHash::update(hashCode, semanticContext);
|
58
|
-
hashCode = misc::MurmurHash::update(hashCode, _passedThroughNonGreedyDecision ? 1 : 0);
|
59
|
-
hashCode = misc::MurmurHash::update(hashCode, _lexerActionExecutor);
|
60
|
-
hashCode = misc::MurmurHash::finish(hashCode, 6);
|
61
|
-
return hashCode;
|
62
|
-
}
|
63
|
-
|
64
|
-
bool LexerATNConfig::operator == (const LexerATNConfig& other) const
|
65
|
-
{
|
66
|
-
if (this == &other)
|
67
|
-
return true;
|
68
|
-
|
69
|
-
if (_passedThroughNonGreedyDecision != other._passedThroughNonGreedyDecision)
|
70
|
-
return false;
|
71
|
-
|
72
|
-
if (_lexerActionExecutor == nullptr)
|
73
|
-
return other._lexerActionExecutor == nullptr;
|
74
|
-
if (*_lexerActionExecutor != *(other._lexerActionExecutor)) {
|
75
|
-
return false;
|
76
|
-
}
|
77
|
-
|
78
|
-
return ATNConfig::operator == (other);
|
79
|
-
}
|
80
|
-
|
81
|
-
bool LexerATNConfig::checkNonGreedyDecision(Ref<LexerATNConfig> const& source, ATNState *target) {
|
82
|
-
return source->_passedThroughNonGreedyDecision ||
|
83
|
-
(is<DecisionState*>(target) && (static_cast<DecisionState*>(target))->nonGreedy);
|
84
|
-
}
|
@@ -1,44 +0,0 @@
|
|
1
|
-
/* Copyright (c) 2012-2017 The ANTLR Project. All rights reserved.
|
2
|
-
* Use of this file is governed by the BSD 3-clause license that
|
3
|
-
* can be found in the LICENSE.txt file in the project root.
|
4
|
-
*/
|
5
|
-
|
6
|
-
#pragma once
|
7
|
-
|
8
|
-
#include "atn/ATNConfig.h"
|
9
|
-
|
10
|
-
namespace antlr4 {
|
11
|
-
namespace atn {
|
12
|
-
|
13
|
-
class ANTLR4CPP_PUBLIC LexerATNConfig : public ATNConfig {
|
14
|
-
public:
|
15
|
-
LexerATNConfig(ATNState *state, int alt, Ref<PredictionContext> const& context);
|
16
|
-
LexerATNConfig(ATNState *state, int alt, Ref<PredictionContext> const& context, Ref<LexerActionExecutor> const& lexerActionExecutor);
|
17
|
-
|
18
|
-
LexerATNConfig(Ref<LexerATNConfig> const& c, ATNState *state);
|
19
|
-
LexerATNConfig(Ref<LexerATNConfig> const& c, ATNState *state, Ref<LexerActionExecutor> const& lexerActionExecutor);
|
20
|
-
LexerATNConfig(Ref<LexerATNConfig> const& c, ATNState *state, Ref<PredictionContext> const& context);
|
21
|
-
|
22
|
-
/**
|
23
|
-
* Gets the {@link LexerActionExecutor} capable of executing the embedded
|
24
|
-
* action(s) for the current configuration.
|
25
|
-
*/
|
26
|
-
Ref<LexerActionExecutor> getLexerActionExecutor() const;
|
27
|
-
bool hasPassedThroughNonGreedyDecision();
|
28
|
-
|
29
|
-
virtual size_t hashCode() const override;
|
30
|
-
|
31
|
-
bool operator == (const LexerATNConfig& other) const;
|
32
|
-
|
33
|
-
private:
|
34
|
-
/**
|
35
|
-
* This is the backing field for {@link #getLexerActionExecutor}.
|
36
|
-
*/
|
37
|
-
const Ref<LexerActionExecutor> _lexerActionExecutor;
|
38
|
-
const bool _passedThroughNonGreedyDecision;
|
39
|
-
|
40
|
-
static bool checkNonGreedyDecision(Ref<LexerATNConfig> const& source, ATNState *target);
|
41
|
-
};
|
42
|
-
|
43
|
-
} // namespace atn
|
44
|
-
} // namespace antlr4
|
@@ -1,628 +0,0 @@
|
|
1
|
-
/* Copyright (c) 2012-2017 The ANTLR Project. All rights reserved.
|
2
|
-
* Use of this file is governed by the BSD 3-clause license that
|
3
|
-
* can be found in the LICENSE.txt file in the project root.
|
4
|
-
*/
|
5
|
-
|
6
|
-
#include "IntStream.h"
|
7
|
-
#include "atn/OrderedATNConfigSet.h"
|
8
|
-
#include "Token.h"
|
9
|
-
#include "LexerNoViableAltException.h"
|
10
|
-
#include "atn/RuleStopState.h"
|
11
|
-
#include "atn/RuleTransition.h"
|
12
|
-
#include "atn/SingletonPredictionContext.h"
|
13
|
-
#include "atn/PredicateTransition.h"
|
14
|
-
#include "atn/ActionTransition.h"
|
15
|
-
#include "atn/TokensStartState.h"
|
16
|
-
#include "misc/Interval.h"
|
17
|
-
#include "dfa/DFA.h"
|
18
|
-
#include "Lexer.h"
|
19
|
-
|
20
|
-
#include "dfa/DFAState.h"
|
21
|
-
#include "atn/LexerATNConfig.h"
|
22
|
-
#include "atn/LexerActionExecutor.h"
|
23
|
-
#include "atn/EmptyPredictionContext.h"
|
24
|
-
|
25
|
-
#include "atn/LexerATNSimulator.h"
|
26
|
-
|
27
|
-
#define DEBUG_ATN 0
|
28
|
-
#define DEBUG_DFA 0
|
29
|
-
|
30
|
-
using namespace antlr4;
|
31
|
-
using namespace antlr4::atn;
|
32
|
-
using namespace antlrcpp;
|
33
|
-
|
34
|
-
LexerATNSimulator::SimState::~SimState() {
|
35
|
-
}
|
36
|
-
|
37
|
-
void LexerATNSimulator::SimState::reset() {
|
38
|
-
index = INVALID_INDEX;
|
39
|
-
line = 0;
|
40
|
-
charPos = INVALID_INDEX;
|
41
|
-
dfaState = nullptr; // Don't delete. It's just a reference.
|
42
|
-
}
|
43
|
-
|
44
|
-
void LexerATNSimulator::SimState::InitializeInstanceFields() {
|
45
|
-
index = INVALID_INDEX;
|
46
|
-
line = 0;
|
47
|
-
charPos = INVALID_INDEX;
|
48
|
-
}
|
49
|
-
|
50
|
-
int LexerATNSimulator::match_calls = 0;
|
51
|
-
|
52
|
-
|
53
|
-
LexerATNSimulator::LexerATNSimulator(const ATN &atn, std::vector<dfa::DFA> &decisionToDFA,
|
54
|
-
PredictionContextCache &sharedContextCache)
|
55
|
-
: LexerATNSimulator(nullptr, atn, decisionToDFA, sharedContextCache) {
|
56
|
-
}
|
57
|
-
|
58
|
-
LexerATNSimulator::LexerATNSimulator(Lexer *recog, const ATN &atn, std::vector<dfa::DFA> &decisionToDFA,
|
59
|
-
PredictionContextCache &sharedContextCache)
|
60
|
-
: ATNSimulator(atn, sharedContextCache), _recog(recog), _decisionToDFA(decisionToDFA) {
|
61
|
-
InitializeInstanceFields();
|
62
|
-
}
|
63
|
-
|
64
|
-
void LexerATNSimulator::copyState(LexerATNSimulator *simulator) {
|
65
|
-
_charPositionInLine = simulator->_charPositionInLine;
|
66
|
-
_line = simulator->_line;
|
67
|
-
_mode = simulator->_mode;
|
68
|
-
_startIndex = simulator->_startIndex;
|
69
|
-
}
|
70
|
-
|
71
|
-
size_t LexerATNSimulator::match(CharStream *input, size_t mode) {
|
72
|
-
match_calls++;
|
73
|
-
_mode = mode;
|
74
|
-
ssize_t mark = input->mark();
|
75
|
-
|
76
|
-
auto onExit = finally([input, mark] {
|
77
|
-
input->release(mark);
|
78
|
-
});
|
79
|
-
|
80
|
-
_startIndex = input->index();
|
81
|
-
_prevAccept.reset();
|
82
|
-
const dfa::DFA &dfa = _decisionToDFA[mode];
|
83
|
-
if (dfa.s0 == nullptr) {
|
84
|
-
return matchATN(input);
|
85
|
-
} else {
|
86
|
-
return execATN(input, dfa.s0);
|
87
|
-
}
|
88
|
-
}
|
89
|
-
|
90
|
-
void LexerATNSimulator::reset() {
|
91
|
-
_prevAccept.reset();
|
92
|
-
_startIndex = 0;
|
93
|
-
_line = 1;
|
94
|
-
_charPositionInLine = 0;
|
95
|
-
_mode = Lexer::DEFAULT_MODE;
|
96
|
-
}
|
97
|
-
|
98
|
-
void LexerATNSimulator::clearDFA() {
|
99
|
-
size_t size = _decisionToDFA.size();
|
100
|
-
_decisionToDFA.clear();
|
101
|
-
for (size_t d = 0; d < size; ++d) {
|
102
|
-
_decisionToDFA.emplace_back(atn.getDecisionState(d), d);
|
103
|
-
}
|
104
|
-
}
|
105
|
-
|
106
|
-
size_t LexerATNSimulator::matchATN(CharStream *input) {
|
107
|
-
ATNState *startState = atn.modeToStartState[_mode];
|
108
|
-
|
109
|
-
std::unique_ptr<ATNConfigSet> s0_closure = computeStartState(input, startState);
|
110
|
-
|
111
|
-
bool suppressEdge = s0_closure->hasSemanticContext;
|
112
|
-
s0_closure->hasSemanticContext = false;
|
113
|
-
|
114
|
-
dfa::DFAState *next = addDFAState(s0_closure.release());
|
115
|
-
if (!suppressEdge) {
|
116
|
-
_decisionToDFA[_mode].s0 = next;
|
117
|
-
}
|
118
|
-
|
119
|
-
size_t predict = execATN(input, next);
|
120
|
-
|
121
|
-
return predict;
|
122
|
-
}
|
123
|
-
|
124
|
-
size_t LexerATNSimulator::execATN(CharStream *input, dfa::DFAState *ds0) {
|
125
|
-
if (ds0->isAcceptState) {
|
126
|
-
// allow zero-length tokens
|
127
|
-
// ml: in Java code this method uses 3 params. The first is a member var of the class anyway (_prevAccept), so why pass it here?
|
128
|
-
captureSimState(input, ds0);
|
129
|
-
}
|
130
|
-
|
131
|
-
size_t t = input->LA(1);
|
132
|
-
dfa::DFAState *s = ds0; // s is current/from DFA state
|
133
|
-
|
134
|
-
while (true) { // while more work
|
135
|
-
// As we move src->trg, src->trg, we keep track of the previous trg to
|
136
|
-
// avoid looking up the DFA state again, which is expensive.
|
137
|
-
// If the previous target was already part of the DFA, we might
|
138
|
-
// be able to avoid doing a reach operation upon t. If s!=null,
|
139
|
-
// it means that semantic predicates didn't prevent us from
|
140
|
-
// creating a DFA state. Once we know s!=null, we check to see if
|
141
|
-
// the DFA state has an edge already for t. If so, we can just reuse
|
142
|
-
// it's configuration set; there's no point in re-computing it.
|
143
|
-
// This is kind of like doing DFA simulation within the ATN
|
144
|
-
// simulation because DFA simulation is really just a way to avoid
|
145
|
-
// computing reach/closure sets. Technically, once we know that
|
146
|
-
// we have a previously added DFA state, we could jump over to
|
147
|
-
// the DFA simulator. But, that would mean popping back and forth
|
148
|
-
// a lot and making things more complicated algorithmically.
|
149
|
-
// This optimization makes a lot of sense for loops within DFA.
|
150
|
-
// A character will take us back to an existing DFA state
|
151
|
-
// that already has lots of edges out of it. e.g., .* in comments.
|
152
|
-
dfa::DFAState *target = getExistingTargetState(s, t);
|
153
|
-
if (target == nullptr) {
|
154
|
-
target = computeTargetState(input, s, t);
|
155
|
-
}
|
156
|
-
|
157
|
-
if (target == ERROR.get()) {
|
158
|
-
break;
|
159
|
-
}
|
160
|
-
|
161
|
-
// If this is a consumable input element, make sure to consume before
|
162
|
-
// capturing the accept state so the input index, line, and char
|
163
|
-
// position accurately reflect the state of the interpreter at the
|
164
|
-
// end of the token.
|
165
|
-
if (t != Token::EOF) {
|
166
|
-
consume(input);
|
167
|
-
}
|
168
|
-
|
169
|
-
if (target->isAcceptState) {
|
170
|
-
captureSimState(input, target);
|
171
|
-
if (t == Token::EOF) {
|
172
|
-
break;
|
173
|
-
}
|
174
|
-
}
|
175
|
-
|
176
|
-
t = input->LA(1);
|
177
|
-
s = target; // flip; current DFA target becomes new src/from state
|
178
|
-
}
|
179
|
-
|
180
|
-
return failOrAccept(input, s->configs.get(), t);
|
181
|
-
}
|
182
|
-
|
183
|
-
dfa::DFAState *LexerATNSimulator::getExistingTargetState(dfa::DFAState *s, size_t t) {
|
184
|
-
dfa::DFAState* retval = nullptr;
|
185
|
-
_edgeLock.readLock();
|
186
|
-
if (t <= MAX_DFA_EDGE) {
|
187
|
-
auto iterator = s->edges.find(t - MIN_DFA_EDGE);
|
188
|
-
#if DEBUG_ATN == 1
|
189
|
-
if (iterator != s->edges.end()) {
|
190
|
-
std::cout << std::string("reuse state ") << s->stateNumber << std::string(" edge to ") << iterator->second->stateNumber << std::endl;
|
191
|
-
}
|
192
|
-
#endif
|
193
|
-
|
194
|
-
if (iterator != s->edges.end())
|
195
|
-
retval = iterator->second;
|
196
|
-
}
|
197
|
-
_edgeLock.readUnlock();
|
198
|
-
return retval;
|
199
|
-
}
|
200
|
-
|
201
|
-
dfa::DFAState *LexerATNSimulator::computeTargetState(CharStream *input, dfa::DFAState *s, size_t t) {
|
202
|
-
OrderedATNConfigSet *reach = new OrderedATNConfigSet(); /* mem-check: deleted on error or managed by new DFA state. */
|
203
|
-
|
204
|
-
// if we don't find an existing DFA state
|
205
|
-
// Fill reach starting from closure, following t transitions
|
206
|
-
getReachableConfigSet(input, s->configs.get(), reach, t);
|
207
|
-
|
208
|
-
if (reach->isEmpty()) { // we got nowhere on t from s
|
209
|
-
if (!reach->hasSemanticContext) {
|
210
|
-
// we got nowhere on t, don't throw out this knowledge; it'd
|
211
|
-
// cause a failover from DFA later.
|
212
|
-
delete reach;
|
213
|
-
addDFAEdge(s, t, ERROR.get());
|
214
|
-
}
|
215
|
-
|
216
|
-
// stop when we can't match any more char
|
217
|
-
return ERROR.get();
|
218
|
-
}
|
219
|
-
|
220
|
-
// Add an edge from s to target DFA found/created for reach
|
221
|
-
return addDFAEdge(s, t, reach);
|
222
|
-
}
|
223
|
-
|
224
|
-
size_t LexerATNSimulator::failOrAccept(CharStream *input, ATNConfigSet *reach, size_t t) {
|
225
|
-
if (_prevAccept.dfaState != nullptr) {
|
226
|
-
Ref<LexerActionExecutor> lexerActionExecutor = _prevAccept.dfaState->lexerActionExecutor;
|
227
|
-
accept(input, lexerActionExecutor, _startIndex, _prevAccept.index, _prevAccept.line, _prevAccept.charPos);
|
228
|
-
return _prevAccept.dfaState->prediction;
|
229
|
-
} else {
|
230
|
-
// if no accept and EOF is first char, return EOF
|
231
|
-
if (t == Token::EOF && input->index() == _startIndex) {
|
232
|
-
return Token::EOF;
|
233
|
-
}
|
234
|
-
|
235
|
-
throw LexerNoViableAltException(_recog, input, _startIndex, reach);
|
236
|
-
}
|
237
|
-
}
|
238
|
-
|
239
|
-
void LexerATNSimulator::getReachableConfigSet(CharStream *input, ATNConfigSet *closure_, ATNConfigSet *reach, size_t t) {
|
240
|
-
// this is used to skip processing for configs which have a lower priority
|
241
|
-
// than a config that already reached an accept state for the same rule
|
242
|
-
size_t skipAlt = ATN::INVALID_ALT_NUMBER;
|
243
|
-
|
244
|
-
for (auto c : closure_->configs) {
|
245
|
-
bool currentAltReachedAcceptState = c->alt == skipAlt;
|
246
|
-
if (currentAltReachedAcceptState && (std::static_pointer_cast<LexerATNConfig>(c))->hasPassedThroughNonGreedyDecision()) {
|
247
|
-
continue;
|
248
|
-
}
|
249
|
-
|
250
|
-
#if DEBUG_ATN == 1
|
251
|
-
std::cout << "testing " << getTokenName((int)t) << " at " << c->toString(true) << std::endl;
|
252
|
-
#endif
|
253
|
-
|
254
|
-
size_t n = c->state->transitions.size();
|
255
|
-
for (size_t ti = 0; ti < n; ti++) { // for each transition
|
256
|
-
Transition *trans = c->state->transitions[ti];
|
257
|
-
ATNState *target = getReachableTarget(trans, (int)t);
|
258
|
-
if (target != nullptr) {
|
259
|
-
Ref<LexerActionExecutor> lexerActionExecutor = std::static_pointer_cast<LexerATNConfig>(c)->getLexerActionExecutor();
|
260
|
-
if (lexerActionExecutor != nullptr) {
|
261
|
-
lexerActionExecutor = lexerActionExecutor->fixOffsetBeforeMatch((int)input->index() - (int)_startIndex);
|
262
|
-
}
|
263
|
-
|
264
|
-
bool treatEofAsEpsilon = t == Token::EOF;
|
265
|
-
Ref<LexerATNConfig> config = std::make_shared<LexerATNConfig>(std::static_pointer_cast<LexerATNConfig>(c),
|
266
|
-
target, lexerActionExecutor);
|
267
|
-
|
268
|
-
if (closure(input, config, reach, currentAltReachedAcceptState, true, treatEofAsEpsilon)) {
|
269
|
-
// any remaining configs for this alt have a lower priority than
|
270
|
-
// the one that just reached an accept state.
|
271
|
-
skipAlt = c->alt;
|
272
|
-
break;
|
273
|
-
}
|
274
|
-
}
|
275
|
-
}
|
276
|
-
}
|
277
|
-
}
|
278
|
-
|
279
|
-
void LexerATNSimulator::accept(CharStream *input, const Ref<LexerActionExecutor> &lexerActionExecutor, size_t /*startIndex*/,
|
280
|
-
size_t index, size_t line, size_t charPos) {
|
281
|
-
#if DEBUG_ATN == 1
|
282
|
-
std::cout << "ACTION ";
|
283
|
-
std::cout << toString(lexerActionExecutor) << std::endl;
|
284
|
-
#endif
|
285
|
-
|
286
|
-
// seek to after last char in token
|
287
|
-
input->seek(index);
|
288
|
-
_line = line;
|
289
|
-
_charPositionInLine = (int)charPos;
|
290
|
-
|
291
|
-
if (lexerActionExecutor != nullptr && _recog != nullptr) {
|
292
|
-
lexerActionExecutor->execute(_recog, input, _startIndex);
|
293
|
-
}
|
294
|
-
}
|
295
|
-
|
296
|
-
atn::ATNState *LexerATNSimulator::getReachableTarget(Transition *trans, size_t t) {
|
297
|
-
if (trans->matches(t, Lexer::MIN_CHAR_VALUE, Lexer::MAX_CHAR_VALUE)) {
|
298
|
-
return trans->target;
|
299
|
-
}
|
300
|
-
|
301
|
-
return nullptr;
|
302
|
-
}
|
303
|
-
|
304
|
-
std::unique_ptr<ATNConfigSet> LexerATNSimulator::computeStartState(CharStream *input, ATNState *p) {
|
305
|
-
Ref<PredictionContext> initialContext = PredictionContext::EMPTY; // ml: the purpose of this assignment is unclear
|
306
|
-
std::unique_ptr<ATNConfigSet> configs(new OrderedATNConfigSet());
|
307
|
-
for (size_t i = 0; i < p->transitions.size(); i++) {
|
308
|
-
ATNState *target = p->transitions[i]->target;
|
309
|
-
Ref<LexerATNConfig> c = std::make_shared<LexerATNConfig>(target, (int)(i + 1), initialContext);
|
310
|
-
closure(input, c, configs.get(), false, false, false);
|
311
|
-
}
|
312
|
-
|
313
|
-
return configs;
|
314
|
-
}
|
315
|
-
|
316
|
-
bool LexerATNSimulator::closure(CharStream *input, const Ref<LexerATNConfig> &config, ATNConfigSet *configs,
|
317
|
-
bool currentAltReachedAcceptState, bool speculative, bool treatEofAsEpsilon) {
|
318
|
-
#if DEBUG_ATN == 1
|
319
|
-
std::cout << "closure(" << config->toString(true) << ")" << std::endl;
|
320
|
-
#endif
|
321
|
-
|
322
|
-
if (is<RuleStopState *>(config->state)) {
|
323
|
-
#if DEBUG_ATN == 1
|
324
|
-
if (_recog != nullptr) {
|
325
|
-
std::cout << "closure at " << _recog->getRuleNames()[config->state->ruleIndex] << " rule stop " << config << std::endl;
|
326
|
-
} else {
|
327
|
-
std::cout << "closure at rule stop " << config << std::endl;
|
328
|
-
}
|
329
|
-
#endif
|
330
|
-
|
331
|
-
if (config->context == nullptr || config->context->hasEmptyPath()) {
|
332
|
-
if (config->context == nullptr || config->context->isEmpty()) {
|
333
|
-
configs->add(config);
|
334
|
-
return true;
|
335
|
-
} else {
|
336
|
-
configs->add(std::make_shared<LexerATNConfig>(config, config->state, PredictionContext::EMPTY));
|
337
|
-
currentAltReachedAcceptState = true;
|
338
|
-
}
|
339
|
-
}
|
340
|
-
|
341
|
-
if (config->context != nullptr && !config->context->isEmpty()) {
|
342
|
-
for (size_t i = 0; i < config->context->size(); i++) {
|
343
|
-
if (config->context->getReturnState(i) != PredictionContext::EMPTY_RETURN_STATE) {
|
344
|
-
std::weak_ptr<PredictionContext> newContext = config->context->getParent(i); // "pop" return state
|
345
|
-
ATNState *returnState = atn.states[config->context->getReturnState(i)];
|
346
|
-
Ref<LexerATNConfig> c = std::make_shared<LexerATNConfig>(config, returnState, newContext.lock());
|
347
|
-
currentAltReachedAcceptState = closure(input, c, configs, currentAltReachedAcceptState, speculative, treatEofAsEpsilon);
|
348
|
-
}
|
349
|
-
}
|
350
|
-
}
|
351
|
-
|
352
|
-
return currentAltReachedAcceptState;
|
353
|
-
}
|
354
|
-
|
355
|
-
// optimization
|
356
|
-
if (!config->state->epsilonOnlyTransitions) {
|
357
|
-
if (!currentAltReachedAcceptState || !config->hasPassedThroughNonGreedyDecision()) {
|
358
|
-
configs->add(config);
|
359
|
-
}
|
360
|
-
}
|
361
|
-
|
362
|
-
ATNState *p = config->state;
|
363
|
-
for (size_t i = 0; i < p->transitions.size(); i++) {
|
364
|
-
Transition *t = p->transitions[i];
|
365
|
-
Ref<LexerATNConfig> c = getEpsilonTarget(input, config, t, configs, speculative, treatEofAsEpsilon);
|
366
|
-
if (c != nullptr) {
|
367
|
-
currentAltReachedAcceptState = closure(input, c, configs, currentAltReachedAcceptState, speculative, treatEofAsEpsilon);
|
368
|
-
}
|
369
|
-
}
|
370
|
-
|
371
|
-
return currentAltReachedAcceptState;
|
372
|
-
}
|
373
|
-
|
374
|
-
Ref<LexerATNConfig> LexerATNSimulator::getEpsilonTarget(CharStream *input, const Ref<LexerATNConfig> &config, Transition *t,
|
375
|
-
ATNConfigSet *configs, bool speculative, bool treatEofAsEpsilon) {
|
376
|
-
|
377
|
-
Ref<LexerATNConfig> c = nullptr;
|
378
|
-
switch (t->getSerializationType()) {
|
379
|
-
case Transition::RULE: {
|
380
|
-
RuleTransition *ruleTransition = static_cast<RuleTransition*>(t);
|
381
|
-
Ref<PredictionContext> newContext = SingletonPredictionContext::create(config->context, ruleTransition->followState->stateNumber);
|
382
|
-
c = std::make_shared<LexerATNConfig>(config, t->target, newContext);
|
383
|
-
break;
|
384
|
-
}
|
385
|
-
|
386
|
-
case Transition::PRECEDENCE:
|
387
|
-
throw UnsupportedOperationException("Precedence predicates are not supported in lexers.");
|
388
|
-
|
389
|
-
case Transition::PREDICATE: {
|
390
|
-
/* Track traversing semantic predicates. If we traverse,
|
391
|
-
we cannot add a DFA state for this "reach" computation
|
392
|
-
because the DFA would not test the predicate again in the
|
393
|
-
future. Rather than creating collections of semantic predicates
|
394
|
-
like v3 and testing them on prediction, v4 will test them on the
|
395
|
-
fly all the time using the ATN not the DFA. This is slower but
|
396
|
-
semantically it's not used that often. One of the key elements to
|
397
|
-
this predicate mechanism is not adding DFA states that see
|
398
|
-
predicates immediately afterwards in the ATN. For example,
|
399
|
-
|
400
|
-
a : ID {p1}? | ID {p2}? ;
|
401
|
-
|
402
|
-
should create the start state for rule 'a' (to save start state
|
403
|
-
competition), but should not create target of ID state. The
|
404
|
-
collection of ATN states the following ID references includes
|
405
|
-
states reached by traversing predicates. Since this is when we
|
406
|
-
test them, we cannot cash the DFA state target of ID.
|
407
|
-
*/
|
408
|
-
PredicateTransition *pt = static_cast<PredicateTransition*>(t);
|
409
|
-
|
410
|
-
#if DEBUG_ATN == 1
|
411
|
-
std::cout << "EVAL rule " << pt->ruleIndex << ":" << pt->predIndex << std::endl;
|
412
|
-
#endif
|
413
|
-
|
414
|
-
configs->hasSemanticContext = true;
|
415
|
-
if (evaluatePredicate(input, pt->ruleIndex, pt->predIndex, speculative)) {
|
416
|
-
c = std::make_shared<LexerATNConfig>(config, t->target);
|
417
|
-
}
|
418
|
-
break;
|
419
|
-
}
|
420
|
-
|
421
|
-
case Transition::ACTION:
|
422
|
-
if (config->context == nullptr|| config->context->hasEmptyPath()) {
|
423
|
-
// execute actions anywhere in the start rule for a token.
|
424
|
-
//
|
425
|
-
// TODO: if the entry rule is invoked recursively, some
|
426
|
-
// actions may be executed during the recursive call. The
|
427
|
-
// problem can appear when hasEmptyPath() is true but
|
428
|
-
// isEmpty() is false. In this case, the config needs to be
|
429
|
-
// split into two contexts - one with just the empty path
|
430
|
-
// and another with everything but the empty path.
|
431
|
-
// Unfortunately, the current algorithm does not allow
|
432
|
-
// getEpsilonTarget to return two configurations, so
|
433
|
-
// additional modifications are needed before we can support
|
434
|
-
// the split operation.
|
435
|
-
Ref<LexerActionExecutor> lexerActionExecutor = LexerActionExecutor::append(config->getLexerActionExecutor(),
|
436
|
-
atn.lexerActions[static_cast<ActionTransition *>(t)->actionIndex]);
|
437
|
-
c = std::make_shared<LexerATNConfig>(config, t->target, lexerActionExecutor);
|
438
|
-
break;
|
439
|
-
}
|
440
|
-
else {
|
441
|
-
// ignore actions in referenced rules
|
442
|
-
c = std::make_shared<LexerATNConfig>(config, t->target);
|
443
|
-
break;
|
444
|
-
}
|
445
|
-
|
446
|
-
case Transition::EPSILON:
|
447
|
-
c = std::make_shared<LexerATNConfig>(config, t->target);
|
448
|
-
break;
|
449
|
-
|
450
|
-
case Transition::ATOM:
|
451
|
-
case Transition::RANGE:
|
452
|
-
case Transition::SET:
|
453
|
-
if (treatEofAsEpsilon) {
|
454
|
-
if (t->matches(Token::EOF, Lexer::MIN_CHAR_VALUE, Lexer::MAX_CHAR_VALUE)) {
|
455
|
-
c = std::make_shared<LexerATNConfig>(config, t->target);
|
456
|
-
break;
|
457
|
-
}
|
458
|
-
}
|
459
|
-
|
460
|
-
break;
|
461
|
-
|
462
|
-
default: // To silence the compiler. Other transition types are not used here.
|
463
|
-
break;
|
464
|
-
}
|
465
|
-
|
466
|
-
return c;
|
467
|
-
}
|
468
|
-
|
469
|
-
bool LexerATNSimulator::evaluatePredicate(CharStream *input, size_t ruleIndex, size_t predIndex, bool speculative) {
|
470
|
-
// assume true if no recognizer was provided
|
471
|
-
if (_recog == nullptr) {
|
472
|
-
return true;
|
473
|
-
}
|
474
|
-
|
475
|
-
if (!speculative) {
|
476
|
-
return _recog->sempred(nullptr, ruleIndex, predIndex);
|
477
|
-
}
|
478
|
-
|
479
|
-
size_t savedCharPositionInLine = _charPositionInLine;
|
480
|
-
size_t savedLine = _line;
|
481
|
-
size_t index = input->index();
|
482
|
-
ssize_t marker = input->mark();
|
483
|
-
|
484
|
-
auto onExit = finally([this, input, savedCharPositionInLine, savedLine, index, marker] {
|
485
|
-
_charPositionInLine = savedCharPositionInLine;
|
486
|
-
_line = savedLine;
|
487
|
-
input->seek(index);
|
488
|
-
input->release(marker);
|
489
|
-
});
|
490
|
-
|
491
|
-
consume(input);
|
492
|
-
return _recog->sempred(nullptr, ruleIndex, predIndex);
|
493
|
-
}
|
494
|
-
|
495
|
-
void LexerATNSimulator::captureSimState(CharStream *input, dfa::DFAState *dfaState) {
|
496
|
-
_prevAccept.index = input->index();
|
497
|
-
_prevAccept.line = _line;
|
498
|
-
_prevAccept.charPos = _charPositionInLine;
|
499
|
-
_prevAccept.dfaState = dfaState;
|
500
|
-
}
|
501
|
-
|
502
|
-
dfa::DFAState *LexerATNSimulator::addDFAEdge(dfa::DFAState *from, size_t t, ATNConfigSet *q) {
|
503
|
-
/* leading to this call, ATNConfigSet.hasSemanticContext is used as a
|
504
|
-
* marker indicating dynamic predicate evaluation makes this edge
|
505
|
-
* dependent on the specific input sequence, so the static edge in the
|
506
|
-
* DFA should be omitted. The target DFAState is still created since
|
507
|
-
* execATN has the ability to resynchronize with the DFA state cache
|
508
|
-
* following the predicate evaluation step.
|
509
|
-
*
|
510
|
-
* TJP notes: next time through the DFA, we see a pred again and eval.
|
511
|
-
* If that gets us to a previously created (but dangling) DFA
|
512
|
-
* state, we can continue in pure DFA mode from there.
|
513
|
-
*/
|
514
|
-
bool suppressEdge = q->hasSemanticContext;
|
515
|
-
q->hasSemanticContext = false;
|
516
|
-
|
517
|
-
dfa::DFAState *to = addDFAState(q);
|
518
|
-
|
519
|
-
if (suppressEdge) {
|
520
|
-
return to;
|
521
|
-
}
|
522
|
-
|
523
|
-
addDFAEdge(from, t, to);
|
524
|
-
return to;
|
525
|
-
}
|
526
|
-
|
527
|
-
void LexerATNSimulator::addDFAEdge(dfa::DFAState *p, size_t t, dfa::DFAState *q) {
|
528
|
-
if (/*t < MIN_DFA_EDGE ||*/ t > MAX_DFA_EDGE) { // MIN_DFA_EDGE is 0
|
529
|
-
// Only track edges within the DFA bounds
|
530
|
-
return;
|
531
|
-
}
|
532
|
-
|
533
|
-
_edgeLock.writeLock();
|
534
|
-
p->edges[t - MIN_DFA_EDGE] = q; // connect
|
535
|
-
_edgeLock.writeUnlock();
|
536
|
-
}
|
537
|
-
|
538
|
-
dfa::DFAState *LexerATNSimulator::addDFAState(ATNConfigSet *configs) {
|
539
|
-
/* the lexer evaluates predicates on-the-fly; by this point configs
|
540
|
-
* should not contain any configurations with unevaluated predicates.
|
541
|
-
*/
|
542
|
-
assert(!configs->hasSemanticContext);
|
543
|
-
|
544
|
-
dfa::DFAState *proposed = new dfa::DFAState(std::unique_ptr<ATNConfigSet>(configs)); /* mem-check: managed by the DFA or deleted below */
|
545
|
-
Ref<ATNConfig> firstConfigWithRuleStopState = nullptr;
|
546
|
-
for (auto &c : configs->configs) {
|
547
|
-
if (is<RuleStopState *>(c->state)) {
|
548
|
-
firstConfigWithRuleStopState = c;
|
549
|
-
break;
|
550
|
-
}
|
551
|
-
}
|
552
|
-
|
553
|
-
if (firstConfigWithRuleStopState != nullptr) {
|
554
|
-
proposed->isAcceptState = true;
|
555
|
-
proposed->lexerActionExecutor = std::dynamic_pointer_cast<LexerATNConfig>(firstConfigWithRuleStopState)->getLexerActionExecutor();
|
556
|
-
proposed->prediction = atn.ruleToTokenType[firstConfigWithRuleStopState->state->ruleIndex];
|
557
|
-
}
|
558
|
-
|
559
|
-
dfa::DFA &dfa = _decisionToDFA[_mode];
|
560
|
-
|
561
|
-
_stateLock.writeLock();
|
562
|
-
if (!dfa.states.empty()) {
|
563
|
-
auto iterator = dfa.states.find(proposed);
|
564
|
-
if (iterator != dfa.states.end()) {
|
565
|
-
delete proposed;
|
566
|
-
_stateLock.writeUnlock();
|
567
|
-
return *iterator;
|
568
|
-
}
|
569
|
-
}
|
570
|
-
|
571
|
-
proposed->stateNumber = (int)dfa.states.size();
|
572
|
-
proposed->configs->setReadonly(true);
|
573
|
-
|
574
|
-
dfa.states.insert(proposed);
|
575
|
-
_stateLock.writeUnlock();
|
576
|
-
|
577
|
-
return proposed;
|
578
|
-
}
|
579
|
-
|
580
|
-
dfa::DFA& LexerATNSimulator::getDFA(size_t mode) {
|
581
|
-
return _decisionToDFA[mode];
|
582
|
-
}
|
583
|
-
|
584
|
-
std::string LexerATNSimulator::getText(CharStream *input) {
|
585
|
-
// index is first lookahead char, don't include.
|
586
|
-
return input->getText(misc::Interval(_startIndex, input->index() - 1));
|
587
|
-
}
|
588
|
-
|
589
|
-
size_t LexerATNSimulator::getLine() const {
|
590
|
-
return _line;
|
591
|
-
}
|
592
|
-
|
593
|
-
void LexerATNSimulator::setLine(size_t line) {
|
594
|
-
_line = line;
|
595
|
-
}
|
596
|
-
|
597
|
-
size_t LexerATNSimulator::getCharPositionInLine() {
|
598
|
-
return _charPositionInLine;
|
599
|
-
}
|
600
|
-
|
601
|
-
void LexerATNSimulator::setCharPositionInLine(size_t charPositionInLine) {
|
602
|
-
_charPositionInLine = charPositionInLine;
|
603
|
-
}
|
604
|
-
|
605
|
-
void LexerATNSimulator::consume(CharStream *input) {
|
606
|
-
size_t curChar = input->LA(1);
|
607
|
-
if (curChar == '\n') {
|
608
|
-
_line++;
|
609
|
-
_charPositionInLine = 0;
|
610
|
-
} else {
|
611
|
-
_charPositionInLine++;
|
612
|
-
}
|
613
|
-
input->consume();
|
614
|
-
}
|
615
|
-
|
616
|
-
std::string LexerATNSimulator::getTokenName(size_t t) {
|
617
|
-
if (t == Token::EOF) {
|
618
|
-
return "EOF";
|
619
|
-
}
|
620
|
-
return std::string("'") + static_cast<char>(t) + std::string("'");
|
621
|
-
}
|
622
|
-
|
623
|
-
void LexerATNSimulator::InitializeInstanceFields() {
|
624
|
-
_startIndex = 0;
|
625
|
-
_line = 1;
|
626
|
-
_charPositionInLine = 0;
|
627
|
-
_mode = antlr4::Lexer::DEFAULT_MODE;
|
628
|
-
}
|