did_parser 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (327) hide show
  1. checksums.yaml +7 -0
  2. data/Gemfile +12 -0
  3. data/Rakefile +28 -0
  4. data/did_parser.gemspec +31 -0
  5. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorListener.cpp +10 -0
  6. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorListener.h +167 -0
  7. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorStrategy.cpp +10 -0
  8. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRErrorStrategy.h +121 -0
  9. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRFileStream.cpp +23 -0
  10. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRFileStream.h +30 -0
  11. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRInputStream.cpp +180 -0
  12. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ANTLRInputStream.h +79 -0
  13. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/BailErrorStrategy.cpp +61 -0
  14. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/BailErrorStrategy.h +59 -0
  15. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/BaseErrorListener.cpp +25 -0
  16. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/BaseErrorListener.h +36 -0
  17. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/BufferedTokenStream.cpp +414 -0
  18. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/BufferedTokenStream.h +200 -0
  19. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/CharStream.cpp +11 -0
  20. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/CharStream.h +37 -0
  21. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonToken.cpp +193 -0
  22. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonToken.h +158 -0
  23. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenFactory.cpp +39 -0
  24. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenFactory.h +74 -0
  25. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenStream.cpp +78 -0
  26. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/CommonTokenStream.h +79 -0
  27. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ConsoleErrorListener.cpp +15 -0
  28. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ConsoleErrorListener.h +35 -0
  29. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/DefaultErrorStrategy.cpp +336 -0
  30. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/DefaultErrorStrategy.h +466 -0
  31. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/DiagnosticErrorListener.cpp +84 -0
  32. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/DiagnosticErrorListener.h +80 -0
  33. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Exceptions.cpp +64 -0
  34. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Exceptions.h +99 -0
  35. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/FailedPredicateException.cpp +52 -0
  36. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/FailedPredicateException.h +32 -0
  37. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/InputMismatchException.cpp +18 -0
  38. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/InputMismatchException.h +24 -0
  39. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/IntStream.cpp +12 -0
  40. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/IntStream.h +218 -0
  41. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/InterpreterRuleContext.cpp +19 -0
  42. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/InterpreterRuleContext.h +45 -0
  43. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Lexer.cpp +294 -0
  44. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Lexer.h +196 -0
  45. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerInterpreter.cpp +60 -0
  46. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerInterpreter.h +46 -0
  47. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerNoViableAltException.cpp +36 -0
  48. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/LexerNoViableAltException.h +31 -0
  49. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ListTokenSource.cpp +92 -0
  50. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ListTokenSource.h +88 -0
  51. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/NoViableAltException.cpp +46 -0
  52. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/NoViableAltException.h +42 -0
  53. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Parser.cpp +668 -0
  54. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Parser.h +461 -0
  55. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserInterpreter.cpp +294 -0
  56. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserInterpreter.h +173 -0
  57. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserRuleContext.cpp +138 -0
  58. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ParserRuleContext.h +147 -0
  59. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ProxyErrorListener.cpp +53 -0
  60. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/ProxyErrorListener.h +38 -0
  61. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/RecognitionException.cpp +65 -0
  62. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/RecognitionException.h +98 -0
  63. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Recognizer.cpp +156 -0
  64. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Recognizer.h +159 -0
  65. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContext.cpp +144 -0
  66. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContext.h +141 -0
  67. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContextWithAltNum.cpp +27 -0
  68. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuleContextWithAltNum.h +32 -0
  69. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuntimeMetaData.cpp +54 -0
  70. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/RuntimeMetaData.h +155 -0
  71. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Token.cpp +9 -0
  72. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Token.h +92 -0
  73. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenFactory.h +30 -0
  74. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenSource.cpp +9 -0
  75. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenSource.h +85 -0
  76. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStream.cpp +11 -0
  77. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStream.h +137 -0
  78. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStreamRewriter.cpp +425 -0
  79. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/TokenStreamRewriter.h +295 -0
  80. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedCharStream.cpp +208 -0
  81. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedCharStream.h +117 -0
  82. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedTokenStream.cpp +270 -0
  83. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/UnbufferedTokenStream.h +115 -0
  84. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Version.h +42 -0
  85. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Vocabulary.cpp +64 -0
  86. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/Vocabulary.h +177 -0
  87. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/WritableToken.cpp +9 -0
  88. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/WritableToken.h +23 -0
  89. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/antlr4-common.h +98 -0
  90. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/antlr4-runtime.h +169 -0
  91. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATN.cpp +158 -0
  92. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATN.h +132 -0
  93. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfig.cpp +106 -0
  94. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfig.h +157 -0
  95. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfigSet.cpp +232 -0
  96. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNConfigSet.h +156 -0
  97. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializationOptions.cpp +54 -0
  98. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializationOptions.h +48 -0
  99. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializer.cpp +629 -0
  100. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNDeserializer.h +32 -0
  101. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSimulator.cpp +33 -0
  102. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNSimulator.h +71 -0
  103. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNState.cpp +56 -0
  104. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNState.h +139 -0
  105. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNStateType.cpp +33 -0
  106. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNStateType.h +36 -0
  107. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ATNType.h +20 -0
  108. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ActionTransition.cpp +29 -0
  109. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ActionTransition.h +35 -0
  110. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AmbiguityInfo.cpp +16 -0
  111. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AmbiguityInfo.h +68 -0
  112. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ArrayPredictionContext.cpp +109 -0
  113. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ArrayPredictionContext.h +51 -0
  114. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AtomTransition.cpp +27 -0
  115. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/AtomTransition.h +33 -0
  116. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicBlockStartState.h +24 -0
  117. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BasicState.h +23 -0
  118. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockEndState.h +26 -0
  119. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/BlockStartState.h +30 -0
  120. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ContextSensitivityInfo.cpp +14 -0
  121. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ContextSensitivityInfo.h +47 -0
  122. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionEventInfo.cpp +14 -0
  123. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionEventInfo.h +70 -0
  124. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionInfo.cpp +25 -0
  125. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionInfo.h +227 -0
  126. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionState.cpp +12 -0
  127. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/DecisionState.h +34 -0
  128. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EpsilonTransition.cpp +31 -0
  129. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/EpsilonTransition.h +42 -0
  130. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ErrorInfo.cpp +15 -0
  131. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ErrorInfo.h +43 -0
  132. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LL1Analyzer.cpp +189 -0
  133. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LL1Analyzer.h +76 -0
  134. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNConfig.cpp +67 -0
  135. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNConfig.h +44 -0
  136. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNSimulator.cpp +615 -0
  137. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerATNSimulator.h +199 -0
  138. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerAction.cpp +15 -0
  139. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerAction.h +100 -0
  140. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionExecutor.cpp +111 -0
  141. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionExecutor.h +128 -0
  142. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerActionType.h +57 -0
  143. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerChannelAction.cpp +43 -0
  144. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerChannelAction.h +59 -0
  145. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerCustomAction.cpp +45 -0
  146. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerCustomAction.h +75 -0
  147. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerIndexedCustomAction.cpp +57 -0
  148. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerIndexedCustomAction.h +76 -0
  149. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerModeAction.cpp +43 -0
  150. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerModeAction.h +57 -0
  151. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerMoreAction.cpp +36 -0
  152. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerMoreAction.h +53 -0
  153. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPopModeAction.cpp +36 -0
  154. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPopModeAction.h +53 -0
  155. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPushModeAction.cpp +43 -0
  156. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerPushModeAction.h +57 -0
  157. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerSkipAction.cpp +36 -0
  158. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerSkipAction.h +51 -0
  159. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerTypeAction.cpp +43 -0
  160. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LexerTypeAction.h +51 -0
  161. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LookaheadEventInfo.cpp +16 -0
  162. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LookaheadEventInfo.h +42 -0
  163. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/LoopEndState.h +26 -0
  164. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/NotSetTransition.cpp +22 -0
  165. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/NotSetTransition.h +27 -0
  166. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/OrderedATNConfigSet.cpp +16 -0
  167. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/OrderedATNConfigSet.h +25 -0
  168. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParseInfo.cpp +102 -0
  169. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParseInfo.h +102 -0
  170. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulator.cpp +1383 -0
  171. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulator.h +911 -0
  172. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ParserATNSimulatorOptions.h +50 -0
  173. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusBlockStartState.h +29 -0
  174. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PlusLoopbackState.h +25 -0
  175. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PrecedencePredicateTransition.cpp +23 -0
  176. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PrecedencePredicateTransition.h +35 -0
  177. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateEvalInfo.cpp +17 -0
  178. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateEvalInfo.h +62 -0
  179. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateTransition.cpp +24 -0
  180. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredicateTransition.h +50 -0
  181. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContext.cpp +579 -0
  182. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContext.h +225 -0
  183. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextCache.cpp +56 -0
  184. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextCache.h +64 -0
  185. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextMergeCache.cpp +167 -0
  186. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextMergeCache.h +101 -0
  187. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextMergeCacheOptions.h +71 -0
  188. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionContextType.h +21 -0
  189. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionMode.cpp +202 -0
  190. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/PredictionMode.h +436 -0
  191. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ProfilingATNSimulator.cpp +179 -0
  192. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/ProfilingATNSimulator.h +60 -0
  193. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RangeTransition.cpp +26 -0
  194. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RangeTransition.h +31 -0
  195. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStartState.h +26 -0
  196. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleStopState.h +27 -0
  197. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleTransition.cpp +33 -0
  198. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/RuleTransition.h +42 -0
  199. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContext.cpp +418 -0
  200. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContext.h +233 -0
  201. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SemanticContextType.h +23 -0
  202. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SerializedATNView.h +101 -0
  203. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SetTransition.cpp +28 -0
  204. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SetTransition.h +38 -0
  205. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SingletonPredictionContext.cpp +86 -0
  206. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/SingletonPredictionContext.h +43 -0
  207. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarBlockStartState.h +24 -0
  208. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopEntryState.h +37 -0
  209. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopbackState.cpp +19 -0
  210. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/StarLoopbackState.h +25 -0
  211. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TokensStartState.h +24 -0
  212. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Transition.cpp +36 -0
  213. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/Transition.h +65 -0
  214. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TransitionType.cpp +27 -0
  215. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/TransitionType.h +33 -0
  216. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/WildcardTransition.cpp +21 -0
  217. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/atn/WildcardTransition.h +27 -0
  218. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFA.cpp +115 -0
  219. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFA.h +96 -0
  220. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFASerializer.cpp +60 -0
  221. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFASerializer.h +32 -0
  222. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFAState.cpp +59 -0
  223. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/DFAState.h +153 -0
  224. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/LexerDFASerializer.cpp +17 -0
  225. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/dfa/LexerDFASerializer.h +22 -0
  226. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/InterpreterDataReader.cpp +124 -0
  227. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/InterpreterDataReader.h +33 -0
  228. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Interval.cpp +61 -0
  229. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Interval.h +84 -0
  230. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/IntervalSet.cpp +508 -0
  231. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/IntervalSet.h +190 -0
  232. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/MurmurHash.cpp +120 -0
  233. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/MurmurHash.h +102 -0
  234. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Predicate.cpp +4 -0
  235. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/misc/Predicate.h +21 -0
  236. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Any.cpp +8 -0
  237. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Any.h +16 -0
  238. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Arrays.cpp +43 -0
  239. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Arrays.h +149 -0
  240. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/BitSet.h +76 -0
  241. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/CPPUtils.cpp +207 -0
  242. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/CPPUtils.h +65 -0
  243. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Casts.h +34 -0
  244. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Declarations.h +161 -0
  245. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/StringUtils.cpp +38 -0
  246. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/StringUtils.h +16 -0
  247. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Unicode.h +28 -0
  248. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Utf8.cpp +242 -0
  249. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/support/Utf8.h +54 -0
  250. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/AbstractParseTreeVisitor.h +129 -0
  251. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNode.h +24 -0
  252. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNodeImpl.cpp +54 -0
  253. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ErrorNodeImpl.h +43 -0
  254. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/IterativeParseTreeWalker.cpp +66 -0
  255. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/IterativeParseTreeWalker.h +53 -0
  256. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTree.cpp +12 -0
  257. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTree.h +111 -0
  258. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeListener.cpp +9 -0
  259. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeListener.h +39 -0
  260. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeProperty.h +50 -0
  261. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeType.h +22 -0
  262. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeVisitor.cpp +9 -0
  263. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeVisitor.h +57 -0
  264. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeWalker.cpp +48 -0
  265. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/ParseTreeWalker.h +55 -0
  266. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNode.h +40 -0
  267. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNodeImpl.cpp +54 -0
  268. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/TerminalNodeImpl.h +32 -0
  269. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/Trees.cpp +241 -0
  270. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/Trees.h +78 -0
  271. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/Chunk.cpp +9 -0
  272. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/Chunk.h +44 -0
  273. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreeMatch.cpp +69 -0
  274. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreeMatch.h +132 -0
  275. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePattern.cpp +64 -0
  276. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePattern.h +105 -0
  277. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePatternMatcher.cpp +370 -0
  278. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/ParseTreePatternMatcher.h +185 -0
  279. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/RuleTagToken.cpp +77 -0
  280. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/RuleTagToken.h +117 -0
  281. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TagChunk.cpp +39 -0
  282. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TagChunk.h +86 -0
  283. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TextChunk.cpp +28 -0
  284. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TextChunk.h +51 -0
  285. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TokenTagToken.cpp +36 -0
  286. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/pattern/TokenTagToken.h +80 -0
  287. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPath.cpp +154 -0
  288. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPath.h +86 -0
  289. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathElement.cpp +31 -0
  290. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathElement.h +40 -0
  291. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.cpp +182 -0
  292. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexer.h +47 -0
  293. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexerErrorListener.cpp +13 -0
  294. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathLexerErrorListener.h +22 -0
  295. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleAnywhereElement.cpp +20 -0
  296. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleAnywhereElement.h +27 -0
  297. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleElement.cpp +30 -0
  298. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathRuleElement.h +26 -0
  299. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenAnywhereElement.cpp +20 -0
  300. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenAnywhereElement.h +25 -0
  301. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenElement.cpp +33 -0
  302. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathTokenElement.h +26 -0
  303. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardAnywhereElement.cpp +23 -0
  304. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardAnywhereElement.h +23 -0
  305. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardElement.cpp +24 -0
  306. data/ext/did_parser/antlr4-upstream/runtime/Cpp/runtime/src/tree/xpath/XPathWildcardElement.h +23 -0
  307. data/ext/did_parser/antlrgen/DIDLexer.cpp +225 -0
  308. data/ext/did_parser/antlrgen/DIDLexer.h +52 -0
  309. data/ext/did_parser/antlrgen/DIDLexer.interp +93 -0
  310. data/ext/did_parser/antlrgen/DIDLexer.tokens +42 -0
  311. data/ext/did_parser/antlrgen/DIDParser.cpp +2042 -0
  312. data/ext/did_parser/antlrgen/DIDParser.h +537 -0
  313. data/ext/did_parser/antlrgen/DIDParser.interp +74 -0
  314. data/ext/did_parser/antlrgen/DIDParser.tokens +42 -0
  315. data/ext/did_parser/antlrgen/DIDParserBaseListener.cpp +7 -0
  316. data/ext/did_parser/antlrgen/DIDParserBaseListener.h +104 -0
  317. data/ext/did_parser/antlrgen/DIDParserBaseVisitor.cpp +7 -0
  318. data/ext/did_parser/antlrgen/DIDParserBaseVisitor.h +124 -0
  319. data/ext/did_parser/antlrgen/DIDParserListener.cpp +7 -0
  320. data/ext/did_parser/antlrgen/DIDParserListener.h +97 -0
  321. data/ext/did_parser/antlrgen/DIDParserVisitor.cpp +7 -0
  322. data/ext/did_parser/antlrgen/DIDParserVisitor.h +76 -0
  323. data/ext/did_parser/did_parser.cpp +2996 -0
  324. data/ext/did_parser/extconf.rb +38 -0
  325. data/lib/did_parser/version.rb +3 -0
  326. data/lib/did_parser.rb +2 -0
  327. metadata +382 -0
@@ -0,0 +1,294 @@
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 "dfa/DFA.h"
7
+ #include "atn/RuleStartState.h"
8
+ #include "InterpreterRuleContext.h"
9
+ #include "atn/ParserATNSimulator.h"
10
+ #include "ANTLRErrorStrategy.h"
11
+ #include "atn/LoopEndState.h"
12
+ #include "FailedPredicateException.h"
13
+ #include "atn/StarLoopEntryState.h"
14
+ #include "atn/AtomTransition.h"
15
+ #include "atn/RuleTransition.h"
16
+ #include "atn/PredicateTransition.h"
17
+ #include "atn/PrecedencePredicateTransition.h"
18
+ #include "atn/ActionTransition.h"
19
+ #include "atn/ATN.h"
20
+ #include "atn/RuleStopState.h"
21
+ #include "Lexer.h"
22
+ #include "Token.h"
23
+ #include "Vocabulary.h"
24
+ #include "InputMismatchException.h"
25
+ #include "CommonToken.h"
26
+ #include "tree/ErrorNode.h"
27
+
28
+ #include "support/CPPUtils.h"
29
+ #include "support/Casts.h"
30
+
31
+ #include "ParserInterpreter.h"
32
+
33
+ using namespace antlr4;
34
+ using namespace antlr4::atn;
35
+ using namespace antlr4::misc;
36
+
37
+ using namespace antlrcpp;
38
+
39
+ ParserInterpreter::ParserInterpreter(const std::string &grammarFileName, const dfa::Vocabulary &vocabulary,
40
+ const std::vector<std::string> &ruleNames, const atn::ATN &atn, TokenStream *input)
41
+ : Parser(input), _grammarFileName(grammarFileName), _atn(atn), _ruleNames(ruleNames), _vocabulary(vocabulary) {
42
+
43
+ // init decision DFA
44
+ for (size_t i = 0; i < atn.getNumberOfDecisions(); ++i) {
45
+ atn::DecisionState *decisionState = atn.getDecisionState(i);
46
+ _decisionToDFA.push_back(dfa::DFA(decisionState, i));
47
+ }
48
+
49
+ // get atn simulator that knows how to do predictions
50
+ _interpreter = new atn::ParserATNSimulator(this, atn, _decisionToDFA, _sharedContextCache); /* mem-check: deleted in d-tor */
51
+ }
52
+
53
+ ParserInterpreter::~ParserInterpreter() {
54
+ delete _interpreter;
55
+ }
56
+
57
+ void ParserInterpreter::reset() {
58
+ Parser::reset();
59
+ _overrideDecisionReached = false;
60
+ _overrideDecisionRoot = nullptr;
61
+ }
62
+
63
+ const atn::ATN& ParserInterpreter::getATN() const {
64
+ return _atn;
65
+ }
66
+
67
+ const dfa::Vocabulary& ParserInterpreter::getVocabulary() const {
68
+ return _vocabulary;
69
+ }
70
+
71
+ const std::vector<std::string>& ParserInterpreter::getRuleNames() const {
72
+ return _ruleNames;
73
+ }
74
+
75
+ std::string ParserInterpreter::getGrammarFileName() const {
76
+ return _grammarFileName;
77
+ }
78
+
79
+ ParserRuleContext* ParserInterpreter::parse(size_t startRuleIndex) {
80
+ atn::RuleStartState *startRuleStartState = _atn.ruleToStartState[startRuleIndex];
81
+
82
+ _rootContext = createInterpreterRuleContext(nullptr, atn::ATNState::INVALID_STATE_NUMBER, startRuleIndex);
83
+
84
+ if (startRuleStartState->isLeftRecursiveRule) {
85
+ enterRecursionRule(_rootContext, startRuleStartState->stateNumber, startRuleIndex, 0);
86
+ } else {
87
+ enterRule(_rootContext, startRuleStartState->stateNumber, startRuleIndex);
88
+ }
89
+
90
+ while (true) {
91
+ atn::ATNState *p = getATNState();
92
+ switch (p->getStateType()) {
93
+ case atn::ATNStateType::RULE_STOP :
94
+ // pop; return from rule
95
+ if (_ctx->isEmpty()) {
96
+ if (startRuleStartState->isLeftRecursiveRule) {
97
+ ParserRuleContext *result = _ctx;
98
+ auto parentContext = _parentContextStack.top();
99
+ _parentContextStack.pop();
100
+ unrollRecursionContexts(parentContext.first);
101
+ return result;
102
+ } else {
103
+ exitRule();
104
+ return _rootContext;
105
+ }
106
+ }
107
+
108
+ visitRuleStopState(p);
109
+ break;
110
+
111
+ default :
112
+ try {
113
+ visitState(p);
114
+ }
115
+ catch (RecognitionException &e) {
116
+ setState(_atn.ruleToStopState[p->ruleIndex]->stateNumber);
117
+ getErrorHandler()->reportError(this, e);
118
+ getContext()->exception = std::current_exception();
119
+ recover(e);
120
+ }
121
+
122
+ break;
123
+ }
124
+ }
125
+ }
126
+
127
+ void ParserInterpreter::enterRecursionRule(ParserRuleContext *localctx, size_t state, size_t ruleIndex, int precedence) {
128
+ _parentContextStack.push({ _ctx, localctx->invokingState });
129
+ Parser::enterRecursionRule(localctx, state, ruleIndex, precedence);
130
+ }
131
+
132
+ void ParserInterpreter::addDecisionOverride(int decision, int tokenIndex, int forcedAlt) {
133
+ _overrideDecision = decision;
134
+ _overrideDecisionInputIndex = tokenIndex;
135
+ _overrideDecisionAlt = forcedAlt;
136
+ }
137
+
138
+ Ref<InterpreterRuleContext> ParserInterpreter::getOverrideDecisionRoot() const {
139
+ return _overrideDecisionRoot;
140
+ }
141
+
142
+ InterpreterRuleContext* ParserInterpreter::getRootContext() {
143
+ return _rootContext;
144
+ }
145
+
146
+ atn::ATNState* ParserInterpreter::getATNState() {
147
+ return _atn.states[getState()];
148
+ }
149
+
150
+ void ParserInterpreter::visitState(atn::ATNState *p) {
151
+ size_t predictedAlt = 1;
152
+ if (DecisionState::is(p)) {
153
+ predictedAlt = visitDecisionState(downCast<DecisionState*>(p));
154
+ }
155
+
156
+ const atn::Transition *transition = p->transitions[predictedAlt - 1].get();
157
+ switch (transition->getTransitionType()) {
158
+ case atn::TransitionType::EPSILON:
159
+ if (p->getStateType() == ATNStateType::STAR_LOOP_ENTRY &&
160
+ (downCast<StarLoopEntryState *>(p))->isPrecedenceDecision &&
161
+ !LoopEndState::is(transition->target)) {
162
+ // We are at the start of a left recursive rule's (...)* loop
163
+ // and we're not taking the exit branch of loop.
164
+ InterpreterRuleContext *localctx = createInterpreterRuleContext(_parentContextStack.top().first,
165
+ _parentContextStack.top().second, static_cast<int>(_ctx->getRuleIndex()));
166
+ pushNewRecursionContext(localctx, _atn.ruleToStartState[p->ruleIndex]->stateNumber, static_cast<int>(_ctx->getRuleIndex()));
167
+ }
168
+ break;
169
+
170
+ case atn::TransitionType::ATOM:
171
+ match(static_cast<int>(static_cast<const atn::AtomTransition*>(transition)->_label));
172
+ break;
173
+
174
+ case atn::TransitionType::RANGE:
175
+ case atn::TransitionType::SET:
176
+ case atn::TransitionType::NOT_SET:
177
+ if (!transition->matches(static_cast<int>(_input->LA(1)), Token::MIN_USER_TOKEN_TYPE, Lexer::MAX_CHAR_VALUE)) {
178
+ recoverInline();
179
+ }
180
+ matchWildcard();
181
+ break;
182
+
183
+ case atn::TransitionType::WILDCARD:
184
+ matchWildcard();
185
+ break;
186
+
187
+ case atn::TransitionType::RULE:
188
+ {
189
+ atn::RuleStartState *ruleStartState = static_cast<atn::RuleStartState*>(transition->target);
190
+ size_t ruleIndex = ruleStartState->ruleIndex;
191
+ InterpreterRuleContext *newctx = createInterpreterRuleContext(_ctx, p->stateNumber, ruleIndex);
192
+ if (ruleStartState->isLeftRecursiveRule) {
193
+ enterRecursionRule(newctx, ruleStartState->stateNumber, ruleIndex, static_cast<const atn::RuleTransition*>(transition)->precedence);
194
+ } else {
195
+ enterRule(newctx, transition->target->stateNumber, ruleIndex);
196
+ }
197
+ }
198
+ break;
199
+
200
+ case atn::TransitionType::PREDICATE:
201
+ {
202
+ const atn::PredicateTransition *predicateTransition = static_cast<const atn::PredicateTransition*>(transition);
203
+ if (!sempred(_ctx, predicateTransition->getRuleIndex(), predicateTransition->getPredIndex())) {
204
+ throw FailedPredicateException(this);
205
+ }
206
+ }
207
+ break;
208
+
209
+ case atn::TransitionType::ACTION:
210
+ {
211
+ const atn::ActionTransition *actionTransition = static_cast<const atn::ActionTransition*>(transition);
212
+ action(_ctx, actionTransition->ruleIndex, actionTransition->actionIndex);
213
+ }
214
+ break;
215
+
216
+ case atn::TransitionType::PRECEDENCE:
217
+ {
218
+ if (!precpred(_ctx, static_cast<const atn::PrecedencePredicateTransition*>(transition)->getPrecedence())) {
219
+ throw FailedPredicateException(this, "precpred(_ctx, " + std::to_string(static_cast<const atn::PrecedencePredicateTransition*>(transition)->getPrecedence()) + ")");
220
+ }
221
+ }
222
+ break;
223
+
224
+ default:
225
+ throw UnsupportedOperationException("Unrecognized ATN transition type.");
226
+ }
227
+
228
+ setState(transition->target->stateNumber);
229
+ }
230
+
231
+ size_t ParserInterpreter::visitDecisionState(DecisionState *p) {
232
+ size_t predictedAlt = 1;
233
+ if (p->transitions.size() > 1) {
234
+ getErrorHandler()->sync(this);
235
+ int decision = p->decision;
236
+ if (decision == _overrideDecision && _input->index() == _overrideDecisionInputIndex && !_overrideDecisionReached) {
237
+ predictedAlt = _overrideDecisionAlt;
238
+ _overrideDecisionReached = true;
239
+ } else {
240
+ predictedAlt = getInterpreter<ParserATNSimulator>()->adaptivePredict(_input, decision, _ctx);
241
+ }
242
+ }
243
+ return predictedAlt;
244
+ }
245
+
246
+ InterpreterRuleContext* ParserInterpreter::createInterpreterRuleContext(ParserRuleContext *parent,
247
+ size_t invokingStateNumber, size_t ruleIndex) {
248
+ return _tracker.createInstance<InterpreterRuleContext>(parent, invokingStateNumber, ruleIndex);
249
+ }
250
+
251
+ void ParserInterpreter::visitRuleStopState(atn::ATNState *p) {
252
+ atn::RuleStartState *ruleStartState = _atn.ruleToStartState[p->ruleIndex];
253
+ if (ruleStartState->isLeftRecursiveRule) {
254
+ std::pair<ParserRuleContext *, size_t> parentContext = _parentContextStack.top();
255
+ _parentContextStack.pop();
256
+
257
+ unrollRecursionContexts(parentContext.first);
258
+ setState(parentContext.second);
259
+ } else {
260
+ exitRule();
261
+ }
262
+
263
+ const atn::RuleTransition *ruleTransition = static_cast<const atn::RuleTransition*>(_atn.states[getState()]->transitions[0].get());
264
+ setState(ruleTransition->followState->stateNumber);
265
+ }
266
+
267
+ void ParserInterpreter::recover(RecognitionException &e) {
268
+ size_t i = _input->index();
269
+ getErrorHandler()->recover(this, std::make_exception_ptr(e));
270
+
271
+ if (_input->index() == i) {
272
+ // no input consumed, better add an error node
273
+ if (is<InputMismatchException *>(&e)) {
274
+ InputMismatchException &ime = static_cast<InputMismatchException&>(e);
275
+ Token *tok = e.getOffendingToken();
276
+ size_t expectedTokenType = ime.getExpectedTokens().getMinElement(); // get any element
277
+ _errorToken = getTokenFactory()->create({ tok->getTokenSource(), tok->getTokenSource()->getInputStream() },
278
+ expectedTokenType, tok->getText(), Token::DEFAULT_CHANNEL, INVALID_INDEX, INVALID_INDEX, // invalid start/stop
279
+ tok->getLine(), tok->getCharPositionInLine());
280
+ _ctx->addChild(createErrorNode(_errorToken.get()));
281
+ }
282
+ else { // NoViableAlt
283
+ Token *tok = e.getOffendingToken();
284
+ _errorToken = getTokenFactory()->create({ tok->getTokenSource(), tok->getTokenSource()->getInputStream() },
285
+ Token::INVALID_TYPE, tok->getText(), Token::DEFAULT_CHANNEL, INVALID_INDEX, INVALID_INDEX, // invalid start/stop
286
+ tok->getLine(), tok->getCharPositionInLine());
287
+ _ctx->addChild(createErrorNode(_errorToken.get()));
288
+ }
289
+ }
290
+ }
291
+
292
+ Token* ParserInterpreter::recoverInline() {
293
+ return _errHandler->recoverInline(this);
294
+ }
@@ -0,0 +1,173 @@
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 "Parser.h"
9
+ #include "atn/ATN.h"
10
+ #include "support/BitSet.h"
11
+ #include "atn/PredictionContext.h"
12
+ #include "atn/PredictionContextCache.h"
13
+ #include "Vocabulary.h"
14
+
15
+ namespace antlr4 {
16
+
17
+ /// <summary>
18
+ /// A parser simulator that mimics what ANTLR's generated
19
+ /// parser code does. A ParserATNSimulator is used to make
20
+ /// predictions via adaptivePredict but this class moves a pointer through the
21
+ /// ATN to simulate parsing. ParserATNSimulator just
22
+ /// makes us efficient rather than having to backtrack, for example.
23
+ ///
24
+ /// This properly creates parse trees even for left recursive rules.
25
+ ///
26
+ /// We rely on the left recursive rule invocation and special predicate
27
+ /// transitions to make left recursive rules work.
28
+ ///
29
+ /// See TestParserInterpreter for examples.
30
+ /// </summary>
31
+ class ANTLR4CPP_PUBLIC ParserInterpreter : public Parser {
32
+ public:
33
+ ParserInterpreter(const std::string &grammarFileName, const dfa::Vocabulary &vocabulary,
34
+ const std::vector<std::string> &ruleNames, const atn::ATN &atn, TokenStream *input);
35
+ ~ParserInterpreter();
36
+
37
+ virtual void reset() override;
38
+
39
+ virtual const atn::ATN& getATN() const override;
40
+
41
+ virtual const dfa::Vocabulary& getVocabulary() const override;
42
+
43
+ virtual const std::vector<std::string>& getRuleNames() const override;
44
+ virtual std::string getGrammarFileName() const override;
45
+
46
+ /// Begin parsing at startRuleIndex
47
+ virtual ParserRuleContext* parse(size_t startRuleIndex);
48
+
49
+ virtual void enterRecursionRule(ParserRuleContext *localctx, size_t state, size_t ruleIndex, int precedence) override;
50
+
51
+
52
+ /** Override this parser interpreters normal decision-making process
53
+ * at a particular decision and input token index. Instead of
54
+ * allowing the adaptive prediction mechanism to choose the
55
+ * first alternative within a block that leads to a successful parse,
56
+ * force it to take the alternative, 1..n for n alternatives.
57
+ *
58
+ * As an implementation limitation right now, you can only specify one
59
+ * override. This is sufficient to allow construction of different
60
+ * parse trees for ambiguous input. It means re-parsing the entire input
61
+ * in general because you're never sure where an ambiguous sequence would
62
+ * live in the various parse trees. For example, in one interpretation,
63
+ * an ambiguous input sequence would be matched completely in expression
64
+ * but in another it could match all the way back to the root.
65
+ *
66
+ * s : e '!'? ;
67
+ * e : ID
68
+ * | ID '!'
69
+ * ;
70
+ *
71
+ * Here, x! can be matched as (s (e ID) !) or (s (e ID !)). In the first
72
+ * case, the ambiguous sequence is fully contained only by the root.
73
+ * In the second case, the ambiguous sequences fully contained within just
74
+ * e, as in: (e ID !).
75
+ *
76
+ * Rather than trying to optimize this and make
77
+ * some intelligent decisions for optimization purposes, I settled on
78
+ * just re-parsing the whole input and then using
79
+ * {link Trees#getRootOfSubtreeEnclosingRegion} to find the minimal
80
+ * subtree that contains the ambiguous sequence. I originally tried to
81
+ * record the call stack at the point the parser detected and ambiguity but
82
+ * left recursive rules create a parse tree stack that does not reflect
83
+ * the actual call stack. That impedance mismatch was enough to make
84
+ * it it challenging to restart the parser at a deeply nested rule
85
+ * invocation.
86
+ *
87
+ * Only parser interpreters can override decisions so as to avoid inserting
88
+ * override checking code in the critical ALL(*) prediction execution path.
89
+ *
90
+ * @since 4.5.1
91
+ */
92
+ void addDecisionOverride(int decision, int tokenIndex, int forcedAlt);
93
+
94
+ Ref<InterpreterRuleContext> getOverrideDecisionRoot() const;
95
+
96
+ /** Return the root of the parse, which can be useful if the parser
97
+ * bails out. You still can access the top node. Note that,
98
+ * because of the way left recursive rules add children, it's possible
99
+ * that the root will not have any children if the start rule immediately
100
+ * called and left recursive rule that fails.
101
+ *
102
+ * @since 4.5.1
103
+ */
104
+ InterpreterRuleContext* getRootContext();
105
+
106
+ protected:
107
+ const std::string _grammarFileName;
108
+ const atn::ATN &_atn;
109
+
110
+ std::vector<std::string> _ruleNames;
111
+
112
+ std::vector<dfa::DFA> _decisionToDFA; // not shared like it is for generated parsers
113
+ atn::PredictionContextCache _sharedContextCache;
114
+
115
+ /** This stack corresponds to the _parentctx, _parentState pair of locals
116
+ * that would exist on call stack frames with a recursive descent parser;
117
+ * in the generated function for a left-recursive rule you'd see:
118
+ *
119
+ * private EContext e(int _p) throws RecognitionException {
120
+ * ParserRuleContext _parentctx = _ctx; // Pair.a
121
+ * int _parentState = getState(); // Pair.b
122
+ * ...
123
+ * }
124
+ *
125
+ * Those values are used to create new recursive rule invocation contexts
126
+ * associated with left operand of an alt like "expr '*' expr".
127
+ */
128
+ std::stack<std::pair<ParserRuleContext *, size_t>> _parentContextStack;
129
+
130
+ /** We need a map from (decision,inputIndex)->forced alt for computing ambiguous
131
+ * parse trees. For now, we allow exactly one override.
132
+ */
133
+ int _overrideDecision = -1;
134
+ size_t _overrideDecisionInputIndex = INVALID_INDEX;
135
+ size_t _overrideDecisionAlt = INVALID_INDEX;
136
+ bool _overrideDecisionReached = false; // latch and only override once; error might trigger infinite loop
137
+
138
+ /** What is the current context when we override a decision? This tells
139
+ * us what the root of the parse tree is when using override
140
+ * for an ambiguity/lookahead check.
141
+ */
142
+ Ref<InterpreterRuleContext> _overrideDecisionRoot;
143
+ InterpreterRuleContext* _rootContext;
144
+
145
+ virtual atn::ATNState *getATNState();
146
+ virtual void visitState(atn::ATNState *p);
147
+
148
+ /** Method visitDecisionState() is called when the interpreter reaches
149
+ * a decision state (instance of DecisionState). It gives an opportunity
150
+ * for subclasses to track interesting things.
151
+ */
152
+ size_t visitDecisionState(atn::DecisionState *p);
153
+
154
+ /** Provide simple "factory" for InterpreterRuleContext's.
155
+ * @since 4.5.1
156
+ */
157
+ InterpreterRuleContext* createInterpreterRuleContext(ParserRuleContext *parent, size_t invokingStateNumber, size_t ruleIndex);
158
+
159
+ virtual void visitRuleStopState(atn::ATNState *p);
160
+
161
+ /** Rely on the error handler for this parser but, if no tokens are consumed
162
+ * to recover, add an error node. Otherwise, nothing is seen in the parse
163
+ * tree.
164
+ */
165
+ void recover(RecognitionException &e);
166
+ Token* recoverInline();
167
+
168
+ private:
169
+ const dfa::Vocabulary &_vocabulary;
170
+ std::unique_ptr<Token> _errorToken;
171
+ };
172
+
173
+ } // namespace antlr4
@@ -0,0 +1,138 @@
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 "tree/TerminalNode.h"
7
+ #include "tree/ErrorNode.h"
8
+ #include "misc/Interval.h"
9
+ #include "Parser.h"
10
+ #include "Token.h"
11
+
12
+ #include "support/Casts.h"
13
+ #include "support/CPPUtils.h"
14
+
15
+ #include "ParserRuleContext.h"
16
+
17
+ using namespace antlr4;
18
+ using namespace antlr4::tree;
19
+
20
+ using namespace antlrcpp;
21
+
22
+ ParserRuleContext ParserRuleContext::EMPTY;
23
+
24
+ ParserRuleContext::ParserRuleContext()
25
+ : start(nullptr), stop(nullptr) {
26
+ }
27
+
28
+ ParserRuleContext::ParserRuleContext(ParserRuleContext *parent, size_t invokingStateNumber)
29
+ : RuleContext(parent, invokingStateNumber), start(nullptr), stop(nullptr) {
30
+ }
31
+
32
+ void ParserRuleContext::copyFrom(ParserRuleContext *ctx) {
33
+ // from RuleContext
34
+ this->parent = ctx->parent;
35
+ this->invokingState = ctx->invokingState;
36
+
37
+ this->start = ctx->start;
38
+ this->stop = ctx->stop;
39
+
40
+ // copy any error nodes to alt label node
41
+ if (!ctx->children.empty()) {
42
+ for (auto *child : ctx->children) {
43
+ if (ErrorNode::is(child)) {
44
+ downCast<ErrorNode*>(child)->setParent(this);
45
+ children.push_back(child);
46
+ }
47
+ }
48
+
49
+ // Remove the just reparented error nodes from the source context.
50
+ ctx->children.erase(std::remove_if(ctx->children.begin(), ctx->children.end(), [this](tree::ParseTree *e) -> bool {
51
+ return std::find(children.begin(), children.end(), e) != children.end();
52
+ }), ctx->children.end());
53
+ }
54
+ }
55
+
56
+ void ParserRuleContext::enterRule(tree::ParseTreeListener * /*listener*/) {
57
+ }
58
+
59
+ void ParserRuleContext::exitRule(tree::ParseTreeListener * /*listener*/) {
60
+ }
61
+
62
+ tree::TerminalNode* ParserRuleContext::addChild(tree::TerminalNode *t) {
63
+ t->setParent(this);
64
+ children.push_back(t);
65
+ return t;
66
+ }
67
+
68
+ RuleContext* ParserRuleContext::addChild(RuleContext *ruleInvocation) {
69
+ children.push_back(ruleInvocation);
70
+ return ruleInvocation;
71
+ }
72
+
73
+ void ParserRuleContext::removeLastChild() {
74
+ if (!children.empty()) {
75
+ children.pop_back();
76
+ }
77
+ }
78
+
79
+ tree::TerminalNode* ParserRuleContext::getToken(size_t ttype, size_t i) const {
80
+ if (i >= children.size()) {
81
+ return nullptr;
82
+ }
83
+ size_t j = 0; // what token with ttype have we found?
84
+ for (auto *child : children) {
85
+ if (TerminalNode::is(child)) {
86
+ tree::TerminalNode *typedChild = downCast<tree::TerminalNode*>(child);
87
+ Token *symbol = typedChild->getSymbol();
88
+ if (symbol->getType() == ttype) {
89
+ if (j++ == i) {
90
+ return typedChild;
91
+ }
92
+ }
93
+ }
94
+ }
95
+ return nullptr;
96
+ }
97
+
98
+ std::vector<tree::TerminalNode *> ParserRuleContext::getTokens(size_t ttype) const {
99
+ std::vector<tree::TerminalNode*> tokens;
100
+ for (auto *child : children) {
101
+ if (TerminalNode::is(child)) {
102
+ tree::TerminalNode *typedChild = downCast<tree::TerminalNode*>(child);
103
+ Token *symbol = typedChild->getSymbol();
104
+ if (symbol->getType() == ttype) {
105
+ tokens.push_back(typedChild);
106
+ }
107
+ }
108
+ }
109
+ return tokens;
110
+ }
111
+
112
+ misc::Interval ParserRuleContext::getSourceInterval() {
113
+ if (start == nullptr) {
114
+ return misc::Interval::INVALID;
115
+ }
116
+
117
+ if (stop == nullptr || stop->getTokenIndex() < start->getTokenIndex()) {
118
+ return misc::Interval(start->getTokenIndex(), start->getTokenIndex() - 1); // empty
119
+ }
120
+ return misc::Interval(start->getTokenIndex(), stop->getTokenIndex());
121
+ }
122
+
123
+ Token* ParserRuleContext::getStart() const {
124
+ return start;
125
+ }
126
+
127
+ Token* ParserRuleContext::getStop() const {
128
+ return stop;
129
+ }
130
+
131
+ std::string ParserRuleContext::toInfoString(Parser *recognizer) {
132
+ std::vector<std::string> rules = recognizer->getRuleInvocationStack(this);
133
+ std::reverse(rules.begin(), rules.end());
134
+ std::string rulesStr = antlrcpp::arrayToString(rules);
135
+ return "ParserRuleContext" + rulesStr + "{start=" + std::to_string(start->getTokenIndex()) + ", stop=" +
136
+ std::to_string(stop->getTokenIndex()) + '}';
137
+ }
138
+