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,418 @@
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 <functional>
7
+ #include <unordered_set>
8
+
9
+ #include "misc/MurmurHash.h"
10
+ #include "support/Casts.h"
11
+ #include "support/CPPUtils.h"
12
+ #include "support/Arrays.h"
13
+
14
+ #include "SemanticContext.h"
15
+
16
+ using namespace antlr4;
17
+ using namespace antlr4::atn;
18
+ using namespace antlrcpp;
19
+
20
+ namespace {
21
+
22
+ struct SemanticContextHasher final {
23
+ size_t operator()(const SemanticContext *semanticContext) const {
24
+ return semanticContext->hashCode();
25
+ }
26
+ };
27
+
28
+ struct SemanticContextComparer final {
29
+ bool operator()(const SemanticContext *lhs, const SemanticContext *rhs) const {
30
+ return *lhs == *rhs;
31
+ }
32
+ };
33
+
34
+ template <typename Comparer>
35
+ void insertSemanticContext(const Ref<const SemanticContext> &semanticContext,
36
+ std::unordered_set<const SemanticContext*, SemanticContextHasher, SemanticContextComparer> &operandSet,
37
+ std::vector<Ref<const SemanticContext>> &operandList,
38
+ Ref<const SemanticContext::PrecedencePredicate> &precedencePredicate,
39
+ Comparer comparer) {
40
+ if (semanticContext != nullptr) {
41
+ if (semanticContext->getContextType() == SemanticContextType::PRECEDENCE) {
42
+ if (precedencePredicate == nullptr || comparer(downCast<const SemanticContext::PrecedencePredicate*>(semanticContext.get())->precedence, precedencePredicate->precedence)) {
43
+ precedencePredicate = std::static_pointer_cast<const SemanticContext::PrecedencePredicate>(semanticContext);
44
+ }
45
+ } else {
46
+ auto [existing, inserted] = operandSet.insert(semanticContext.get());
47
+ if (inserted) {
48
+ operandList.push_back(semanticContext);
49
+ }
50
+ }
51
+ }
52
+ }
53
+
54
+ template <typename Comparer>
55
+ void insertSemanticContext(Ref<const SemanticContext> &&semanticContext,
56
+ std::unordered_set<const SemanticContext*, SemanticContextHasher, SemanticContextComparer> &operandSet,
57
+ std::vector<Ref<const SemanticContext>> &operandList,
58
+ Ref<const SemanticContext::PrecedencePredicate> &precedencePredicate,
59
+ Comparer comparer) {
60
+ if (semanticContext != nullptr) {
61
+ if (semanticContext->getContextType() == SemanticContextType::PRECEDENCE) {
62
+ if (precedencePredicate == nullptr || comparer(downCast<const SemanticContext::PrecedencePredicate*>(semanticContext.get())->precedence, precedencePredicate->precedence)) {
63
+ precedencePredicate = std::static_pointer_cast<const SemanticContext::PrecedencePredicate>(std::move(semanticContext));
64
+ }
65
+ } else {
66
+ auto [existing, inserted] = operandSet.insert(semanticContext.get());
67
+ if (inserted) {
68
+ operandList.push_back(std::move(semanticContext));
69
+ }
70
+ }
71
+ }
72
+ }
73
+
74
+ size_t predictOperandCapacity(const Ref<const SemanticContext> &x) {
75
+ switch (x->getContextType()) {
76
+ case SemanticContextType::AND:
77
+ return downCast<const SemanticContext::AND&>(*x).getOperands().size();
78
+ case SemanticContextType::OR:
79
+ return downCast<const SemanticContext::OR&>(*x).getOperands().size();
80
+ default:
81
+ return 1;
82
+ }
83
+ }
84
+
85
+ size_t predictOperandCapacity(const Ref<const SemanticContext> &a, const Ref<const SemanticContext> &b) {
86
+ return predictOperandCapacity(a) + predictOperandCapacity(b);
87
+ }
88
+
89
+ }
90
+
91
+ //------------------ Predicate -----------------------------------------------------------------------------------------
92
+
93
+ SemanticContext::Predicate::Predicate(size_t ruleIndex, size_t predIndex, bool isCtxDependent)
94
+ : SemanticContext(SemanticContextType::PREDICATE), ruleIndex(ruleIndex), predIndex(predIndex), isCtxDependent(isCtxDependent) {}
95
+
96
+ bool SemanticContext::Predicate::eval(Recognizer *parser, RuleContext *parserCallStack) const {
97
+ RuleContext *localctx = nullptr;
98
+ if (isCtxDependent) {
99
+ localctx = parserCallStack;
100
+ }
101
+ return parser->sempred(localctx, ruleIndex, predIndex);
102
+ }
103
+
104
+ size_t SemanticContext::Predicate::hashCode() const {
105
+ size_t hashCode = misc::MurmurHash::initialize();
106
+ hashCode = misc::MurmurHash::update(hashCode, static_cast<size_t>(getContextType()));
107
+ hashCode = misc::MurmurHash::update(hashCode, ruleIndex);
108
+ hashCode = misc::MurmurHash::update(hashCode, predIndex);
109
+ hashCode = misc::MurmurHash::update(hashCode, isCtxDependent ? 1 : 0);
110
+ hashCode = misc::MurmurHash::finish(hashCode, 4);
111
+ return hashCode;
112
+ }
113
+
114
+ bool SemanticContext::Predicate::equals(const SemanticContext &other) const {
115
+ if (this == &other) {
116
+ return true;
117
+ }
118
+ if (getContextType() != other.getContextType()) {
119
+ return false;
120
+ }
121
+ const Predicate &p = downCast<const Predicate&>(other);
122
+ return ruleIndex == p.ruleIndex && predIndex == p.predIndex && isCtxDependent == p.isCtxDependent;
123
+ }
124
+
125
+ std::string SemanticContext::Predicate::toString() const {
126
+ return std::string("{") + std::to_string(ruleIndex) + std::string(":") + std::to_string(predIndex) + std::string("}?");
127
+ }
128
+
129
+ //------------------ PrecedencePredicate -------------------------------------------------------------------------------
130
+
131
+ SemanticContext::PrecedencePredicate::PrecedencePredicate(int precedence) : SemanticContext(SemanticContextType::PRECEDENCE), precedence(precedence) {}
132
+
133
+ bool SemanticContext::PrecedencePredicate::eval(Recognizer *parser, RuleContext *parserCallStack) const {
134
+ return parser->precpred(parserCallStack, precedence);
135
+ }
136
+
137
+ Ref<const SemanticContext> SemanticContext::PrecedencePredicate::evalPrecedence(Recognizer *parser,
138
+ RuleContext *parserCallStack) const {
139
+ if (parser->precpred(parserCallStack, precedence)) {
140
+ return SemanticContext::NONE;
141
+ }
142
+ return nullptr;
143
+ }
144
+
145
+ size_t SemanticContext::PrecedencePredicate::hashCode() const {
146
+ size_t hashCode = misc::MurmurHash::initialize();
147
+ hashCode = misc::MurmurHash::update(hashCode, static_cast<size_t>(getContextType()));
148
+ hashCode = misc::MurmurHash::update(hashCode, static_cast<size_t>(precedence));
149
+ return misc::MurmurHash::finish(hashCode, 2);
150
+ }
151
+
152
+ bool SemanticContext::PrecedencePredicate::equals(const SemanticContext &other) const {
153
+ if (this == &other) {
154
+ return true;
155
+ }
156
+ if (getContextType() != other.getContextType()) {
157
+ return false;
158
+ }
159
+ const PrecedencePredicate &predicate = downCast<const PrecedencePredicate&>(other);
160
+ return precedence == predicate.precedence;
161
+ }
162
+
163
+ std::string SemanticContext::PrecedencePredicate::toString() const {
164
+ return "{" + std::to_string(precedence) + ">=prec}?";
165
+ }
166
+
167
+ //------------------ AND -----------------------------------------------------------------------------------------------
168
+
169
+ SemanticContext::AND::AND(Ref<const SemanticContext> a, Ref<const SemanticContext> b) : Operator(SemanticContextType::AND) {
170
+ std::unordered_set<const SemanticContext*, SemanticContextHasher, SemanticContextComparer> operands;
171
+ Ref<const SemanticContext::PrecedencePredicate> precedencePredicate;
172
+
173
+ _opnds.reserve(predictOperandCapacity(a, b) + 1);
174
+
175
+ if (a->getContextType() == SemanticContextType::AND) {
176
+ for (const auto &operand : downCast<const AND*>(a.get())->getOperands()) {
177
+ insertSemanticContext(operand, operands, _opnds, precedencePredicate, std::less<int>{});
178
+ }
179
+ } else {
180
+ insertSemanticContext(std::move(a), operands, _opnds, precedencePredicate, std::less<int>{});
181
+ }
182
+
183
+ if (b->getContextType() == SemanticContextType::AND) {
184
+ for (const auto &operand : downCast<const AND*>(b.get())->getOperands()) {
185
+ insertSemanticContext(operand, operands, _opnds, precedencePredicate, std::less<int>{});
186
+ }
187
+ } else {
188
+ insertSemanticContext(std::move(b), operands, _opnds, precedencePredicate, std::less<int>{});
189
+ }
190
+
191
+ if (precedencePredicate != nullptr) {
192
+ // interested in the transition with the lowest precedence
193
+ auto [existing, inserted] = operands.insert(precedencePredicate.get());
194
+ if (inserted) {
195
+ _opnds.push_back(std::move(precedencePredicate));
196
+ }
197
+ }
198
+ }
199
+
200
+ const std::vector<Ref<const SemanticContext>>& SemanticContext::AND::getOperands() const {
201
+ return _opnds;
202
+ }
203
+
204
+ bool SemanticContext::AND::equals(const SemanticContext &other) const {
205
+ if (this == &other) {
206
+ return true;
207
+ }
208
+ if (getContextType() != other.getContextType()) {
209
+ return false;
210
+ }
211
+ const AND &context = downCast<const AND&>(other);
212
+ return Arrays::equals(getOperands(), context.getOperands());
213
+ }
214
+
215
+ size_t SemanticContext::AND::hashCode() const {
216
+ size_t hash = misc::MurmurHash::initialize();
217
+ hash = misc::MurmurHash::update(hash, static_cast<size_t>(getContextType()));
218
+ return misc::MurmurHash::hashCode(getOperands(), hash);
219
+ }
220
+
221
+ bool SemanticContext::AND::eval(Recognizer *parser, RuleContext *parserCallStack) const {
222
+ for (const auto &opnd : getOperands()) {
223
+ if (!opnd->eval(parser, parserCallStack)) {
224
+ return false;
225
+ }
226
+ }
227
+ return true;
228
+ }
229
+
230
+ Ref<const SemanticContext> SemanticContext::AND::evalPrecedence(Recognizer *parser, RuleContext *parserCallStack) const {
231
+ bool differs = false;
232
+ std::vector<Ref<const SemanticContext>> operands;
233
+ for (const auto &context : getOperands()) {
234
+ auto evaluated = context->evalPrecedence(parser, parserCallStack);
235
+ differs |= (evaluated != context);
236
+ if (evaluated == nullptr) {
237
+ // The AND context is false if any element is false.
238
+ return nullptr;
239
+ }
240
+ if (evaluated != NONE) {
241
+ // Reduce the result by skipping true elements.
242
+ operands.push_back(std::move(evaluated));
243
+ }
244
+ }
245
+
246
+ if (!differs) {
247
+ return shared_from_this();
248
+ }
249
+
250
+ if (operands.empty()) {
251
+ // All elements were true, so the AND context is true.
252
+ return NONE;
253
+ }
254
+
255
+ Ref<const SemanticContext> result = std::move(operands[0]);
256
+ for (size_t i = 1; i < operands.size(); ++i) {
257
+ result = SemanticContext::And(std::move(result), std::move(operands[i]));
258
+ }
259
+
260
+ return result;
261
+ }
262
+
263
+ std::string SemanticContext::AND::toString() const {
264
+ std::string tmp;
265
+ for (const auto &var : getOperands()) {
266
+ tmp += var->toString() + " && ";
267
+ }
268
+ return tmp;
269
+ }
270
+
271
+ //------------------ OR ------------------------------------------------------------------------------------------------
272
+
273
+ SemanticContext::OR::OR(Ref<const SemanticContext> a, Ref<const SemanticContext> b) : Operator(SemanticContextType::OR) {
274
+ std::unordered_set<const SemanticContext*, SemanticContextHasher, SemanticContextComparer> operands;
275
+ Ref<const SemanticContext::PrecedencePredicate> precedencePredicate;
276
+
277
+ _opnds.reserve(predictOperandCapacity(a, b) + 1);
278
+
279
+ if (a->getContextType() == SemanticContextType::OR) {
280
+ for (const auto &operand : downCast<const OR*>(a.get())->getOperands()) {
281
+ insertSemanticContext(operand, operands, _opnds, precedencePredicate, std::greater<int>{});
282
+ }
283
+ } else {
284
+ insertSemanticContext(std::move(a), operands, _opnds, precedencePredicate, std::greater<int>{});
285
+ }
286
+
287
+ if (b->getContextType() == SemanticContextType::OR) {
288
+ for (const auto &operand : downCast<const OR*>(b.get())->getOperands()) {
289
+ insertSemanticContext(operand, operands, _opnds, precedencePredicate, std::greater<int>{});
290
+ }
291
+ } else {
292
+ insertSemanticContext(std::move(b), operands, _opnds, precedencePredicate, std::greater<int>{});
293
+ }
294
+
295
+ if (precedencePredicate != nullptr) {
296
+ // interested in the transition with the highest precedence
297
+ auto [existing, inserted] = operands.insert(precedencePredicate.get());
298
+ if (inserted) {
299
+ _opnds.push_back(std::move(precedencePredicate));
300
+ }
301
+ }
302
+ }
303
+
304
+ const std::vector<Ref<const SemanticContext>>& SemanticContext::OR::getOperands() const {
305
+ return _opnds;
306
+ }
307
+
308
+ bool SemanticContext::OR::equals(const SemanticContext &other) const {
309
+ if (this == &other) {
310
+ return true;
311
+ }
312
+ if (getContextType() != other.getContextType()) {
313
+ return false;
314
+ }
315
+ const OR &context = downCast<const OR&>(other);
316
+ return Arrays::equals(getOperands(), context.getOperands());
317
+ }
318
+
319
+ size_t SemanticContext::OR::hashCode() const {
320
+ size_t hash = misc::MurmurHash::initialize();
321
+ hash = misc::MurmurHash::update(hash, static_cast<size_t>(getContextType()));
322
+ return misc::MurmurHash::hashCode(getOperands(), hash);
323
+ }
324
+
325
+ bool SemanticContext::OR::eval(Recognizer *parser, RuleContext *parserCallStack) const {
326
+ for (const auto &opnd : getOperands()) {
327
+ if (opnd->eval(parser, parserCallStack)) {
328
+ return true;
329
+ }
330
+ }
331
+ return false;
332
+ }
333
+
334
+ Ref<const SemanticContext> SemanticContext::OR::evalPrecedence(Recognizer *parser, RuleContext *parserCallStack) const {
335
+ bool differs = false;
336
+ std::vector<Ref<const SemanticContext>> operands;
337
+ for (const auto &context : getOperands()) {
338
+ auto evaluated = context->evalPrecedence(parser, parserCallStack);
339
+ differs |= (evaluated != context);
340
+ if (evaluated == NONE) {
341
+ // The OR context is true if any element is true.
342
+ return NONE;
343
+ }
344
+ if (evaluated != nullptr) {
345
+ // Reduce the result by skipping false elements.
346
+ operands.push_back(std::move(evaluated));
347
+ }
348
+ }
349
+
350
+ if (!differs) {
351
+ return shared_from_this();
352
+ }
353
+
354
+ if (operands.empty()) {
355
+ // All elements were false, so the OR context is false.
356
+ return nullptr;
357
+ }
358
+
359
+ Ref<const SemanticContext> result = std::move(operands[0]);
360
+ for (size_t i = 1; i < operands.size(); ++i) {
361
+ result = SemanticContext::Or(std::move(result), std::move(operands[i]));
362
+ }
363
+
364
+ return result;
365
+ }
366
+
367
+ std::string SemanticContext::OR::toString() const {
368
+ std::string tmp;
369
+ for(const auto &var : getOperands()) {
370
+ tmp += var->toString() + " || ";
371
+ }
372
+ return tmp;
373
+ }
374
+
375
+ //------------------ SemanticContext -----------------------------------------------------------------------------------
376
+
377
+ const Ref<const SemanticContext> SemanticContext::NONE = std::make_shared<Predicate>(INVALID_INDEX, INVALID_INDEX, false);
378
+
379
+ Ref<const SemanticContext> SemanticContext::evalPrecedence(Recognizer * /*parser*/, RuleContext * /*parserCallStack*/) const {
380
+ return shared_from_this();
381
+ }
382
+
383
+ Ref<const SemanticContext> SemanticContext::And(Ref<const SemanticContext> a, Ref<const SemanticContext> b) {
384
+ if (!a || a == NONE) {
385
+ return b;
386
+ }
387
+
388
+ if (!b || b == NONE) {
389
+ return a;
390
+ }
391
+
392
+ Ref<AND> result = std::make_shared<AND>(std::move(a), std::move(b));
393
+ if (result->getOperands().size() == 1) {
394
+ return result->getOperands()[0];
395
+ }
396
+
397
+ return result;
398
+ }
399
+
400
+ Ref<const SemanticContext> SemanticContext::Or(Ref<const SemanticContext> a, Ref<const SemanticContext> b) {
401
+ if (!a) {
402
+ return b;
403
+ }
404
+ if (!b) {
405
+ return a;
406
+ }
407
+
408
+ if (a == NONE || b == NONE) {
409
+ return NONE;
410
+ }
411
+
412
+ Ref<OR> result = std::make_shared<OR>(std::move(a), std::move(b));
413
+ if (result->getOperands().size() == 1) {
414
+ return result->getOperands()[0];
415
+ }
416
+
417
+ return result;
418
+ }
@@ -0,0 +1,233 @@
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 "Recognizer.h"
9
+ #include "support/CPPUtils.h"
10
+ #include "atn/SemanticContextType.h"
11
+
12
+ namespace antlr4 {
13
+ namespace atn {
14
+
15
+ /// A tree structure used to record the semantic context in which
16
+ /// an ATN configuration is valid. It's either a single predicate,
17
+ /// a conjunction "p1 && p2", or a sum of products "p1||p2".
18
+ ///
19
+ /// I have scoped the AND, OR, and Predicate subclasses of
20
+ /// SemanticContext within the scope of this outer class.
21
+ class ANTLR4CPP_PUBLIC SemanticContext : public std::enable_shared_from_this<SemanticContext> {
22
+ public:
23
+ /**
24
+ * The default {@link SemanticContext}, which is semantically equivalent to
25
+ * a predicate of the form {@code {true}?}.
26
+ */
27
+ static const Ref<const SemanticContext> NONE;
28
+
29
+ virtual ~SemanticContext() = default;
30
+
31
+ SemanticContextType getContextType() const { return _contextType; }
32
+
33
+ /// <summary>
34
+ /// For context independent predicates, we evaluate them without a local
35
+ /// context (i.e., null context). That way, we can evaluate them without
36
+ /// having to create proper rule-specific context during prediction (as
37
+ /// opposed to the parser, which creates them naturally). In a practical
38
+ /// sense, this avoids a cast exception from RuleContext to myruleContext.
39
+ /// <p/>
40
+ /// For context dependent predicates, we must pass in a local context so that
41
+ /// references such as $arg evaluate properly as _localctx.arg. We only
42
+ /// capture context dependent predicates in the context in which we begin
43
+ /// prediction, so we passed in the outer context here in case of context
44
+ /// dependent predicate evaluation.
45
+ /// </summary>
46
+ virtual bool eval(Recognizer *parser, RuleContext *parserCallStack) const = 0;
47
+
48
+ /**
49
+ * Evaluate the precedence predicates for the context and reduce the result.
50
+ *
51
+ * @param parser The parser instance.
52
+ * @param parserCallStack
53
+ * @return The simplified semantic context after precedence predicates are
54
+ * evaluated, which will be one of the following values.
55
+ * <ul>
56
+ * <li>{@link #NONE}: if the predicate simplifies to {@code true} after
57
+ * precedence predicates are evaluated.</li>
58
+ * <li>{@code null}: if the predicate simplifies to {@code false} after
59
+ * precedence predicates are evaluated.</li>
60
+ * <li>{@code this}: if the semantic context is not changed as a result of
61
+ * precedence predicate evaluation.</li>
62
+ * <li>A non-{@code null} {@link SemanticContext}: the new simplified
63
+ * semantic context after precedence predicates are evaluated.</li>
64
+ * </ul>
65
+ */
66
+ virtual Ref<const SemanticContext> evalPrecedence(Recognizer *parser, RuleContext *parserCallStack) const;
67
+
68
+ virtual size_t hashCode() const = 0;
69
+
70
+ virtual bool equals(const SemanticContext &other) const = 0;
71
+
72
+ virtual std::string toString() const = 0;
73
+
74
+ static Ref<const SemanticContext> And(Ref<const SemanticContext> a, Ref<const SemanticContext> b);
75
+
76
+ /// See also: ParserATNSimulator::getPredsForAmbigAlts.
77
+ static Ref<const SemanticContext> Or(Ref<const SemanticContext> a, Ref<const SemanticContext> b);
78
+
79
+ class Predicate;
80
+ class PrecedencePredicate;
81
+ class Operator;
82
+ class AND;
83
+ class OR;
84
+
85
+ protected:
86
+ explicit SemanticContext(SemanticContextType contextType) : _contextType(contextType) {}
87
+
88
+ private:
89
+ const SemanticContextType _contextType;
90
+ };
91
+
92
+ inline bool operator==(const SemanticContext &lhs, const SemanticContext &rhs) {
93
+ return lhs.equals(rhs);
94
+ }
95
+
96
+ inline bool operator!=(const SemanticContext &lhs, const SemanticContext &rhs) {
97
+ return !operator==(lhs, rhs);
98
+ }
99
+
100
+ class ANTLR4CPP_PUBLIC SemanticContext::Predicate final : public SemanticContext {
101
+ public:
102
+ static bool is(const SemanticContext &semanticContext) { return semanticContext.getContextType() == SemanticContextType::PREDICATE; }
103
+
104
+ static bool is(const SemanticContext *semanticContext) { return semanticContext != nullptr && is(*semanticContext); }
105
+
106
+ const size_t ruleIndex;
107
+ const size_t predIndex;
108
+ const bool isCtxDependent; // e.g., $i ref in pred
109
+
110
+ Predicate(size_t ruleIndex, size_t predIndex, bool isCtxDependent);
111
+
112
+ bool eval(Recognizer *parser, RuleContext *parserCallStack) const override;
113
+ size_t hashCode() const override;
114
+ bool equals(const SemanticContext &other) const override;
115
+ std::string toString() const override;
116
+ };
117
+
118
+ class ANTLR4CPP_PUBLIC SemanticContext::PrecedencePredicate final : public SemanticContext {
119
+ public:
120
+ static bool is(const SemanticContext &semanticContext) { return semanticContext.getContextType() == SemanticContextType::PRECEDENCE; }
121
+
122
+ static bool is(const SemanticContext *semanticContext) { return semanticContext != nullptr && is(*semanticContext); }
123
+
124
+ const int precedence;
125
+
126
+ explicit PrecedencePredicate(int precedence);
127
+
128
+ bool eval(Recognizer *parser, RuleContext *parserCallStack) const override;
129
+ Ref<const SemanticContext> evalPrecedence(Recognizer *parser, RuleContext *parserCallStack) const override;
130
+ size_t hashCode() const override;
131
+ bool equals(const SemanticContext &other) const override;
132
+ std::string toString() const override;
133
+ };
134
+
135
+ /**
136
+ * This is the base class for semantic context "operators", which operate on
137
+ * a collection of semantic context "operands".
138
+ *
139
+ * @since 4.3
140
+ */
141
+ class ANTLR4CPP_PUBLIC SemanticContext::Operator : public SemanticContext {
142
+ public:
143
+ static bool is(const SemanticContext &semanticContext) {
144
+ const auto contextType = semanticContext.getContextType();
145
+ return contextType == SemanticContextType::AND || contextType == SemanticContextType::OR;
146
+ }
147
+
148
+ static bool is(const SemanticContext *semanticContext) { return semanticContext != nullptr && is(*semanticContext); }
149
+
150
+ /**
151
+ * Gets the operands for the semantic context operator.
152
+ *
153
+ * @return a collection of {@link SemanticContext} operands for the
154
+ * operator.
155
+ *
156
+ * @since 4.3
157
+ */
158
+
159
+ virtual const std::vector<Ref<const SemanticContext>>& getOperands() const = 0;
160
+
161
+ protected:
162
+ using SemanticContext::SemanticContext;
163
+ };
164
+
165
+ /**
166
+ * A semantic context which is true whenever none of the contained contexts
167
+ * is false.
168
+ */
169
+ class ANTLR4CPP_PUBLIC SemanticContext::AND final : public SemanticContext::Operator {
170
+ public:
171
+ static bool is(const SemanticContext &semanticContext) { return semanticContext.getContextType() == SemanticContextType::AND; }
172
+
173
+ static bool is(const SemanticContext *semanticContext) { return semanticContext != nullptr && is(*semanticContext); }
174
+
175
+ AND(Ref<const SemanticContext> a, Ref<const SemanticContext> b) ;
176
+
177
+ const std::vector<Ref<const SemanticContext>>& getOperands() const override;
178
+
179
+ /**
180
+ * The evaluation of predicates by this context is short-circuiting, but
181
+ * unordered.</p>
182
+ */
183
+ bool eval(Recognizer *parser, RuleContext *parserCallStack) const override;
184
+ Ref<const SemanticContext> evalPrecedence(Recognizer *parser, RuleContext *parserCallStack) const override;
185
+ size_t hashCode() const override;
186
+ bool equals(const SemanticContext &other) const override;
187
+ std::string toString() const override;
188
+
189
+ private:
190
+ std::vector<Ref<const SemanticContext>> _opnds;
191
+ };
192
+
193
+ /**
194
+ * A semantic context which is true whenever at least one of the contained
195
+ * contexts is true.
196
+ */
197
+ class ANTLR4CPP_PUBLIC SemanticContext::OR final : public SemanticContext::Operator {
198
+ public:
199
+ static bool is(const SemanticContext &semanticContext) { return semanticContext.getContextType() == SemanticContextType::OR; }
200
+
201
+ static bool is(const SemanticContext *semanticContext) { return semanticContext != nullptr && is(*semanticContext); }
202
+
203
+ OR(Ref<const SemanticContext> a, Ref<const SemanticContext> b);
204
+
205
+ const std::vector<Ref<const SemanticContext>>& getOperands() const override;
206
+
207
+ /**
208
+ * The evaluation of predicates by this context is short-circuiting, but
209
+ * unordered.
210
+ */
211
+ bool eval(Recognizer *parser, RuleContext *parserCallStack) const override;
212
+ Ref<const SemanticContext> evalPrecedence(Recognizer *parser, RuleContext *parserCallStack) const override;
213
+ size_t hashCode() const override;
214
+ bool equals(const SemanticContext &other) const override;
215
+ std::string toString() const override;
216
+
217
+ private:
218
+ std::vector<Ref<const SemanticContext>> _opnds;
219
+ };
220
+
221
+ } // namespace atn
222
+ } // namespace antlr4
223
+
224
+ namespace std {
225
+
226
+ template <>
227
+ struct hash<::antlr4::atn::SemanticContext> {
228
+ size_t operator()(const ::antlr4::atn::SemanticContext &semanticContext) const {
229
+ return semanticContext.hashCode();
230
+ }
231
+ };
232
+
233
+ } // namespace std
@@ -0,0 +1,23 @@
1
+ /* Copyright (c) 2012-2017 The ANTLR Project. All rights reserved.
2
+ * Use of this file is governed by the BSD 3-clause license that
3
+ * can be found in the LICENSE.txt file in the project root.
4
+ */
5
+
6
+ #pragma once
7
+
8
+ #include <cstddef>
9
+
10
+ #include "antlr4-common.h"
11
+
12
+ namespace antlr4 {
13
+ namespace atn {
14
+
15
+ enum class SemanticContextType : size_t {
16
+ PREDICATE = 1,
17
+ PRECEDENCE = 2,
18
+ AND = 3,
19
+ OR = 4,
20
+ };
21
+
22
+ } // namespace atn
23
+ } // namespace antlr4