expressir 0.2.4 → 0.2.9
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.cross_rubies +30 -0
- data/.github/workflows/rake.yml +14 -15
- data/.github/workflows/release.yml +26 -17
- data/.gitignore +3 -1
- data/Gemfile +0 -2
- data/Rakefile +2 -17
- data/expressir.gemspec +10 -5
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/CMakeLists.txt +118 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2013.vcxproj +637 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2013.vcxproj.filters +984 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2015.vcxproj +652 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2015.vcxproj.filters +990 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2017.vcxproj +652 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2017.vcxproj.filters +990 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2019.vcxproj +652 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2019.vcxproj.filters +990 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp-ios/Info.plist +26 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp-ios/antlrcpp_ios.h +17 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/project.pbxproj +3024 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/project.xcworkspace/contents.xcworkspacedata +7 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/xcshareddata/xcschemes/antlr4.xcscheme +76 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/xcshareddata/xcschemes/antlr4_ios.xcscheme +80 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/xcshareddata/xcschemes/antlr4_static.xcscheme +80 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorListener.cpp +10 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorListener.h +167 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorStrategy.cpp +10 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorStrategy.h +121 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRFileStream.cpp +34 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRFileStream.h +27 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRInputStream.cpp +155 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRInputStream.h +69 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BailErrorStrategy.cpp +61 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BailErrorStrategy.h +59 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BaseErrorListener.cpp +25 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BaseErrorListener.h +36 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BufferedTokenStream.cpp +414 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/BufferedTokenStream.h +200 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CharStream.cpp +11 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CharStream.h +37 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonToken.cpp +195 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonToken.h +158 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenFactory.cpp +39 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenFactory.h +74 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenStream.cpp +78 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenStream.h +79 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ConsoleErrorListener.cpp +15 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ConsoleErrorListener.h +35 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/DefaultErrorStrategy.cpp +333 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/DefaultErrorStrategy.h +466 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/DiagnosticErrorListener.cpp +84 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/DiagnosticErrorListener.h +80 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Exceptions.cpp +64 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Exceptions.h +99 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/FailedPredicateException.cpp +51 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/FailedPredicateException.h +32 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/InputMismatchException.cpp +18 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/InputMismatchException.h +24 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/IntStream.cpp +12 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/IntStream.h +218 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/InterpreterRuleContext.cpp +19 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/InterpreterRuleContext.h +45 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Lexer.cpp +295 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Lexer.h +196 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerInterpreter.cpp +75 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerInterpreter.h +52 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerNoViableAltException.cpp +36 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerNoViableAltException.h +31 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ListTokenSource.cpp +92 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ListTokenSource.h +88 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/NoViableAltException.cpp +46 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/NoViableAltException.h +42 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Parser.cpp +648 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Parser.h +467 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserInterpreter.cpp +306 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserInterpreter.h +179 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserRuleContext.cpp +141 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserRuleContext.h +147 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ProxyErrorListener.cpp +53 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/ProxyErrorListener.h +38 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RecognitionException.cpp +66 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RecognitionException.h +98 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Recognizer.cpp +167 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Recognizer.h +164 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContext.cpp +143 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContext.h +137 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContextWithAltNum.cpp +27 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContextWithAltNum.h +32 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuntimeMetaData.cpp +53 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/RuntimeMetaData.h +155 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Token.cpp +9 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Token.h +92 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenFactory.h +30 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenSource.cpp +9 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenSource.h +85 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStream.cpp +11 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStream.h +137 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStreamRewriter.cpp +425 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStreamRewriter.h +293 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedCharStream.cpp +211 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedCharStream.h +123 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedTokenStream.cpp +270 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedTokenStream.h +115 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Vocabulary.cpp +104 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/Vocabulary.h +193 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/WritableToken.cpp +9 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/WritableToken.h +23 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/antlr4-common.h +137 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/antlr4-runtime.h +167 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATN.cpp +209 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATN.h +112 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfig.cpp +113 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfig.h +148 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfigSet.cpp +228 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfigSet.h +110 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializationOptions.cpp +64 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializationOptions.h +50 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializer.cpp +758 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializer.h +85 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSerializer.cpp +621 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSerializer.h +61 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSimulator.cpp +63 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSimulator.h +87 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNState.cpp +72 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNState.h +133 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNType.h +20 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AbstractPredicateTransition.cpp +14 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AbstractPredicateTransition.h +24 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ActionTransition.cpp +33 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ActionTransition.h +33 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AmbiguityInfo.cpp +16 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AmbiguityInfo.h +68 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ArrayPredictionContext.cpp +82 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ArrayPredictionContext.h +43 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AtomTransition.cpp +31 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AtomTransition.h +30 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicBlockStartState.cpp +12 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicBlockStartState.h +22 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicState.cpp +12 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicState.h +21 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockEndState.cpp +15 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockEndState.h +24 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockStartState.cpp +9 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockStartState.h +21 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ContextSensitivityInfo.cpp +14 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ContextSensitivityInfo.h +47 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionEventInfo.cpp +14 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionEventInfo.h +70 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionInfo.cpp +25 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionInfo.h +227 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionState.cpp +17 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionState.h +30 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EmptyPredictionContext.cpp +35 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EmptyPredictionContext.h +27 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EpsilonTransition.cpp +35 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EpsilonTransition.h +39 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ErrorInfo.cpp +15 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ErrorInfo.h +43 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LL1Analyzer.cpp +158 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LL1Analyzer.h +109 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNConfig.cpp +84 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNConfig.h +44 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNSimulator.cpp +628 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNSimulator.h +210 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerAction.cpp +9 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerAction.h +66 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionExecutor.cpp +107 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionExecutor.h +115 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionType.h +55 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerChannelAction.cpp +55 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerChannelAction.h +63 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerCustomAction.cpp +62 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerCustomAction.h +87 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerIndexedCustomAction.cpp +63 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerIndexedCustomAction.h +82 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerModeAction.cpp +56 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerModeAction.h +61 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerMoreAction.cpp +47 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerMoreAction.h +57 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPopModeAction.cpp +47 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPopModeAction.h +57 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPushModeAction.cpp +56 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPushModeAction.h +61 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerSkipAction.cpp +47 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerSkipAction.h +55 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerTypeAction.cpp +56 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerTypeAction.h +55 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LookaheadEventInfo.cpp +16 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LookaheadEventInfo.h +42 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LoopEndState.cpp +12 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LoopEndState.h +22 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Makefile +67 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/NotSetTransition.cpp +27 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/NotSetTransition.h +25 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/OrderedATNConfigSet.cpp +12 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/OrderedATNConfigSet.h +20 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParseInfo.cpp +102 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParseInfo.h +102 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulator.cpp +1366 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulator.h +904 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusBlockStartState.cpp +12 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusBlockStartState.h +25 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusLoopbackState.cpp +12 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusLoopbackState.h +22 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PrecedencePredicateTransition.cpp +32 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PrecedencePredicateTransition.h +29 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateEvalInfo.cpp +17 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateEvalInfo.h +62 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateTransition.cpp +34 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateTransition.h +39 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContext.cpp +662 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContext.h +254 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionMode.cpp +201 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionMode.h +436 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ProfilingATNSimulator.cpp +179 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ProfilingATNSimulator.h +60 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RangeTransition.cpp +30 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RangeTransition.h +29 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStartState.cpp +16 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStartState.h +25 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStopState.cpp +12 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStopState.h +25 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleTransition.cpp +37 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleTransition.h +40 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContext.cpp +377 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContext.h +222 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SetTransition.cpp +32 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SetTransition.h +30 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SingletonPredictionContext.cpp +81 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SingletonPredictionContext.h +36 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarBlockStartState.cpp +12 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarBlockStartState.h +21 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopEntryState.cpp +15 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopEntryState.h +35 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopbackState.cpp +19 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopbackState.h +21 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TokensStartState.cpp +12 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TokensStartState.h +21 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Transition.cpp +44 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Transition.h +76 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/WildcardTransition.cpp +25 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/WildcardTransition.h +25 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFA.cpp +127 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFA.h +91 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFASerializer.cpp +67 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFASerializer.h +32 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFAState.cpp +100 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFAState.h +144 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/LexerDFASerializer.cpp +20 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/LexerDFASerializer.h +23 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/InterpreterDataReader.cpp +124 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/InterpreterDataReader.h +31 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Interval.cpp +89 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Interval.h +84 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/IntervalSet.cpp +521 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/IntervalSet.h +198 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/MurmurHash.cpp +134 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/MurmurHash.h +76 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Predicate.cpp +4 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Predicate.h +21 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Any.cpp +13 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Any.h +170 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Arrays.cpp +43 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Arrays.h +110 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/BitSet.h +76 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/CPPUtils.cpp +248 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/CPPUtils.h +78 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Declarations.h +163 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/StringUtils.cpp +36 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/StringUtils.h +54 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/guid.cpp +303 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/support/guid.h +112 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/AbstractParseTreeVisitor.h +128 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNode.cpp +9 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNode.h +19 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNodeImpl.cpp +23 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNodeImpl.h +33 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/IterativeParseTreeWalker.cpp +71 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/IterativeParseTreeWalker.h +53 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTree.cpp +15 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTree.h +102 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeListener.cpp +9 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeListener.h +39 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeProperty.h +50 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeVisitor.cpp +9 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeVisitor.h +57 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeWalker.cpp +49 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeWalker.h +31 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNode.cpp +9 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNode.h +32 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNodeImpl.cpp +57 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNodeImpl.h +33 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/Trees.cpp +241 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/Trees.h +78 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/Chunk.cpp +9 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/Chunk.h +44 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreeMatch.cpp +69 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreeMatch.h +132 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePattern.cpp +64 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePattern.h +105 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePatternMatcher.cpp +371 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePatternMatcher.h +185 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/RuleTagToken.cpp +77 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/RuleTagToken.h +117 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TagChunk.cpp +39 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TagChunk.h +86 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TextChunk.cpp +28 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TextChunk.h +51 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TokenTagToken.cpp +36 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TokenTagToken.h +80 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPath.cpp +154 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPath.h +86 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathElement.cpp +31 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathElement.h +40 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.cpp +173 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.g4 +64 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.h +56 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.tokens +12 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexerErrorListener.cpp +13 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexerErrorListener.h +22 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleAnywhereElement.cpp +20 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleAnywhereElement.h +27 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleElement.cpp +30 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleElement.h +26 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenAnywhereElement.cpp +20 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenAnywhereElement.h +25 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenElement.cpp +33 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenElement.h +26 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardAnywhereElement.cpp +23 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardAnywhereElement.h +23 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardElement.cpp +24 -0
- data/ext/express-parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardElement.h +23 -0
- data/ext/express-parser/express_parser.cpp +12 -10
- data/ext/express-parser/extconf.rb +48 -25
- data/lib/expressir/express_exp/formatter.rb +3 -7
- data/lib/expressir/express_exp/parser.rb +20 -2
- data/lib/expressir/express_exp/visitor.rb +106 -55
- data/lib/expressir/model.rb +1 -0
- data/lib/expressir/model/entity.rb +3 -0
- data/lib/expressir/model/expressions/query_expression.rb +2 -2
- data/lib/expressir/model/identifier.rb +2 -0
- data/lib/expressir/model/informal_proposition.rb +11 -0
- data/lib/expressir/model/rule.rb +3 -0
- data/lib/expressir/model/schema.rb +2 -0
- data/lib/expressir/model/scope.rb +52 -3
- data/lib/expressir/model/type.rb +8 -0
- data/lib/expressir/version.rb +1 -1
- data/original/examples/syntax/remark.exp +64 -20
- data/original/examples/syntax/remark_formatted.exp +63 -19
- data/original/examples/syntax/source.exp +16 -0
- data/original/examples/syntax/syntax.exp +6 -1
- data/original/examples/syntax/syntax_formatted.exp +13 -0
- data/rakelib/cross-ruby.rake +308 -0
- data/spec/expressir/express_exp/head_source_spec.rb +41 -0
- data/spec/expressir/express_exp/parse_multiple_spec.rb +32 -0
- data/spec/expressir/express_exp/parse_remark_spec.rb +119 -53
- data/spec/expressir/express_exp/parse_syntax_spec.rb +47 -2
- data/spec/expressir/express_exp/source_spec.rb +32 -0
- data/spec/expressir/model/find_spec.rb +19 -6
- metadata +369 -23
@@ -0,0 +1,84 @@
|
|
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
|
+
}
|
@@ -0,0 +1,44 @@
|
|
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
|
@@ -0,0 +1,628 @@
|
|
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
|
+
}
|