expressir 1.4.2 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/workflows/codeql.yml +2 -14
- data/.github/workflows/rake.yml +6 -364
- data/.github/workflows/release.yml +15 -178
- data/.github/workflows/stress.yml +1 -18
- data/.rubocop.yml +1 -0
- data/.rubocop_todo.yml +7 -0
- data/Gemfile +13 -0
- data/README.adoc +6 -19
- data/Rakefile +6 -7
- data/expressir.gemspec +23 -32
- data/expressir_wrapped.txt +23068 -0
- data/lib/expressir/cli.rb +3 -2
- data/lib/expressir/express/formatter.rb +661 -661
- data/lib/expressir/express/parser.rb +299 -33
- data/lib/expressir/express/visitor.rb +238 -133
- data/lib/expressir/model/declarations/interface_item.rb +1 -1
- data/lib/expressir/version.rb +1 -1
- metadata +15 -573
- data/.cross_rubies +0 -28
- data/.gitmodules +0 -6
- data/.yardopts +0 -11
- data/exe/generate-parser +0 -51
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/CMakeLists.txt +0 -191
- 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 -948
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2022.vcxproj +0 -652
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2022.vcxproj.filters +0 -948
- 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 -3040
- 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 -76
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/xcshareddata/xcschemes/antlr4_static.xcscheme +0 -76
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.noarch.nuspec +0 -23
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.noarch.targets +0 -8
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.shared.nuspec +0 -30
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.shared.props +0 -21
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.shared.targets +0 -44
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.static.nuspec +0 -29
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.static.targets +0 -44
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/antlr4.jpg +0 -0
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/pack.cmd +0 -93
- 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 -23
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRFileStream.h +0 -30
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRInputStream.cpp +0 -180
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRInputStream.h +0 -79
- 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 -193
- 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 -336
- 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 -52
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/FailedPredicateException.h +0 -32
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/FlatHashMap.h +0 -57
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/FlatHashSet.h +0 -57
- 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 -294
- 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 -60
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerInterpreter.h +0 -46
- 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 -670
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Parser.h +0 -461
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserInterpreter.cpp +0 -294
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserInterpreter.h +0 -173
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserRuleContext.cpp +0 -138
- 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 -65
- 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 -157
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Recognizer.h +0 -160
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContext.cpp +0 -144
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContext.h +0 -141
- 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 -54
- 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 -295
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedCharStream.cpp +0 -208
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedCharStream.h +0 -117
- 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/Version.h +0 -42
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Vocabulary.cpp +0 -64
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Vocabulary.h +0 -177
- 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 -101
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/antlr4-runtime.h +0 -168
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATN.cpp +0 -159
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATN.h +0 -133
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfig.cpp +0 -106
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfig.h +0 -157
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfigSet.cpp +0 -233
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfigSet.h +0 -157
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializationOptions.cpp +0 -39
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializationOptions.h +0 -48
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializer.cpp +0 -628
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializer.h +0 -32
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSimulator.cpp +0 -33
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSimulator.h +0 -71
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNState.cpp +0 -56
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNState.h +0 -139
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNStateType.cpp +0 -33
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNStateType.h +0 -36
- 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/ActionTransition.cpp +0 -29
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ActionTransition.h +0 -35
- 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 -129
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ArrayPredictionContext.h +0 -51
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AtomTransition.cpp +0 -27
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AtomTransition.h +0 -33
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicBlockStartState.h +0 -24
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicState.h +0 -23
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockEndState.h +0 -26
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockStartState.h +0 -30
- 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 -12
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionState.h +0 -34
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EpsilonTransition.cpp +0 -31
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EpsilonTransition.h +0 -42
- 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/HashUtils.h +0 -18
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LL1Analyzer.cpp +0 -189
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LL1Analyzer.h +0 -76
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNConfig.cpp +0 -67
- 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 -621
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNSimulator.h +0 -199
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerAction.cpp +0 -15
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerAction.h +0 -100
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionExecutor.cpp +0 -108
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionExecutor.h +0 -128
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionType.h +0 -57
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerChannelAction.cpp +0 -43
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerChannelAction.h +0 -59
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerCustomAction.cpp +0 -45
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerCustomAction.h +0 -75
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerIndexedCustomAction.cpp +0 -50
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerIndexedCustomAction.h +0 -76
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerModeAction.cpp +0 -43
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerModeAction.h +0 -57
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerMoreAction.cpp +0 -36
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerMoreAction.h +0 -53
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPopModeAction.cpp +0 -36
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPopModeAction.h +0 -53
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPushModeAction.cpp +0 -43
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPushModeAction.h +0 -57
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerSkipAction.cpp +0 -36
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerSkipAction.h +0 -51
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerTypeAction.cpp +0 -43
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerTypeAction.h +0 -51
- 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.h +0 -26
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/NotSetTransition.cpp +0 -22
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/NotSetTransition.h +0 -27
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/OrderedATNConfigSet.cpp +0 -16
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/OrderedATNConfigSet.h +0 -25
- 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 -1413
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulator.h +0 -911
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulatorOptions.h +0 -50
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusBlockStartState.h +0 -29
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusLoopbackState.h +0 -25
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PrecedencePredicateTransition.cpp +0 -23
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PrecedencePredicateTransition.h +0 -35
- 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 -24
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateTransition.h +0 -50
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContext.cpp +0 -601
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContext.h +0 -225
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextCache.cpp +0 -56
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextCache.h +0 -63
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextMergeCache.cpp +0 -167
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextMergeCache.h +0 -101
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextMergeCacheOptions.h +0 -71
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextType.h +0 -21
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionMode.cpp +0 -202
- 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 -26
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RangeTransition.h +0 -31
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStartState.h +0 -26
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStopState.h +0 -27
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleTransition.cpp +0 -33
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleTransition.h +0 -42
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContext.cpp +0 -418
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContext.h +0 -237
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContextType.h +0 -23
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SerializedATNView.h +0 -101
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SetTransition.cpp +0 -28
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SetTransition.h +0 -38
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SingletonPredictionContext.cpp +0 -79
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SingletonPredictionContext.h +0 -43
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarBlockStartState.h +0 -24
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopEntryState.h +0 -37
- 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 -25
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TokensStartState.h +0 -24
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Transition.cpp +0 -36
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Transition.h +0 -65
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TransitionType.cpp +0 -27
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TransitionType.h +0 -33
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/WildcardTransition.cpp +0 -21
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/WildcardTransition.h +0 -27
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFA.cpp +0 -115
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFA.h +0 -96
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFASerializer.cpp +0 -60
- 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 -59
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFAState.h +0 -154
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/LexerDFASerializer.cpp +0 -17
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/LexerDFASerializer.h +0 -22
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/internal/Synchronization.cpp +0 -100
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/internal/Synchronization.h +0 -154
- 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 -33
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Interval.cpp +0 -61
- 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 -508
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/IntervalSet.h +0 -190
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/MurmurHash.cpp +0 -120
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/MurmurHash.h +0 -102
- 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 -8
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Any.h +0 -16
- 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 -149
- 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 -207
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/CPPUtils.h +0 -65
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Casts.h +0 -34
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Declarations.h +0 -161
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/StringUtils.cpp +0 -38
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/StringUtils.h +0 -16
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Unicode.h +0 -28
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Utf8.cpp +0 -242
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Utf8.h +0 -54
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/AbstractParseTreeVisitor.h +0 -129
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNode.h +0 -24
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNodeImpl.cpp +0 -54
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNodeImpl.h +0 -43
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/IterativeParseTreeWalker.cpp +0 -66
- 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 -12
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTree.h +0 -111
- 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/ParseTreeType.h +0 -22
- 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 -48
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeWalker.h +0 -55
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNode.h +0 -40
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNodeImpl.cpp +0 -54
- data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNodeImpl.h +0 -32
- 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 -370
- 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 -180
- 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 -53
- 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/antlr4-upstream/runtime/Cpp/runtime/tests/Utf8Test.cpp +0 -110
- 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 -685
- data/ext/express_parser/antlrgen/ExpressLexer.h +0 -78
- 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 -17591
- data/ext/express_parser/antlrgen/ExpressParser.h +0 -3692
- 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 -19405
- data/ext/express_parser/extconf.rb +0 -63
- data/rakelib/antlr4-native.rake +0 -173
- data/rakelib/cross-ruby.rake +0 -403
- data/spec/acceptance/version_spec.rb +0 -30
- data/spec/expressir/express/cache_spec.rb +0 -89
- data/spec/expressir/express/formatter_spec.rb +0 -171
- data/spec/expressir/express/parser_spec.rb +0 -141
- data/spec/expressir/model/model_element_spec.rb +0 -343
- data/spec/spec_helper.rb +0 -24
- data/spec/support/console_helper.rb +0 -29
- data/spec/syntax/multiple.exp +0 -23
- data/spec/syntax/multiple.yaml +0 -198
- data/spec/syntax/multiple_formatted.exp +0 -71
- data/spec/syntax/multiple_hyperlink_formatted.exp +0 -71
- data/spec/syntax/multiple_schema_head_hyperlink_formatted.exp +0 -13
- data/spec/syntax/remark.exp +0 -193
- data/spec/syntax/remark.yaml +0 -471
- data/spec/syntax/remark_formatted.exp +0 -228
- data/spec/syntax/single.exp +0 -4
- data/spec/syntax/single.yaml +0 -18
- data/spec/syntax/single_formatted.exp +0 -10
- data/spec/syntax/single_formatted.yaml +0 -36
- data/spec/syntax/syntax.exp +0 -333
- data/spec/syntax/syntax.yaml +0 -3509
- data/spec/syntax/syntax_formatted.exp +0 -902
- data/spec/syntax/syntax_hyperlink_formatted.exp +0 -902
- data/spec/syntax/syntax_schema_head_formatted.exp +0 -18
@@ -1,21 +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 <cstddef>
|
9
|
-
|
10
|
-
#include "antlr4-common.h"
|
11
|
-
|
12
|
-
namespace antlr4 {
|
13
|
-
namespace atn {
|
14
|
-
|
15
|
-
enum class PredictionContextType : size_t {
|
16
|
-
SINGLETON = 1,
|
17
|
-
ARRAY = 2,
|
18
|
-
};
|
19
|
-
|
20
|
-
} // namespace atn
|
21
|
-
} // namespace antlr4
|
@@ -1,202 +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 "atn/RuleStopState.h"
|
7
|
-
#include "atn/ATNConfigSet.h"
|
8
|
-
#include "atn/ATNConfig.h"
|
9
|
-
#include "misc/MurmurHash.h"
|
10
|
-
#include "SemanticContext.h"
|
11
|
-
|
12
|
-
#include "PredictionMode.h"
|
13
|
-
|
14
|
-
using namespace antlr4;
|
15
|
-
using namespace antlr4::atn;
|
16
|
-
using namespace antlrcpp;
|
17
|
-
|
18
|
-
struct AltAndContextConfigHasher
|
19
|
-
{
|
20
|
-
/**
|
21
|
-
* The hash code is only a function of the {@link ATNState#stateNumber}
|
22
|
-
* and {@link ATNConfig#context}.
|
23
|
-
*/
|
24
|
-
size_t operator () (ATNConfig *o) const {
|
25
|
-
size_t hashCode = misc::MurmurHash::initialize(7);
|
26
|
-
hashCode = misc::MurmurHash::update(hashCode, o->state->stateNumber);
|
27
|
-
hashCode = misc::MurmurHash::update(hashCode, o->context);
|
28
|
-
return misc::MurmurHash::finish(hashCode, 2);
|
29
|
-
}
|
30
|
-
};
|
31
|
-
|
32
|
-
struct AltAndContextConfigComparer {
|
33
|
-
bool operator()(ATNConfig *a, ATNConfig *b) const
|
34
|
-
{
|
35
|
-
if (a == b) {
|
36
|
-
return true;
|
37
|
-
}
|
38
|
-
return a->state->stateNumber == b->state->stateNumber && *a->context == *b->context;
|
39
|
-
}
|
40
|
-
};
|
41
|
-
|
42
|
-
bool PredictionModeClass::hasSLLConflictTerminatingPrediction(PredictionMode mode, ATNConfigSet *configs) {
|
43
|
-
/* Configs in rule stop states indicate reaching the end of the decision
|
44
|
-
* rule (local context) or end of start rule (full context). If all
|
45
|
-
* configs meet this condition, then none of the configurations is able
|
46
|
-
* to match additional input so we terminate prediction.
|
47
|
-
*/
|
48
|
-
if (allConfigsInRuleStopStates(configs)) {
|
49
|
-
return true;
|
50
|
-
}
|
51
|
-
|
52
|
-
bool heuristic;
|
53
|
-
|
54
|
-
// Pure SLL mode parsing or SLL+LL if:
|
55
|
-
// Don't bother with combining configs from different semantic
|
56
|
-
// contexts if we can fail over to full LL; costs more time
|
57
|
-
// since we'll often fail over anyway.
|
58
|
-
if (mode == PredictionMode::SLL || !configs->hasSemanticContext) {
|
59
|
-
std::vector<antlrcpp::BitSet> altsets = getConflictingAltSubsets(configs);
|
60
|
-
heuristic = hasConflictingAltSet(altsets) && !hasStateAssociatedWithOneAlt(configs);
|
61
|
-
} else {
|
62
|
-
// dup configs, tossing out semantic predicates
|
63
|
-
ATNConfigSet dup(true);
|
64
|
-
for (auto &config : configs->configs) {
|
65
|
-
Ref<ATNConfig> c = std::make_shared<ATNConfig>(*config, SemanticContext::Empty::Instance);
|
66
|
-
dup.add(c);
|
67
|
-
}
|
68
|
-
std::vector<antlrcpp::BitSet> altsets = getConflictingAltSubsets(&dup);
|
69
|
-
heuristic = hasConflictingAltSet(altsets) && !hasStateAssociatedWithOneAlt(&dup);
|
70
|
-
}
|
71
|
-
|
72
|
-
return heuristic;
|
73
|
-
}
|
74
|
-
|
75
|
-
bool PredictionModeClass::hasConfigInRuleStopState(ATNConfigSet *configs) {
|
76
|
-
for (const auto &config : configs->configs) {
|
77
|
-
if (RuleStopState::is(config->state)) {
|
78
|
-
return true;
|
79
|
-
}
|
80
|
-
}
|
81
|
-
|
82
|
-
return false;
|
83
|
-
}
|
84
|
-
|
85
|
-
bool PredictionModeClass::allConfigsInRuleStopStates(ATNConfigSet *configs) {
|
86
|
-
for (const auto &config : configs->configs) {
|
87
|
-
if (!RuleStopState::is(config->state)) {
|
88
|
-
return false;
|
89
|
-
}
|
90
|
-
}
|
91
|
-
|
92
|
-
return true;
|
93
|
-
}
|
94
|
-
|
95
|
-
size_t PredictionModeClass::resolvesToJustOneViableAlt(const std::vector<antlrcpp::BitSet>& altsets) {
|
96
|
-
return getSingleViableAlt(altsets);
|
97
|
-
}
|
98
|
-
|
99
|
-
bool PredictionModeClass::allSubsetsConflict(const std::vector<antlrcpp::BitSet>& altsets) {
|
100
|
-
return !hasNonConflictingAltSet(altsets);
|
101
|
-
}
|
102
|
-
|
103
|
-
bool PredictionModeClass::hasNonConflictingAltSet(const std::vector<antlrcpp::BitSet>& altsets) {
|
104
|
-
for (antlrcpp::BitSet alts : altsets) {
|
105
|
-
if (alts.count() == 1) {
|
106
|
-
return true;
|
107
|
-
}
|
108
|
-
}
|
109
|
-
return false;
|
110
|
-
}
|
111
|
-
|
112
|
-
bool PredictionModeClass::hasConflictingAltSet(const std::vector<antlrcpp::BitSet>& altsets) {
|
113
|
-
for (antlrcpp::BitSet alts : altsets) {
|
114
|
-
if (alts.count() > 1) {
|
115
|
-
return true;
|
116
|
-
}
|
117
|
-
}
|
118
|
-
return false;
|
119
|
-
}
|
120
|
-
|
121
|
-
bool PredictionModeClass::allSubsetsEqual(const std::vector<antlrcpp::BitSet>& altsets) {
|
122
|
-
if (altsets.empty()) {
|
123
|
-
return true;
|
124
|
-
}
|
125
|
-
|
126
|
-
const antlrcpp::BitSet& first = *altsets.begin();
|
127
|
-
for (const antlrcpp::BitSet& alts : altsets) {
|
128
|
-
if (alts != first) {
|
129
|
-
return false;
|
130
|
-
}
|
131
|
-
}
|
132
|
-
return true;
|
133
|
-
}
|
134
|
-
|
135
|
-
size_t PredictionModeClass::getUniqueAlt(const std::vector<antlrcpp::BitSet>& altsets) {
|
136
|
-
antlrcpp::BitSet all = getAlts(altsets);
|
137
|
-
if (all.count() == 1) {
|
138
|
-
return all.nextSetBit(0);
|
139
|
-
}
|
140
|
-
return ATN::INVALID_ALT_NUMBER;
|
141
|
-
}
|
142
|
-
|
143
|
-
antlrcpp::BitSet PredictionModeClass::getAlts(const std::vector<antlrcpp::BitSet>& altsets) {
|
144
|
-
antlrcpp::BitSet all;
|
145
|
-
for (const auto &alts : altsets) {
|
146
|
-
all |= alts;
|
147
|
-
}
|
148
|
-
|
149
|
-
return all;
|
150
|
-
}
|
151
|
-
|
152
|
-
antlrcpp::BitSet PredictionModeClass::getAlts(ATNConfigSet *configs) {
|
153
|
-
antlrcpp::BitSet alts;
|
154
|
-
for (const auto &config : configs->configs) {
|
155
|
-
alts.set(config->alt);
|
156
|
-
}
|
157
|
-
return alts;
|
158
|
-
}
|
159
|
-
|
160
|
-
std::vector<antlrcpp::BitSet> PredictionModeClass::getConflictingAltSubsets(ATNConfigSet *configs) {
|
161
|
-
std::unordered_map<ATNConfig*, antlrcpp::BitSet, AltAndContextConfigHasher, AltAndContextConfigComparer> configToAlts;
|
162
|
-
for (auto &config : configs->configs) {
|
163
|
-
configToAlts[config.get()].set(config->alt);
|
164
|
-
}
|
165
|
-
std::vector<antlrcpp::BitSet> values;
|
166
|
-
values.reserve(configToAlts.size());
|
167
|
-
for (const auto &pair : configToAlts) {
|
168
|
-
values.push_back(pair.second);
|
169
|
-
}
|
170
|
-
return values;
|
171
|
-
}
|
172
|
-
|
173
|
-
std::unordered_map<ATNState*, antlrcpp::BitSet> PredictionModeClass::getStateToAltMap(ATNConfigSet *configs) {
|
174
|
-
std::unordered_map<ATNState*, antlrcpp::BitSet> m;
|
175
|
-
for (const auto &c : configs->configs) {
|
176
|
-
m[c->state].set(c->alt);
|
177
|
-
}
|
178
|
-
return m;
|
179
|
-
}
|
180
|
-
|
181
|
-
bool PredictionModeClass::hasStateAssociatedWithOneAlt(ATNConfigSet *configs) {
|
182
|
-
auto x = getStateToAltMap(configs);
|
183
|
-
for (const auto &pair : x){
|
184
|
-
if (pair.second.count() == 1) return true;
|
185
|
-
}
|
186
|
-
return false;
|
187
|
-
}
|
188
|
-
|
189
|
-
size_t PredictionModeClass::getSingleViableAlt(const std::vector<antlrcpp::BitSet>& altsets) {
|
190
|
-
antlrcpp::BitSet viableAlts;
|
191
|
-
for (const auto &alts : altsets) {
|
192
|
-
size_t minAlt = alts.nextSetBit(0);
|
193
|
-
|
194
|
-
viableAlts.set(minAlt);
|
195
|
-
if (viableAlts.count() > 1) // more than 1 viable alt
|
196
|
-
{
|
197
|
-
return ATN::INVALID_ALT_NUMBER;
|
198
|
-
}
|
199
|
-
}
|
200
|
-
|
201
|
-
return viableAlts.nextSetBit(0);
|
202
|
-
}
|
@@ -1,436 +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 "support/BitSet.h"
|
9
|
-
|
10
|
-
namespace antlr4 {
|
11
|
-
namespace atn {
|
12
|
-
|
13
|
-
/**
|
14
|
-
* This enumeration defines the prediction modes available in ANTLR 4 along with
|
15
|
-
* utility methods for analyzing configuration sets for conflicts and/or
|
16
|
-
* ambiguities.
|
17
|
-
*/
|
18
|
-
enum class PredictionMode {
|
19
|
-
/**
|
20
|
-
* The SLL(*) prediction mode. This prediction mode ignores the current
|
21
|
-
* parser context when making predictions. This is the fastest prediction
|
22
|
-
* mode, and provides correct results for many grammars. This prediction
|
23
|
-
* mode is more powerful than the prediction mode provided by ANTLR 3, but
|
24
|
-
* may result in syntax errors for grammar and input combinations which are
|
25
|
-
* not SLL.
|
26
|
-
*
|
27
|
-
* <p>
|
28
|
-
* When using this prediction mode, the parser will either return a correct
|
29
|
-
* parse tree (i.e. the same parse tree that would be returned with the
|
30
|
-
* {@link #LL} prediction mode), or it will report a syntax error. If a
|
31
|
-
* syntax error is encountered when using the {@link #SLL} prediction mode,
|
32
|
-
* it may be due to either an actual syntax error in the input or indicate
|
33
|
-
* that the particular combination of grammar and input requires the more
|
34
|
-
* powerful {@link #LL} prediction abilities to complete successfully.</p>
|
35
|
-
*
|
36
|
-
* <p>
|
37
|
-
* This prediction mode does not provide any guarantees for prediction
|
38
|
-
* behavior for syntactically-incorrect inputs.</p>
|
39
|
-
*/
|
40
|
-
SLL,
|
41
|
-
|
42
|
-
/**
|
43
|
-
* The LL(*) prediction mode. This prediction mode allows the current parser
|
44
|
-
* context to be used for resolving SLL conflicts that occur during
|
45
|
-
* prediction. This is the fastest prediction mode that guarantees correct
|
46
|
-
* parse results for all combinations of grammars with syntactically correct
|
47
|
-
* inputs.
|
48
|
-
*
|
49
|
-
* <p>
|
50
|
-
* When using this prediction mode, the parser will make correct decisions
|
51
|
-
* for all syntactically-correct grammar and input combinations. However, in
|
52
|
-
* cases where the grammar is truly ambiguous this prediction mode might not
|
53
|
-
* report a precise answer for <em>exactly which</em> alternatives are
|
54
|
-
* ambiguous.</p>
|
55
|
-
*
|
56
|
-
* <p>
|
57
|
-
* This prediction mode does not provide any guarantees for prediction
|
58
|
-
* behavior for syntactically-incorrect inputs.</p>
|
59
|
-
*/
|
60
|
-
LL,
|
61
|
-
|
62
|
-
/**
|
63
|
-
* The LL(*) prediction mode with exact ambiguity detection. In addition to
|
64
|
-
* the correctness guarantees provided by the {@link #LL} prediction mode,
|
65
|
-
* this prediction mode instructs the prediction algorithm to determine the
|
66
|
-
* complete and exact set of ambiguous alternatives for every ambiguous
|
67
|
-
* decision encountered while parsing.
|
68
|
-
*
|
69
|
-
* <p>
|
70
|
-
* This prediction mode may be used for diagnosing ambiguities during
|
71
|
-
* grammar development. Due to the performance overhead of calculating sets
|
72
|
-
* of ambiguous alternatives, this prediction mode should be avoided when
|
73
|
-
* the exact results are not necessary.</p>
|
74
|
-
*
|
75
|
-
* <p>
|
76
|
-
* This prediction mode does not provide any guarantees for prediction
|
77
|
-
* behavior for syntactically-incorrect inputs.</p>
|
78
|
-
*/
|
79
|
-
LL_EXACT_AMBIG_DETECTION
|
80
|
-
};
|
81
|
-
|
82
|
-
class ANTLR4CPP_PUBLIC PredictionModeClass {
|
83
|
-
public:
|
84
|
-
/**
|
85
|
-
* Computes the SLL prediction termination condition.
|
86
|
-
*
|
87
|
-
* <p>
|
88
|
-
* This method computes the SLL prediction termination condition for both of
|
89
|
-
* the following cases.</p>
|
90
|
-
*
|
91
|
-
* <ul>
|
92
|
-
* <li>The usual SLL+LL fallback upon SLL conflict</li>
|
93
|
-
* <li>Pure SLL without LL fallback</li>
|
94
|
-
* </ul>
|
95
|
-
*
|
96
|
-
* <p><strong>COMBINED SLL+LL PARSING</strong></p>
|
97
|
-
*
|
98
|
-
* <p>When LL-fallback is enabled upon SLL conflict, correct predictions are
|
99
|
-
* ensured regardless of how the termination condition is computed by this
|
100
|
-
* method. Due to the substantially higher cost of LL prediction, the
|
101
|
-
* prediction should only fall back to LL when the additional lookahead
|
102
|
-
* cannot lead to a unique SLL prediction.</p>
|
103
|
-
*
|
104
|
-
* <p>Assuming combined SLL+LL parsing, an SLL configuration set with only
|
105
|
-
* conflicting subsets should fall back to full LL, even if the
|
106
|
-
* configuration sets don't resolve to the same alternative (e.g.
|
107
|
-
* {@code {1,2}} and {@code {3,4}}. If there is at least one non-conflicting
|
108
|
-
* configuration, SLL could continue with the hopes that more lookahead will
|
109
|
-
* resolve via one of those non-conflicting configurations.</p>
|
110
|
-
*
|
111
|
-
* <p>Here's the prediction termination rule them: SLL (for SLL+LL parsing)
|
112
|
-
* stops when it sees only conflicting configuration subsets. In contrast,
|
113
|
-
* full LL keeps going when there is uncertainty.</p>
|
114
|
-
*
|
115
|
-
* <p><strong>HEURISTIC</strong></p>
|
116
|
-
*
|
117
|
-
* <p>As a heuristic, we stop prediction when we see any conflicting subset
|
118
|
-
* unless we see a state that only has one alternative associated with it.
|
119
|
-
* The single-alt-state thing lets prediction continue upon rules like
|
120
|
-
* (otherwise, it would admit defeat too soon):</p>
|
121
|
-
*
|
122
|
-
* <p>{@code [12|1|[], 6|2|[], 12|2|[]]. s : (ID | ID ID?) ';' ;}</p>
|
123
|
-
*
|
124
|
-
* <p>When the ATN simulation reaches the state before {@code ';'}, it has a
|
125
|
-
* DFA state that looks like: {@code [12|1|[], 6|2|[], 12|2|[]]}. Naturally
|
126
|
-
* {@code 12|1|[]} and {@code 12|2|[]} conflict, but we cannot stop
|
127
|
-
* processing this node because alternative to has another way to continue,
|
128
|
-
* via {@code [6|2|[]]}.</p>
|
129
|
-
*
|
130
|
-
* <p>It also let's us continue for this rule:</p>
|
131
|
-
*
|
132
|
-
* <p>{@code [1|1|[], 1|2|[], 8|3|[]] a : A | A | A B ;}</p>
|
133
|
-
*
|
134
|
-
* <p>After matching input A, we reach the stop state for rule A, state 1.
|
135
|
-
* State 8 is the state right before B. Clearly alternatives 1 and 2
|
136
|
-
* conflict and no amount of further lookahead will separate the two.
|
137
|
-
* However, alternative 3 will be able to continue and so we do not stop
|
138
|
-
* working on this state. In the previous example, we're concerned with
|
139
|
-
* states associated with the conflicting alternatives. Here alt 3 is not
|
140
|
-
* associated with the conflicting configs, but since we can continue
|
141
|
-
* looking for input reasonably, don't declare the state done.</p>
|
142
|
-
*
|
143
|
-
* <p><strong>PURE SLL PARSING</strong></p>
|
144
|
-
*
|
145
|
-
* <p>To handle pure SLL parsing, all we have to do is make sure that we
|
146
|
-
* combine stack contexts for configurations that differ only by semantic
|
147
|
-
* predicate. From there, we can do the usual SLL termination heuristic.</p>
|
148
|
-
*
|
149
|
-
* <p><strong>PREDICATES IN SLL+LL PARSING</strong></p>
|
150
|
-
*
|
151
|
-
* <p>SLL decisions don't evaluate predicates until after they reach DFA stop
|
152
|
-
* states because they need to create the DFA cache that works in all
|
153
|
-
* semantic situations. In contrast, full LL evaluates predicates collected
|
154
|
-
* during start state computation so it can ignore predicates thereafter.
|
155
|
-
* This means that SLL termination detection can totally ignore semantic
|
156
|
-
* predicates.</p>
|
157
|
-
*
|
158
|
-
* <p>Implementation-wise, {@link ATNConfigSet} combines stack contexts but not
|
159
|
-
* semantic predicate contexts so we might see two configurations like the
|
160
|
-
* following.</p>
|
161
|
-
*
|
162
|
-
* <p>{@code (s, 1, x, {}), (s, 1, x', {p})}</p>
|
163
|
-
*
|
164
|
-
* <p>Before testing these configurations against others, we have to merge
|
165
|
-
* {@code x} and {@code x'} (without modifying the existing configurations).
|
166
|
-
* For example, we test {@code (x+x')==x''} when looking for conflicts in
|
167
|
-
* the following configurations.</p>
|
168
|
-
*
|
169
|
-
* <p>{@code (s, 1, x, {}), (s, 1, x', {p}), (s, 2, x'', {})}</p>
|
170
|
-
*
|
171
|
-
* <p>If the configuration set has predicates (as indicated by
|
172
|
-
* {@link ATNConfigSet#hasSemanticContext}), this algorithm makes a copy of
|
173
|
-
* the configurations to strip out all of the predicates so that a standard
|
174
|
-
* {@link ATNConfigSet} will merge everything ignoring predicates.</p>
|
175
|
-
*/
|
176
|
-
static bool hasSLLConflictTerminatingPrediction(PredictionMode mode, ATNConfigSet *configs);
|
177
|
-
|
178
|
-
/// <summary>
|
179
|
-
/// Checks if any configuration in {@code configs} is in a
|
180
|
-
/// <seealso cref="RuleStopState"/>. Configurations meeting this condition have
|
181
|
-
/// reached
|
182
|
-
/// the end of the decision rule (local context) or end of start rule (full
|
183
|
-
/// context).
|
184
|
-
/// </summary>
|
185
|
-
/// <param name="configs"> the configuration set to test </param>
|
186
|
-
/// <returns> {@code true} if any configuration in {@code configs} is in a
|
187
|
-
/// <seealso cref="RuleStopState"/>, otherwise {@code false} </returns>
|
188
|
-
static bool hasConfigInRuleStopState(ATNConfigSet *configs);
|
189
|
-
|
190
|
-
/// <summary>
|
191
|
-
/// Checks if all configurations in {@code configs} are in a
|
192
|
-
/// <seealso cref="RuleStopState"/>. Configurations meeting this condition have
|
193
|
-
/// reached
|
194
|
-
/// the end of the decision rule (local context) or end of start rule (full
|
195
|
-
/// context).
|
196
|
-
/// </summary>
|
197
|
-
/// <param name="configs"> the configuration set to test </param>
|
198
|
-
/// <returns> {@code true} if all configurations in {@code configs} are in a
|
199
|
-
/// <seealso cref="RuleStopState"/>, otherwise {@code false} </returns>
|
200
|
-
static bool allConfigsInRuleStopStates(ATNConfigSet *configs);
|
201
|
-
|
202
|
-
/**
|
203
|
-
* Full LL prediction termination.
|
204
|
-
*
|
205
|
-
* <p>Can we stop looking ahead during ATN simulation or is there some
|
206
|
-
* uncertainty as to which alternative we will ultimately pick, after
|
207
|
-
* consuming more input? Even if there are partial conflicts, we might know
|
208
|
-
* that everything is going to resolve to the same minimum alternative. That
|
209
|
-
* means we can stop since no more lookahead will change that fact. On the
|
210
|
-
* other hand, there might be multiple conflicts that resolve to different
|
211
|
-
* minimums. That means we need more look ahead to decide which of those
|
212
|
-
* alternatives we should predict.</p>
|
213
|
-
*
|
214
|
-
* <p>The basic idea is to split the set of configurations {@code C}, into
|
215
|
-
* conflicting subsets {@code (s, _, ctx, _)} and singleton subsets with
|
216
|
-
* non-conflicting configurations. Two configurations conflict if they have
|
217
|
-
* identical {@link ATNConfig#state} and {@link ATNConfig#context} values
|
218
|
-
* but different {@link ATNConfig#alt} value, e.g. {@code (s, i, ctx, _)}
|
219
|
-
* and {@code (s, j, ctx, _)} for {@code i!=j}.</p>
|
220
|
-
*
|
221
|
-
* <p>Reduce these configuration subsets to the set of possible alternatives.
|
222
|
-
* You can compute the alternative subsets in one pass as follows:</p>
|
223
|
-
*
|
224
|
-
* <p>{@code A_s,ctx = {i | (s, i, ctx, _)}} for each configuration in
|
225
|
-
* {@code C} holding {@code s} and {@code ctx} fixed.</p>
|
226
|
-
*
|
227
|
-
* <p>Or in pseudo-code, for each configuration {@code c} in {@code C}:</p>
|
228
|
-
*
|
229
|
-
* <pre>
|
230
|
-
* map[c] U= c.{@link ATNConfig#alt alt} # map hash/equals uses s and x, not
|
231
|
-
* alt and not pred
|
232
|
-
* </pre>
|
233
|
-
*
|
234
|
-
* <p>The values in {@code map} are the set of {@code A_s,ctx} sets.</p>
|
235
|
-
*
|
236
|
-
* <p>If {@code |A_s,ctx|=1} then there is no conflict associated with
|
237
|
-
* {@code s} and {@code ctx}.</p>
|
238
|
-
*
|
239
|
-
* <p>Reduce the subsets to singletons by choosing a minimum of each subset. If
|
240
|
-
* the union of these alternative subsets is a singleton, then no amount of
|
241
|
-
* more lookahead will help us. We will always pick that alternative. If,
|
242
|
-
* however, there is more than one alternative, then we are uncertain which
|
243
|
-
* alternative to predict and must continue looking for resolution. We may
|
244
|
-
* or may not discover an ambiguity in the future, even if there are no
|
245
|
-
* conflicting subsets this round.</p>
|
246
|
-
*
|
247
|
-
* <p>The biggest sin is to terminate early because it means we've made a
|
248
|
-
* decision but were uncertain as to the eventual outcome. We haven't used
|
249
|
-
* enough lookahead. On the other hand, announcing a conflict too late is no
|
250
|
-
* big deal; you will still have the conflict. It's just inefficient. It
|
251
|
-
* might even look until the end of file.</p>
|
252
|
-
*
|
253
|
-
* <p>No special consideration for semantic predicates is required because
|
254
|
-
* predicates are evaluated on-the-fly for full LL prediction, ensuring that
|
255
|
-
* no configuration contains a semantic context during the termination
|
256
|
-
* check.</p>
|
257
|
-
*
|
258
|
-
* <p><strong>CONFLICTING CONFIGS</strong></p>
|
259
|
-
*
|
260
|
-
* <p>Two configurations {@code (s, i, x)} and {@code (s, j, x')}, conflict
|
261
|
-
* when {@code i!=j} but {@code x=x'}. Because we merge all
|
262
|
-
* {@code (s, i, _)} configurations together, that means that there are at
|
263
|
-
* most {@code n} configurations associated with state {@code s} for
|
264
|
-
* {@code n} possible alternatives in the decision. The merged stacks
|
265
|
-
* complicate the comparison of configuration contexts {@code x} and
|
266
|
-
* {@code x'}. Sam checks to see if one is a subset of the other by calling
|
267
|
-
* merge and checking to see if the merged result is either {@code x} or
|
268
|
-
* {@code x'}. If the {@code x} associated with lowest alternative {@code i}
|
269
|
-
* is the superset, then {@code i} is the only possible prediction since the
|
270
|
-
* others resolve to {@code min(i)} as well. However, if {@code x} is
|
271
|
-
* associated with {@code j>i} then at least one stack configuration for
|
272
|
-
* {@code j} is not in conflict with alternative {@code i}. The algorithm
|
273
|
-
* should keep going, looking for more lookahead due to the uncertainty.</p>
|
274
|
-
*
|
275
|
-
* <p>For simplicity, I'm doing a equality check between {@code x} and
|
276
|
-
* {@code x'} that lets the algorithm continue to consume lookahead longer
|
277
|
-
* than necessary. The reason I like the equality is of course the
|
278
|
-
* simplicity but also because that is the test you need to detect the
|
279
|
-
* alternatives that are actually in conflict.</p>
|
280
|
-
*
|
281
|
-
* <p><strong>CONTINUE/STOP RULE</strong></p>
|
282
|
-
*
|
283
|
-
* <p>Continue if union of resolved alternative sets from non-conflicting and
|
284
|
-
* conflicting alternative subsets has more than one alternative. We are
|
285
|
-
* uncertain about which alternative to predict.</p>
|
286
|
-
*
|
287
|
-
* <p>The complete set of alternatives, {@code [i for (_,i,_)]}, tells us which
|
288
|
-
* alternatives are still in the running for the amount of input we've
|
289
|
-
* consumed at this point. The conflicting sets let us to strip away
|
290
|
-
* configurations that won't lead to more states because we resolve
|
291
|
-
* conflicts to the configuration with a minimum alternate for the
|
292
|
-
* conflicting set.</p>
|
293
|
-
*
|
294
|
-
* <p><strong>CASES</strong></p>
|
295
|
-
*
|
296
|
-
* <ul>
|
297
|
-
*
|
298
|
-
* <li>no conflicts and more than 1 alternative in set => continue</li>
|
299
|
-
*
|
300
|
-
* <li> {@code (s, 1, x)}, {@code (s, 2, x)}, {@code (s, 3, z)},
|
301
|
-
* {@code (s', 1, y)}, {@code (s', 2, y)} yields non-conflicting set
|
302
|
-
* {@code {3}} U conflicting sets {@code min({1,2})} U {@code min({1,2})} =
|
303
|
-
* {@code {1,3}} => continue
|
304
|
-
* </li>
|
305
|
-
*
|
306
|
-
* <li>{@code (s, 1, x)}, {@code (s, 2, x)}, {@code (s', 1, y)},
|
307
|
-
* {@code (s', 2, y)}, {@code (s'', 1, z)} yields non-conflicting set
|
308
|
-
* {@code {1}} U conflicting sets {@code min({1,2})} U {@code min({1,2})} =
|
309
|
-
* {@code {1}} => stop and predict 1</li>
|
310
|
-
*
|
311
|
-
* <li>{@code (s, 1, x)}, {@code (s, 2, x)}, {@code (s', 1, y)},
|
312
|
-
* {@code (s', 2, y)} yields conflicting, reduced sets {@code {1}} U
|
313
|
-
* {@code {1}} = {@code {1}} => stop and predict 1, can announce
|
314
|
-
* ambiguity {@code {1,2}}</li>
|
315
|
-
*
|
316
|
-
* <li>{@code (s, 1, x)}, {@code (s, 2, x)}, {@code (s', 2, y)},
|
317
|
-
* {@code (s', 3, y)} yields conflicting, reduced sets {@code {1}} U
|
318
|
-
* {@code {2}} = {@code {1,2}} => continue</li>
|
319
|
-
*
|
320
|
-
* <li>{@code (s, 1, x)}, {@code (s, 2, x)}, {@code (s', 3, y)},
|
321
|
-
* {@code (s', 4, y)} yields conflicting, reduced sets {@code {1}} U
|
322
|
-
* {@code {3}} = {@code {1,3}} => continue</li>
|
323
|
-
*
|
324
|
-
* </ul>
|
325
|
-
*
|
326
|
-
* <p><strong>EXACT AMBIGUITY DETECTION</strong></p>
|
327
|
-
*
|
328
|
-
* <p>If all states report the same conflicting set of alternatives, then we
|
329
|
-
* know we have the exact ambiguity set.</p>
|
330
|
-
*
|
331
|
-
* <p><code>|A_<em>i</em>|>1</code> and
|
332
|
-
* <code>A_<em>i</em> = A_<em>j</em></code> for all <em>i</em>, <em>j</em>.</p>
|
333
|
-
*
|
334
|
-
* <p>In other words, we continue examining lookahead until all {@code A_i}
|
335
|
-
* have more than one alternative and all {@code A_i} are the same. If
|
336
|
-
* {@code A={{1,2}, {1,3}}}, then regular LL prediction would terminate
|
337
|
-
* because the resolved set is {@code {1}}. To determine what the real
|
338
|
-
* ambiguity is, we have to know whether the ambiguity is between one and
|
339
|
-
* two or one and three so we keep going. We can only stop prediction when
|
340
|
-
* we need exact ambiguity detection when the sets look like
|
341
|
-
* {@code A={{1,2}}} or {@code {{1,2},{1,2}}}, etc...</p>
|
342
|
-
*/
|
343
|
-
static size_t resolvesToJustOneViableAlt(const std::vector<antlrcpp::BitSet> &altsets);
|
344
|
-
|
345
|
-
/// <summary>
|
346
|
-
/// Determines if every alternative subset in {@code altsets} contains more
|
347
|
-
/// than one alternative.
|
348
|
-
/// </summary>
|
349
|
-
/// <param name="altsets"> a collection of alternative subsets </param>
|
350
|
-
/// <returns> {@code true} if every <seealso cref="BitSet"/> in {@code altsets}
|
351
|
-
/// has
|
352
|
-
/// <seealso cref="BitSet#cardinality cardinality"/> > 1, otherwise {@code
|
353
|
-
/// false} </returns>
|
354
|
-
static bool allSubsetsConflict(const std::vector<antlrcpp::BitSet> &altsets);
|
355
|
-
|
356
|
-
/// <summary>
|
357
|
-
/// Determines if any single alternative subset in {@code altsets} contains
|
358
|
-
/// exactly one alternative.
|
359
|
-
/// </summary>
|
360
|
-
/// <param name="altsets"> a collection of alternative subsets </param>
|
361
|
-
/// <returns> {@code true} if {@code altsets} contains a <seealso
|
362
|
-
/// cref="BitSet"/> with
|
363
|
-
/// <seealso cref="BitSet#cardinality cardinality"/> 1, otherwise {@code false}
|
364
|
-
/// </returns>
|
365
|
-
static bool hasNonConflictingAltSet(const std::vector<antlrcpp::BitSet> &altsets);
|
366
|
-
|
367
|
-
/// <summary>
|
368
|
-
/// Determines if any single alternative subset in {@code altsets} contains
|
369
|
-
/// more than one alternative.
|
370
|
-
/// </summary>
|
371
|
-
/// <param name="altsets"> a collection of alternative subsets </param>
|
372
|
-
/// <returns> {@code true} if {@code altsets} contains a <seealso
|
373
|
-
/// cref="BitSet"/> with
|
374
|
-
/// <seealso cref="BitSet#cardinality cardinality"/> > 1, otherwise {@code
|
375
|
-
/// false} </returns>
|
376
|
-
static bool hasConflictingAltSet(const std::vector<antlrcpp::BitSet> &altsets);
|
377
|
-
|
378
|
-
/// <summary>
|
379
|
-
/// Determines if every alternative subset in {@code altsets} is equivalent.
|
380
|
-
/// </summary>
|
381
|
-
/// <param name="altsets"> a collection of alternative subsets </param>
|
382
|
-
/// <returns> {@code true} if every member of {@code altsets} is equal to the
|
383
|
-
/// others, otherwise {@code false} </returns>
|
384
|
-
static bool allSubsetsEqual(const std::vector<antlrcpp::BitSet> &altsets);
|
385
|
-
|
386
|
-
/// <summary>
|
387
|
-
/// Returns the unique alternative predicted by all alternative subsets in
|
388
|
-
/// {@code altsets}. If no such alternative exists, this method returns
|
389
|
-
/// <seealso cref="ATN#INVALID_ALT_NUMBER"/>.
|
390
|
-
/// </summary>
|
391
|
-
/// <param name="altsets"> a collection of alternative subsets </param>
|
392
|
-
static size_t getUniqueAlt(const std::vector<antlrcpp::BitSet> &altsets);
|
393
|
-
|
394
|
-
/// <summary>
|
395
|
-
/// Gets the complete set of represented alternatives for a collection of
|
396
|
-
/// alternative subsets. This method returns the union of each <seealso
|
397
|
-
/// cref="BitSet"/>
|
398
|
-
/// in {@code altsets}.
|
399
|
-
/// </summary>
|
400
|
-
/// <param name="altsets"> a collection of alternative subsets </param>
|
401
|
-
/// <returns> the set of represented alternatives in {@code altsets} </returns>
|
402
|
-
static antlrcpp::BitSet getAlts(const std::vector<antlrcpp::BitSet> &altsets);
|
403
|
-
|
404
|
-
/** Get union of all alts from configs. @since 4.5.1 */
|
405
|
-
static antlrcpp::BitSet getAlts(ATNConfigSet *configs);
|
406
|
-
|
407
|
-
/// <summary>
|
408
|
-
/// This function gets the conflicting alt subsets from a configuration set.
|
409
|
-
/// For each configuration {@code c} in {@code configs}:
|
410
|
-
///
|
411
|
-
/// <pre>
|
412
|
-
/// map[c] U= c.<seealso cref="ATNConfig#alt alt"/> # map hash/equals uses s and
|
413
|
-
/// x, not
|
414
|
-
/// alt and not pred
|
415
|
-
/// </pre>
|
416
|
-
/// </summary>
|
417
|
-
static std::vector<antlrcpp::BitSet> getConflictingAltSubsets(ATNConfigSet *configs);
|
418
|
-
|
419
|
-
/// <summary>
|
420
|
-
/// Get a map from state to alt subset from a configuration set. For each
|
421
|
-
/// configuration {@code c} in {@code configs}:
|
422
|
-
///
|
423
|
-
/// <pre>
|
424
|
-
/// map[c.<seealso cref="ATNConfig#state state"/>] U= c.<seealso
|
425
|
-
/// cref="ATNConfig#alt alt"/>
|
426
|
-
/// </pre>
|
427
|
-
/// </summary>
|
428
|
-
static std::unordered_map<ATNState*, antlrcpp::BitSet> getStateToAltMap(ATNConfigSet *configs);
|
429
|
-
|
430
|
-
static bool hasStateAssociatedWithOneAlt(ATNConfigSet *configs);
|
431
|
-
|
432
|
-
static size_t getSingleViableAlt(const std::vector<antlrcpp::BitSet> &altsets);
|
433
|
-
};
|
434
|
-
|
435
|
-
} // namespace atn
|
436
|
-
} // namespace antlr4
|