expressir 1.4.2 → 2.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (399) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/codeql.yml +2 -14
  3. data/.github/workflows/rake.yml +6 -364
  4. data/.github/workflows/release.yml +15 -178
  5. data/.github/workflows/stress.yml +1 -18
  6. data/.rubocop.yml +1 -0
  7. data/.rubocop_todo.yml +7 -0
  8. data/Gemfile +13 -0
  9. data/README.adoc +6 -19
  10. data/Rakefile +6 -7
  11. data/expressir.gemspec +23 -32
  12. data/expressir_wrapped.txt +23068 -0
  13. data/lib/expressir/cli.rb +3 -2
  14. data/lib/expressir/express/formatter.rb +661 -661
  15. data/lib/expressir/express/parser.rb +299 -33
  16. data/lib/expressir/express/visitor.rb +238 -133
  17. data/lib/expressir/model/declarations/interface_item.rb +1 -1
  18. data/lib/expressir/version.rb +1 -1
  19. metadata +15 -573
  20. data/.cross_rubies +0 -28
  21. data/.gitmodules +0 -6
  22. data/.yardopts +0 -11
  23. data/exe/generate-parser +0 -51
  24. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/CMakeLists.txt +0 -191
  25. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2019.vcxproj +0 -652
  26. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2019.vcxproj.filters +0 -948
  27. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2022.vcxproj +0 -652
  28. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlr4cpp-vs2022.vcxproj.filters +0 -948
  29. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp-ios/Info.plist +0 -26
  30. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp-ios/antlrcpp_ios.h +0 -17
  31. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/project.pbxproj +0 -3040
  32. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
  33. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +0 -8
  34. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/xcshareddata/xcschemes/antlr4.xcscheme +0 -76
  35. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/xcshareddata/xcschemes/antlr4_ios.xcscheme +0 -76
  36. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/antlrcpp.xcodeproj/xcshareddata/xcschemes/antlr4_static.xcscheme +0 -76
  37. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.noarch.nuspec +0 -23
  38. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.noarch.targets +0 -8
  39. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.shared.nuspec +0 -30
  40. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.shared.props +0 -21
  41. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.shared.targets +0 -44
  42. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.static.nuspec +0 -29
  43. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/ANTLR4.Runtime.cpp.static.targets +0 -44
  44. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/antlr4.jpg +0 -0
  45. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/nuget/pack.cmd +0 -93
  46. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorListener.cpp +0 -10
  47. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorListener.h +0 -167
  48. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorStrategy.cpp +0 -10
  49. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorStrategy.h +0 -121
  50. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRFileStream.cpp +0 -23
  51. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRFileStream.h +0 -30
  52. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRInputStream.cpp +0 -180
  53. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRInputStream.h +0 -79
  54. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/BailErrorStrategy.cpp +0 -61
  55. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/BailErrorStrategy.h +0 -59
  56. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/BaseErrorListener.cpp +0 -25
  57. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/BaseErrorListener.h +0 -36
  58. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/BufferedTokenStream.cpp +0 -414
  59. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/BufferedTokenStream.h +0 -200
  60. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/CharStream.cpp +0 -11
  61. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/CharStream.h +0 -37
  62. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonToken.cpp +0 -193
  63. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonToken.h +0 -158
  64. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenFactory.cpp +0 -39
  65. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenFactory.h +0 -74
  66. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenStream.cpp +0 -78
  67. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenStream.h +0 -79
  68. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ConsoleErrorListener.cpp +0 -15
  69. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ConsoleErrorListener.h +0 -35
  70. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/DefaultErrorStrategy.cpp +0 -336
  71. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/DefaultErrorStrategy.h +0 -466
  72. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/DiagnosticErrorListener.cpp +0 -84
  73. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/DiagnosticErrorListener.h +0 -80
  74. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Exceptions.cpp +0 -64
  75. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Exceptions.h +0 -99
  76. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/FailedPredicateException.cpp +0 -52
  77. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/FailedPredicateException.h +0 -32
  78. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/FlatHashMap.h +0 -57
  79. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/FlatHashSet.h +0 -57
  80. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/InputMismatchException.cpp +0 -18
  81. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/InputMismatchException.h +0 -24
  82. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/IntStream.cpp +0 -12
  83. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/IntStream.h +0 -218
  84. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/InterpreterRuleContext.cpp +0 -19
  85. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/InterpreterRuleContext.h +0 -45
  86. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Lexer.cpp +0 -294
  87. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Lexer.h +0 -196
  88. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerInterpreter.cpp +0 -60
  89. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerInterpreter.h +0 -46
  90. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerNoViableAltException.cpp +0 -36
  91. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerNoViableAltException.h +0 -31
  92. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ListTokenSource.cpp +0 -92
  93. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ListTokenSource.h +0 -88
  94. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/NoViableAltException.cpp +0 -46
  95. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/NoViableAltException.h +0 -42
  96. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Parser.cpp +0 -670
  97. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Parser.h +0 -461
  98. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserInterpreter.cpp +0 -294
  99. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserInterpreter.h +0 -173
  100. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserRuleContext.cpp +0 -138
  101. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserRuleContext.h +0 -147
  102. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ProxyErrorListener.cpp +0 -53
  103. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/ProxyErrorListener.h +0 -38
  104. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/RecognitionException.cpp +0 -65
  105. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/RecognitionException.h +0 -98
  106. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Recognizer.cpp +0 -157
  107. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Recognizer.h +0 -160
  108. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContext.cpp +0 -144
  109. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContext.h +0 -141
  110. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContextWithAltNum.cpp +0 -27
  111. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContextWithAltNum.h +0 -32
  112. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuntimeMetaData.cpp +0 -54
  113. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuntimeMetaData.h +0 -155
  114. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Token.cpp +0 -9
  115. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Token.h +0 -92
  116. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenFactory.h +0 -30
  117. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenSource.cpp +0 -9
  118. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenSource.h +0 -85
  119. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStream.cpp +0 -11
  120. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStream.h +0 -137
  121. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStreamRewriter.cpp +0 -425
  122. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStreamRewriter.h +0 -295
  123. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedCharStream.cpp +0 -208
  124. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedCharStream.h +0 -117
  125. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedTokenStream.cpp +0 -270
  126. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedTokenStream.h +0 -115
  127. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Version.h +0 -42
  128. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Vocabulary.cpp +0 -64
  129. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/Vocabulary.h +0 -177
  130. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/WritableToken.cpp +0 -9
  131. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/WritableToken.h +0 -23
  132. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/antlr4-common.h +0 -101
  133. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/antlr4-runtime.h +0 -168
  134. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATN.cpp +0 -159
  135. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATN.h +0 -133
  136. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfig.cpp +0 -106
  137. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfig.h +0 -157
  138. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfigSet.cpp +0 -233
  139. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfigSet.h +0 -157
  140. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializationOptions.cpp +0 -39
  141. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializationOptions.h +0 -48
  142. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializer.cpp +0 -628
  143. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializer.h +0 -32
  144. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSimulator.cpp +0 -33
  145. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSimulator.h +0 -71
  146. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNState.cpp +0 -56
  147. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNState.h +0 -139
  148. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNStateType.cpp +0 -33
  149. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNStateType.h +0 -36
  150. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNType.h +0 -20
  151. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ActionTransition.cpp +0 -29
  152. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ActionTransition.h +0 -35
  153. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AmbiguityInfo.cpp +0 -16
  154. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AmbiguityInfo.h +0 -68
  155. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ArrayPredictionContext.cpp +0 -129
  156. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ArrayPredictionContext.h +0 -51
  157. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AtomTransition.cpp +0 -27
  158. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AtomTransition.h +0 -33
  159. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicBlockStartState.h +0 -24
  160. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicState.h +0 -23
  161. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockEndState.h +0 -26
  162. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockStartState.h +0 -30
  163. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ContextSensitivityInfo.cpp +0 -14
  164. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ContextSensitivityInfo.h +0 -47
  165. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionEventInfo.cpp +0 -14
  166. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionEventInfo.h +0 -70
  167. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionInfo.cpp +0 -25
  168. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionInfo.h +0 -227
  169. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionState.cpp +0 -12
  170. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionState.h +0 -34
  171. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EpsilonTransition.cpp +0 -31
  172. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EpsilonTransition.h +0 -42
  173. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ErrorInfo.cpp +0 -15
  174. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ErrorInfo.h +0 -43
  175. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/HashUtils.h +0 -18
  176. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LL1Analyzer.cpp +0 -189
  177. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LL1Analyzer.h +0 -76
  178. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNConfig.cpp +0 -67
  179. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNConfig.h +0 -44
  180. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNSimulator.cpp +0 -621
  181. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNSimulator.h +0 -199
  182. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerAction.cpp +0 -15
  183. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerAction.h +0 -100
  184. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionExecutor.cpp +0 -108
  185. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionExecutor.h +0 -128
  186. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionType.h +0 -57
  187. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerChannelAction.cpp +0 -43
  188. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerChannelAction.h +0 -59
  189. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerCustomAction.cpp +0 -45
  190. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerCustomAction.h +0 -75
  191. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerIndexedCustomAction.cpp +0 -50
  192. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerIndexedCustomAction.h +0 -76
  193. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerModeAction.cpp +0 -43
  194. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerModeAction.h +0 -57
  195. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerMoreAction.cpp +0 -36
  196. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerMoreAction.h +0 -53
  197. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPopModeAction.cpp +0 -36
  198. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPopModeAction.h +0 -53
  199. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPushModeAction.cpp +0 -43
  200. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPushModeAction.h +0 -57
  201. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerSkipAction.cpp +0 -36
  202. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerSkipAction.h +0 -51
  203. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerTypeAction.cpp +0 -43
  204. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerTypeAction.h +0 -51
  205. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LookaheadEventInfo.cpp +0 -16
  206. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LookaheadEventInfo.h +0 -42
  207. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LoopEndState.h +0 -26
  208. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/NotSetTransition.cpp +0 -22
  209. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/NotSetTransition.h +0 -27
  210. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/OrderedATNConfigSet.cpp +0 -16
  211. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/OrderedATNConfigSet.h +0 -25
  212. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParseInfo.cpp +0 -102
  213. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParseInfo.h +0 -102
  214. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulator.cpp +0 -1413
  215. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulator.h +0 -911
  216. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulatorOptions.h +0 -50
  217. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusBlockStartState.h +0 -29
  218. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusLoopbackState.h +0 -25
  219. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PrecedencePredicateTransition.cpp +0 -23
  220. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PrecedencePredicateTransition.h +0 -35
  221. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateEvalInfo.cpp +0 -17
  222. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateEvalInfo.h +0 -62
  223. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateTransition.cpp +0 -24
  224. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateTransition.h +0 -50
  225. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContext.cpp +0 -601
  226. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContext.h +0 -225
  227. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextCache.cpp +0 -56
  228. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextCache.h +0 -63
  229. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextMergeCache.cpp +0 -167
  230. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextMergeCache.h +0 -101
  231. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextMergeCacheOptions.h +0 -71
  232. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextType.h +0 -21
  233. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionMode.cpp +0 -202
  234. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionMode.h +0 -436
  235. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ProfilingATNSimulator.cpp +0 -179
  236. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ProfilingATNSimulator.h +0 -60
  237. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RangeTransition.cpp +0 -26
  238. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RangeTransition.h +0 -31
  239. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStartState.h +0 -26
  240. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStopState.h +0 -27
  241. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleTransition.cpp +0 -33
  242. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleTransition.h +0 -42
  243. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContext.cpp +0 -418
  244. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContext.h +0 -237
  245. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContextType.h +0 -23
  246. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SerializedATNView.h +0 -101
  247. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SetTransition.cpp +0 -28
  248. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SetTransition.h +0 -38
  249. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SingletonPredictionContext.cpp +0 -79
  250. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SingletonPredictionContext.h +0 -43
  251. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarBlockStartState.h +0 -24
  252. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopEntryState.h +0 -37
  253. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopbackState.cpp +0 -19
  254. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopbackState.h +0 -25
  255. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TokensStartState.h +0 -24
  256. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Transition.cpp +0 -36
  257. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Transition.h +0 -65
  258. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TransitionType.cpp +0 -27
  259. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TransitionType.h +0 -33
  260. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/WildcardTransition.cpp +0 -21
  261. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/WildcardTransition.h +0 -27
  262. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFA.cpp +0 -115
  263. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFA.h +0 -96
  264. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFASerializer.cpp +0 -60
  265. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFASerializer.h +0 -32
  266. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFAState.cpp +0 -59
  267. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFAState.h +0 -154
  268. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/LexerDFASerializer.cpp +0 -17
  269. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/LexerDFASerializer.h +0 -22
  270. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/internal/Synchronization.cpp +0 -100
  271. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/internal/Synchronization.h +0 -154
  272. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/InterpreterDataReader.cpp +0 -124
  273. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/InterpreterDataReader.h +0 -33
  274. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Interval.cpp +0 -61
  275. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Interval.h +0 -84
  276. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/IntervalSet.cpp +0 -508
  277. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/IntervalSet.h +0 -190
  278. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/MurmurHash.cpp +0 -120
  279. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/MurmurHash.h +0 -102
  280. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Predicate.cpp +0 -4
  281. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Predicate.h +0 -21
  282. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Any.cpp +0 -8
  283. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Any.h +0 -16
  284. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Arrays.cpp +0 -43
  285. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Arrays.h +0 -149
  286. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/BitSet.h +0 -76
  287. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/CPPUtils.cpp +0 -207
  288. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/CPPUtils.h +0 -65
  289. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Casts.h +0 -34
  290. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Declarations.h +0 -161
  291. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/StringUtils.cpp +0 -38
  292. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/StringUtils.h +0 -16
  293. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Unicode.h +0 -28
  294. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Utf8.cpp +0 -242
  295. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Utf8.h +0 -54
  296. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/AbstractParseTreeVisitor.h +0 -129
  297. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNode.h +0 -24
  298. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNodeImpl.cpp +0 -54
  299. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNodeImpl.h +0 -43
  300. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/IterativeParseTreeWalker.cpp +0 -66
  301. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/IterativeParseTreeWalker.h +0 -53
  302. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTree.cpp +0 -12
  303. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTree.h +0 -111
  304. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeListener.cpp +0 -9
  305. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeListener.h +0 -39
  306. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeProperty.h +0 -50
  307. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeType.h +0 -22
  308. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeVisitor.cpp +0 -9
  309. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeVisitor.h +0 -57
  310. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeWalker.cpp +0 -48
  311. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeWalker.h +0 -55
  312. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNode.h +0 -40
  313. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNodeImpl.cpp +0 -54
  314. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNodeImpl.h +0 -32
  315. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/Trees.cpp +0 -241
  316. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/Trees.h +0 -78
  317. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/Chunk.cpp +0 -9
  318. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/Chunk.h +0 -44
  319. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreeMatch.cpp +0 -69
  320. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreeMatch.h +0 -132
  321. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePattern.cpp +0 -64
  322. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePattern.h +0 -105
  323. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePatternMatcher.cpp +0 -370
  324. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePatternMatcher.h +0 -185
  325. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/RuleTagToken.cpp +0 -77
  326. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/RuleTagToken.h +0 -117
  327. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TagChunk.cpp +0 -39
  328. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TagChunk.h +0 -86
  329. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TextChunk.cpp +0 -28
  330. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TextChunk.h +0 -51
  331. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TokenTagToken.cpp +0 -36
  332. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TokenTagToken.h +0 -80
  333. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPath.cpp +0 -154
  334. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPath.h +0 -86
  335. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathElement.cpp +0 -31
  336. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathElement.h +0 -40
  337. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.cpp +0 -180
  338. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.g4 +0 -64
  339. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.h +0 -53
  340. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.tokens +0 -12
  341. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexerErrorListener.cpp +0 -13
  342. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexerErrorListener.h +0 -22
  343. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleAnywhereElement.cpp +0 -20
  344. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleAnywhereElement.h +0 -27
  345. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleElement.cpp +0 -30
  346. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleElement.h +0 -26
  347. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenAnywhereElement.cpp +0 -20
  348. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenAnywhereElement.h +0 -25
  349. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenElement.cpp +0 -33
  350. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenElement.h +0 -26
  351. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardAnywhereElement.cpp +0 -23
  352. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardAnywhereElement.h +0 -23
  353. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardElement.cpp +0 -24
  354. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardElement.h +0 -23
  355. data/ext/express_parser/antlr4-upstream/runtime/Cpp/runtime/tests/Utf8Test.cpp +0 -110
  356. data/ext/express_parser/antlrgen/Express.interp +0 -532
  357. data/ext/express_parser/antlrgen/Express.tokens +0 -190
  358. data/ext/express_parser/antlrgen/ExpressBaseListener.cpp +0 -7
  359. data/ext/express_parser/antlrgen/ExpressBaseListener.h +0 -623
  360. data/ext/express_parser/antlrgen/ExpressBaseVisitor.cpp +0 -7
  361. data/ext/express_parser/antlrgen/ExpressBaseVisitor.h +0 -816
  362. data/ext/express_parser/antlrgen/ExpressLexer.cpp +0 -685
  363. data/ext/express_parser/antlrgen/ExpressLexer.h +0 -78
  364. data/ext/express_parser/antlrgen/ExpressLexer.interp +0 -534
  365. data/ext/express_parser/antlrgen/ExpressLexer.tokens +0 -190
  366. data/ext/express_parser/antlrgen/ExpressListener.cpp +0 -7
  367. data/ext/express_parser/antlrgen/ExpressListener.h +0 -616
  368. data/ext/express_parser/antlrgen/ExpressParser.cpp +0 -17591
  369. data/ext/express_parser/antlrgen/ExpressParser.h +0 -3692
  370. data/ext/express_parser/antlrgen/ExpressVisitor.cpp +0 -7
  371. data/ext/express_parser/antlrgen/ExpressVisitor.h +0 -422
  372. data/ext/express_parser/express_parser.cpp +0 -19405
  373. data/ext/express_parser/extconf.rb +0 -63
  374. data/rakelib/antlr4-native.rake +0 -173
  375. data/rakelib/cross-ruby.rake +0 -403
  376. data/spec/acceptance/version_spec.rb +0 -30
  377. data/spec/expressir/express/cache_spec.rb +0 -89
  378. data/spec/expressir/express/formatter_spec.rb +0 -171
  379. data/spec/expressir/express/parser_spec.rb +0 -141
  380. data/spec/expressir/model/model_element_spec.rb +0 -343
  381. data/spec/spec_helper.rb +0 -24
  382. data/spec/support/console_helper.rb +0 -29
  383. data/spec/syntax/multiple.exp +0 -23
  384. data/spec/syntax/multiple.yaml +0 -198
  385. data/spec/syntax/multiple_formatted.exp +0 -71
  386. data/spec/syntax/multiple_hyperlink_formatted.exp +0 -71
  387. data/spec/syntax/multiple_schema_head_hyperlink_formatted.exp +0 -13
  388. data/spec/syntax/remark.exp +0 -193
  389. data/spec/syntax/remark.yaml +0 -471
  390. data/spec/syntax/remark_formatted.exp +0 -228
  391. data/spec/syntax/single.exp +0 -4
  392. data/spec/syntax/single.yaml +0 -18
  393. data/spec/syntax/single_formatted.exp +0 -10
  394. data/spec/syntax/single_formatted.yaml +0 -36
  395. data/spec/syntax/syntax.exp +0 -333
  396. data/spec/syntax/syntax.yaml +0 -3509
  397. data/spec/syntax/syntax_formatted.exp +0 -902
  398. data/spec/syntax/syntax_hyperlink_formatted.exp +0 -902
  399. 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 =&gt; 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}} =&gt; 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}} =&gt; 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}} =&gt; 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}} =&gt; 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}} =&gt; 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>|&gt;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"/> &gt; 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"/> &gt; 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