expressir 0.2.3 → 0.2.8

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