jaclang 0.6.0__py3-none-any.whl → 0.6.5__py3-none-any.whl

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.

Potentially problematic release.


This version of jaclang might be problematic. Click here for more details.

Files changed (1348) hide show
  1. jaclang/__init__.py +1 -9
  2. jaclang/cli/.gitignore +3 -0
  3. jaclang/cli/cli.md +190 -0
  4. jaclang/cli/cli.py +115 -7
  5. jaclang/cli/cmdreg.py +18 -6
  6. jaclang/compiler/.gitignore +1 -0
  7. jaclang/compiler/__init__.py +1 -0
  8. jaclang/compiler/absyntree.py +8 -9
  9. jaclang/compiler/compile.py +4 -4
  10. jaclang/compiler/jac.lark +1 -0
  11. jaclang/compiler/parser.py +16 -3
  12. jaclang/compiler/passes/main/def_impl_match_pass.py +8 -1
  13. jaclang/compiler/passes/main/fuse_typeinfo_pass.py +20 -8
  14. jaclang/compiler/passes/main/import_pass.py +78 -47
  15. jaclang/compiler/passes/main/pyast_gen_pass.py +6 -57
  16. jaclang/compiler/passes/main/pyast_load_pass.py +33 -6
  17. jaclang/compiler/passes/main/pyjac_ast_link_pass.py +218 -0
  18. jaclang/compiler/passes/main/schedules.py +2 -0
  19. jaclang/compiler/passes/main/sym_tab_build_pass.py +9 -3
  20. jaclang/compiler/passes/main/tests/fixtures/autoimpl.impl/getme.impl.jac +3 -0
  21. jaclang/compiler/passes/main/tests/fixtures/autoimpl.impl.jac +3 -0
  22. jaclang/compiler/passes/main/tests/fixtures/autoimpl.jac +9 -0
  23. jaclang/compiler/passes/main/tests/fixtures/autoimpl.something.else.impl.jac +3 -0
  24. jaclang/compiler/passes/main/tests/fixtures/base.jac +13 -0
  25. jaclang/compiler/passes/main/tests/fixtures/base2.jac +14 -0
  26. jaclang/compiler/passes/main/tests/fixtures/blip.jac +2 -0
  27. jaclang/compiler/passes/main/tests/fixtures/codegentext.jac +31 -0
  28. jaclang/compiler/passes/main/tests/fixtures/decls.jac +10 -0
  29. jaclang/compiler/passes/main/tests/fixtures/defs_and_uses.jac +44 -0
  30. jaclang/compiler/passes/main/tests/fixtures/fstrings.jac +4 -0
  31. jaclang/compiler/passes/main/tests/fixtures/func.jac +18 -0
  32. jaclang/compiler/passes/main/tests/fixtures/func2.jac +8 -0
  33. jaclang/compiler/passes/main/tests/fixtures/game1.jac +15 -0
  34. jaclang/compiler/passes/main/tests/fixtures/impl/defs1.jac +8 -0
  35. jaclang/compiler/passes/main/tests/fixtures/impl/defs2.jac +8 -0
  36. jaclang/compiler/passes/main/tests/fixtures/impl/imps.jac +11 -0
  37. jaclang/compiler/passes/main/tests/fixtures/multi_def_err.jac +7 -0
  38. jaclang/compiler/passes/main/tests/fixtures/registry.jac +36 -0
  39. jaclang/compiler/passes/main/tests/fixtures/type_info.jac +31 -0
  40. jaclang/compiler/passes/main/tests/test_import_pass.py +11 -0
  41. jaclang/compiler/passes/main/tests/test_type_check_pass.py +15 -0
  42. jaclang/compiler/passes/tool/tests/fixtures/corelib.jac +480 -0
  43. jaclang/compiler/passes/tool/tests/fixtures/corelib_fmt.jac +480 -0
  44. jaclang/compiler/passes/tool/tests/fixtures/genai/essay_review.jac +36 -0
  45. jaclang/compiler/passes/tool/tests/fixtures/genai/expert_answer.jac +17 -0
  46. jaclang/compiler/passes/tool/tests/fixtures/genai/joke_gen.jac +32 -0
  47. jaclang/compiler/passes/tool/tests/fixtures/genai/odd_word_out.jac +27 -0
  48. jaclang/compiler/passes/tool/tests/fixtures/genai/personality_finder.jac +35 -0
  49. jaclang/compiler/passes/tool/tests/fixtures/genai/text_to_type.jac +25 -0
  50. jaclang/compiler/passes/tool/tests/fixtures/genai/translator.jac +13 -0
  51. jaclang/compiler/passes/tool/tests/fixtures/genai/wikipedia.jac +63 -0
  52. jaclang/compiler/passes/tool/tests/fixtures/multi_def_err.dot +39 -0
  53. jaclang/compiler/passes/tool/tests/fixtures/multi_def_err.jac +7 -0
  54. jaclang/compiler/passes/tool/tests/fixtures/multi_def_err.txt +20 -0
  55. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/ability_impl_long_comprehension.jac +15 -0
  56. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/call_with_many_parameters.jac +24 -0
  57. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/entry_main.jac +4 -0
  58. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/long_line_nested_dict_access.jac +10 -0
  59. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/multiline_fstrings.jac +16 -0
  60. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/nested_dict.jac +15 -0
  61. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/nested_loop_and_incrementer.jac +13 -0
  62. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/simple_walker.jac +25 -0
  63. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/try_block_and_walker_spawn_and_fstrings.jac +26 -0
  64. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/tuple_iteration_and_not_negation.jac +20 -0
  65. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/type_annotation.jac +3 -0
  66. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/walker_decl_only.jac +12 -0
  67. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/walker_with_default_values_types_and_docstrings.jac +18 -0
  68. jaclang/compiler/passes/tool/tests/fixtures/myca_formatted_code/walker_with_inline_ability_impl.jac +8 -0
  69. jaclang/compiler/passes/tool/tests/fixtures/simple_walk.jac +47 -0
  70. jaclang/compiler/passes/tool/tests/fixtures/simple_walk_fmt.jac +47 -0
  71. jaclang/compiler/passes/utils/mypy_ast_build.py +8 -0
  72. jaclang/compiler/tests/fixtures/fam.jac +67 -0
  73. jaclang/compiler/tests/fixtures/hello_world.jac +5 -0
  74. jaclang/compiler/tests/fixtures/kwesc.jac +5 -0
  75. jaclang/compiler/tests/fixtures/mod_doc_test.jac +1 -0
  76. jaclang/compiler/tests/fixtures/staticcheck.jac +20 -0
  77. jaclang/compiler/tests/fixtures/stuff.jac +6 -0
  78. jaclang/core/aott.py +10 -1
  79. jaclang/core/construct.py +157 -21
  80. jaclang/core/importer.py +6 -2
  81. jaclang/core/memory.py +48 -0
  82. jaclang/core/shelve_storage.py +55 -0
  83. jaclang/langserve/__init__.py +1 -0
  84. jaclang/langserve/server.py +108 -0
  85. jaclang/langserve/tests/__init__.py +1 -0
  86. jaclang/langserve/tests/defaults.py +226 -0
  87. jaclang/langserve/tests/fixtures/hello.jac +1 -0
  88. jaclang/langserve/tests/pylsp_jsonrpc/__init__.py +2 -0
  89. jaclang/langserve/tests/pylsp_jsonrpc/dispatchers.py +37 -0
  90. jaclang/langserve/tests/pylsp_jsonrpc/endpoint.py +294 -0
  91. jaclang/langserve/tests/pylsp_jsonrpc/exceptions.py +114 -0
  92. jaclang/langserve/tests/pylsp_jsonrpc/streams.py +113 -0
  93. jaclang/langserve/tests/session.py +255 -0
  94. jaclang/langserve/tests/test_server.py +36 -0
  95. jaclang/langserve/utils.py +53 -0
  96. jaclang/plugin/__init__.py +1 -2
  97. jaclang/plugin/builtin.py +1 -1
  98. jaclang/plugin/default.py +97 -4
  99. jaclang/plugin/feature.py +28 -9
  100. jaclang/plugin/spec.py +45 -10
  101. jaclang/plugin/tests/fixtures/impl_match.jac +9 -0
  102. jaclang/plugin/tests/fixtures/impl_match_impl.jac +3 -0
  103. jaclang/plugin/tests/fixtures/simple_node_connection.jac +55 -0
  104. jaclang/plugin/tests/fixtures/simple_persistent.jac +41 -0
  105. jaclang/plugin/tests/test_jaseci.py +219 -0
  106. jaclang/settings.py +5 -0
  107. jaclang/tests/fixtures/abc.jac +73 -0
  108. jaclang/tests/fixtures/access_checker.jac +19 -0
  109. jaclang/tests/fixtures/access_modifier.jac +49 -0
  110. jaclang/tests/fixtures/aott_raise.jac +25 -0
  111. jaclang/tests/fixtures/arithmetic_bug.jac +13 -0
  112. jaclang/tests/fixtures/assign_compr.jac +15 -0
  113. jaclang/tests/fixtures/assign_compr_dup.jac +15 -0
  114. jaclang/tests/fixtures/builtin_dotgen.jac +41 -0
  115. jaclang/tests/fixtures/chandra_bugs.jac +11 -0
  116. jaclang/tests/fixtures/chandra_bugs2.jac +26 -0
  117. jaclang/tests/fixtures/circle_pysolo.py +91 -0
  118. jaclang/tests/fixtures/deep/deeper/deep_outer_import.jac +9 -0
  119. jaclang/tests/fixtures/deep/deeper/deep_outer_import2.jac +9 -0
  120. jaclang/tests/fixtures/deep/deeper/snd_lev.jac +6 -0
  121. jaclang/tests/fixtures/deep/mycode.jac +4 -0
  122. jaclang/tests/fixtures/deep/one_lev.jac +6 -0
  123. jaclang/tests/fixtures/deep/one_lev_dup.jac +6 -0
  124. jaclang/tests/fixtures/deep/one_lev_dup_py.py +6 -0
  125. jaclang/tests/fixtures/deep_convert.jac +5 -0
  126. jaclang/tests/fixtures/deep_convo.py +6 -0
  127. jaclang/tests/fixtures/deep_import.jac +7 -0
  128. jaclang/tests/fixtures/deferred_field.jac +13 -0
  129. jaclang/tests/fixtures/disconn.jac +29 -0
  130. jaclang/tests/fixtures/edge_node_walk.jac +46 -0
  131. jaclang/tests/fixtures/edge_ops.jac +45 -0
  132. jaclang/tests/fixtures/edges_walk.jac +38 -0
  133. jaclang/tests/fixtures/enum_inside_archtype.jac +20 -0
  134. jaclang/tests/fixtures/err.jac +5 -0
  135. jaclang/tests/fixtures/err2.jac +5 -0
  136. jaclang/tests/fixtures/game1.jac +15 -0
  137. jaclang/tests/fixtures/gendot_bubble_sort.jac +77 -0
  138. jaclang/tests/fixtures/guess_game.jac +47 -0
  139. jaclang/tests/fixtures/has_goodness.jac +15 -0
  140. jaclang/tests/fixtures/hashcheck.jac +12 -0
  141. jaclang/tests/fixtures/hashcheck_dup.jac +12 -0
  142. jaclang/tests/fixtures/hello.jac +5 -0
  143. jaclang/tests/fixtures/hello_nc.jac +5 -0
  144. jaclang/tests/fixtures/ignore.jac +43 -0
  145. jaclang/tests/fixtures/ignore_dup.jac +43 -0
  146. jaclang/tests/fixtures/impl_grab.impl.jac +4 -0
  147. jaclang/tests/fixtures/impl_grab.jac +2 -0
  148. jaclang/tests/fixtures/inherit_check.jac +33 -0
  149. jaclang/tests/fixtures/jacsamp.jac +6 -0
  150. jaclang/tests/fixtures/jp_importer.jac +17 -0
  151. jaclang/tests/fixtures/lambda.jac +6 -0
  152. jaclang/tests/fixtures/maxfail_run_test.jac +5 -0
  153. jaclang/tests/fixtures/mtest.impl.jac +6 -0
  154. jaclang/tests/fixtures/mtest.jac +6 -0
  155. jaclang/tests/fixtures/needs_import.jac +18 -0
  156. jaclang/tests/fixtures/needs_import_1.jac +6 -0
  157. jaclang/tests/fixtures/needs_import_2.jac +6 -0
  158. jaclang/tests/fixtures/needs_import_3.jac +6 -0
  159. jaclang/tests/fixtures/needs_import_dup.jac +18 -0
  160. jaclang/tests/fixtures/package_import.jac +6 -0
  161. jaclang/tests/fixtures/pyfunc.py +11 -0
  162. jaclang/tests/fixtures/pyfunc_1.py +311 -0
  163. jaclang/tests/fixtures/pyfunc_2.py +279 -0
  164. jaclang/tests/fixtures/pyfunc_3.py +310 -0
  165. jaclang/tests/fixtures/random_check.jac +62 -0
  166. jaclang/tests/fixtures/raw_byte_string.jac +18 -0
  167. jaclang/tests/fixtures/registry.jac +37 -0
  168. jaclang/tests/fixtures/run_test.jac +5 -0
  169. jaclang/tests/fixtures/semstr.jac +33 -0
  170. jaclang/tests/fixtures/simple_archs.jac +26 -0
  171. jaclang/tests/fixtures/slice_vals.jac +7 -0
  172. jaclang/tests/fixtures/sub_abil_sep.jac +15 -0
  173. jaclang/tests/fixtures/sub_abil_sep_multilev.jac +17 -0
  174. jaclang/tests/fixtures/try_finally.jac +34 -0
  175. jaclang/tests/fixtures/tupleunpack.jac +6 -0
  176. jaclang/tests/fixtures/tuplytuples.jac +8 -0
  177. jaclang/tests/fixtures/type_info.jac +15 -0
  178. jaclang/tests/fixtures/with_context.jac +30 -0
  179. jaclang/tests/fixtures/with_llm_function.jac +33 -0
  180. jaclang/tests/fixtures/with_llm_lower.jac +45 -0
  181. jaclang/tests/fixtures/with_llm_method.jac +51 -0
  182. jaclang/tests/fixtures/with_llm_type.jac +52 -0
  183. jaclang/tests/test_cli.py +239 -0
  184. jaclang/tests/test_language.py +831 -0
  185. jaclang/tests/test_man_code.py +148 -0
  186. jaclang/tests/test_reference.py +95 -0
  187. jaclang/tests/test_settings.py +46 -0
  188. jaclang/utils/helpers.py +11 -0
  189. jaclang/utils/tests/test_lang_tools.py +17 -0
  190. jaclang/utils/treeprinter.py +17 -4
  191. jaclang/vendor/__init__.py +12 -1
  192. jaclang/vendor/attr/__init__.py +134 -0
  193. jaclang/vendor/attr/__init__.pyi +555 -0
  194. jaclang/vendor/attr/_cmp.py +150 -0
  195. jaclang/vendor/attr/_cmp.pyi +13 -0
  196. jaclang/vendor/attr/_compat.py +87 -0
  197. jaclang/vendor/attr/_config.py +31 -0
  198. jaclang/vendor/attr/_funcs.py +483 -0
  199. jaclang/vendor/attr/_make.py +3119 -0
  200. jaclang/vendor/attr/_next_gen.py +229 -0
  201. jaclang/vendor/attr/_typing_compat.pyi +15 -0
  202. jaclang/vendor/attr/_version_info.py +86 -0
  203. jaclang/vendor/attr/_version_info.pyi +9 -0
  204. jaclang/vendor/attr/converters.py +144 -0
  205. jaclang/vendor/attr/converters.pyi +13 -0
  206. jaclang/vendor/attr/exceptions.py +95 -0
  207. jaclang/vendor/attr/exceptions.pyi +17 -0
  208. jaclang/vendor/attr/filters.py +66 -0
  209. jaclang/vendor/attr/filters.pyi +6 -0
  210. jaclang/vendor/attr/setters.py +73 -0
  211. jaclang/vendor/attr/setters.pyi +19 -0
  212. jaclang/vendor/attr/validators.py +681 -0
  213. jaclang/vendor/attr/validators.pyi +88 -0
  214. jaclang/vendor/attrs/__init__.py +65 -0
  215. jaclang/vendor/attrs/__init__.pyi +67 -0
  216. jaclang/vendor/attrs/converters.py +3 -0
  217. jaclang/vendor/attrs/exceptions.py +3 -0
  218. jaclang/vendor/attrs/filters.py +3 -0
  219. jaclang/vendor/attrs/py.typed +0 -0
  220. jaclang/vendor/attrs/setters.py +3 -0
  221. jaclang/vendor/attrs/validators.py +3 -0
  222. jaclang/vendor/attrs-23.2.0.dist-info/METADATA +202 -0
  223. jaclang/vendor/attrs-23.2.0.dist-info/RECORD +35 -0
  224. jaclang/vendor/attrs-23.2.0.dist-info/WHEEL +4 -0
  225. jaclang/vendor/attrs-23.2.0.dist-info/licenses/LICENSE +21 -0
  226. jaclang/vendor/cattr/__init__.py +25 -0
  227. jaclang/vendor/cattr/converters.py +8 -0
  228. jaclang/vendor/cattr/disambiguators.py +3 -0
  229. jaclang/vendor/cattr/dispatch.py +3 -0
  230. jaclang/vendor/cattr/errors.py +15 -0
  231. jaclang/vendor/cattr/gen.py +21 -0
  232. jaclang/vendor/cattr/preconf/__init__.py +3 -0
  233. jaclang/vendor/cattr/preconf/bson.py +4 -0
  234. jaclang/vendor/cattr/preconf/json.py +4 -0
  235. jaclang/vendor/cattr/preconf/msgpack.py +4 -0
  236. jaclang/vendor/cattr/preconf/orjson.py +4 -0
  237. jaclang/vendor/cattr/preconf/pyyaml.py +4 -0
  238. jaclang/vendor/cattr/preconf/tomlkit.py +4 -0
  239. jaclang/vendor/cattr/preconf/ujson.py +4 -0
  240. jaclang/vendor/cattr/py.typed +0 -0
  241. jaclang/vendor/cattrs/__init__.py +55 -0
  242. jaclang/vendor/cattrs/_compat.py +465 -0
  243. jaclang/vendor/cattrs/_generics.py +22 -0
  244. jaclang/vendor/cattrs/converters.py +1101 -0
  245. jaclang/vendor/cattrs/disambiguators.py +132 -0
  246. jaclang/vendor/cattrs/dispatch.py +164 -0
  247. jaclang/vendor/cattrs/errors.py +129 -0
  248. jaclang/vendor/cattrs/fns.py +17 -0
  249. jaclang/vendor/cattrs/gen/__init__.py +890 -0
  250. jaclang/vendor/cattrs/gen/_consts.py +19 -0
  251. jaclang/vendor/cattrs/gen/_generics.py +43 -0
  252. jaclang/vendor/cattrs/gen/_lc.py +28 -0
  253. jaclang/vendor/cattrs/gen/_shared.py +51 -0
  254. jaclang/vendor/cattrs/gen/typeddicts.py +624 -0
  255. jaclang/vendor/cattrs/preconf/__init__.py +7 -0
  256. jaclang/vendor/cattrs/preconf/bson.py +107 -0
  257. jaclang/vendor/cattrs/preconf/cbor2.py +47 -0
  258. jaclang/vendor/cattrs/preconf/json.py +52 -0
  259. jaclang/vendor/cattrs/preconf/msgpack.py +51 -0
  260. jaclang/vendor/cattrs/preconf/orjson.py +82 -0
  261. jaclang/vendor/cattrs/preconf/pyyaml.py +60 -0
  262. jaclang/vendor/cattrs/preconf/tomlkit.py +85 -0
  263. jaclang/vendor/cattrs/preconf/ujson.py +52 -0
  264. jaclang/vendor/cattrs/py.typed +0 -0
  265. jaclang/vendor/cattrs/strategies/__init__.py +11 -0
  266. jaclang/vendor/cattrs/strategies/_class_methods.py +64 -0
  267. jaclang/vendor/cattrs/strategies/_subclasses.py +224 -0
  268. jaclang/vendor/cattrs/strategies/_unions.py +235 -0
  269. jaclang/vendor/cattrs/v.py +111 -0
  270. jaclang/vendor/cattrs-23.2.3.dist-info/METADATA +221 -0
  271. jaclang/vendor/cattrs-23.2.3.dist-info/RECORD +48 -0
  272. jaclang/vendor/cattrs-23.2.3.dist-info/WHEEL +4 -0
  273. jaclang/vendor/cattrs-23.2.3.dist-info/licenses/LICENSE +11 -0
  274. jaclang/vendor/lark/__init__.py +38 -38
  275. jaclang/vendor/lark/__pyinstaller/__init__.py +6 -7
  276. jaclang/vendor/lark/__pyinstaller/hook-lark.py +14 -14
  277. jaclang/vendor/lark/ast_utils.py +59 -70
  278. jaclang/vendor/lark/common.py +89 -113
  279. jaclang/vendor/lark/exceptions.py +292 -352
  280. jaclang/vendor/lark/grammar.py +130 -158
  281. jaclang/vendor/lark/grammars/common.lark +59 -59
  282. jaclang/vendor/lark/grammars/lark.lark +62 -62
  283. jaclang/vendor/lark/grammars/python.lark +302 -302
  284. jaclang/vendor/lark/grammars/unicode.lark +7 -7
  285. jaclang/vendor/lark/indenter.py +112 -118
  286. jaclang/vendor/lark/lark.py +661 -800
  287. jaclang/vendor/lark/lexer.py +678 -829
  288. jaclang/vendor/lark/load_grammar.py +1428 -1673
  289. jaclang/vendor/lark/parse_tree_builder.py +391 -466
  290. jaclang/vendor/lark/parser_frontends.py +257 -305
  291. jaclang/vendor/lark/parsers/cyk.py +340 -391
  292. jaclang/vendor/lark/parsers/earley.py +308 -385
  293. jaclang/vendor/lark/parsers/earley_common.py +42 -59
  294. jaclang/vendor/lark/parsers/earley_forest.py +810 -923
  295. jaclang/vendor/lark/parsers/grammar_analysis.py +203 -239
  296. jaclang/vendor/lark/parsers/lalr_analysis.py +332 -378
  297. jaclang/vendor/lark/parsers/lalr_interactive_parser.py +157 -171
  298. jaclang/vendor/lark/parsers/lalr_parser.py +122 -145
  299. jaclang/vendor/lark/parsers/lalr_parser_state.py +110 -141
  300. jaclang/vendor/lark/parsers/xearley.py +165 -209
  301. jaclang/vendor/lark/reconstruct.py +107 -131
  302. jaclang/vendor/lark/tools/__init__.py +71 -93
  303. jaclang/vendor/lark/tools/nearley.py +202 -240
  304. jaclang/vendor/lark/tools/serialize.py +32 -35
  305. jaclang/vendor/lark/tools/standalone.py +196 -225
  306. jaclang/vendor/lark/tree.py +272 -302
  307. jaclang/vendor/lark/tree_matcher.py +186 -194
  308. jaclang/vendor/lark/tree_templates.py +18 -26
  309. jaclang/vendor/lark/utils.py +361 -393
  310. jaclang/vendor/lark/visitors.py +593 -645
  311. jaclang/vendor/lark-1.1.9.dist-info/LICENSE +18 -0
  312. jaclang/vendor/lark-1.1.9.dist-info/METADATA +47 -0
  313. jaclang/vendor/lark-1.1.9.dist-info/RECORD +46 -0
  314. jaclang/vendor/lark-1.1.9.dist-info/WHEEL +5 -0
  315. jaclang/vendor/lark-1.1.9.dist-info/entry_points.txt +2 -0
  316. jaclang/vendor/lark-1.1.9.dist-info/top_level.txt +1 -0
  317. jaclang/vendor/lsprotocol/__init__.py +2 -0
  318. jaclang/vendor/lsprotocol/_hooks.py +1237 -0
  319. jaclang/vendor/lsprotocol/converters.py +17 -0
  320. jaclang/vendor/lsprotocol/py.typed +0 -0
  321. jaclang/vendor/lsprotocol/types.py +12898 -0
  322. jaclang/vendor/lsprotocol/validators.py +47 -0
  323. jaclang/vendor/lsprotocol-2023.0.1.dist-info/LICENSE +21 -0
  324. jaclang/vendor/lsprotocol-2023.0.1.dist-info/METADATA +65 -0
  325. jaclang/vendor/lsprotocol-2023.0.1.dist-info/RECORD +10 -0
  326. jaclang/vendor/lsprotocol-2023.0.1.dist-info/WHEEL +4 -0
  327. jaclang/vendor/mypy/api.py +1 -3
  328. jaclang/vendor/mypy/applytype.py +24 -24
  329. jaclang/vendor/mypy/argmap.py +5 -9
  330. jaclang/vendor/mypy/binder.py +11 -42
  331. jaclang/vendor/mypy/build.py +78 -260
  332. jaclang/vendor/mypy/checker.py +394 -930
  333. jaclang/vendor/mypy/checkexpr.py +210 -640
  334. jaclang/vendor/mypy/checkmember.py +44 -94
  335. jaclang/vendor/mypy/checkpattern.py +32 -104
  336. jaclang/vendor/mypy/checkstrformat.py +38 -131
  337. jaclang/vendor/mypy/config_parser.py +8 -31
  338. jaclang/vendor/mypy/constant_fold.py +1 -3
  339. jaclang/vendor/mypy/constraints.py +94 -253
  340. jaclang/vendor/mypy/copytype.py +3 -13
  341. jaclang/vendor/mypy/defaults.py +2 -4
  342. jaclang/vendor/mypy/dmypy/client.py +30 -102
  343. jaclang/vendor/mypy/dmypy_server.py +31 -118
  344. jaclang/vendor/mypy/erasetype.py +6 -18
  345. jaclang/vendor/mypy/errorcodes.py +26 -64
  346. jaclang/vendor/mypy/errors.py +23 -117
  347. jaclang/vendor/mypy/evalexpr.py +1 -3
  348. jaclang/vendor/mypy/expandtype.py +37 -40
  349. jaclang/vendor/mypy/exprtotype.py +14 -27
  350. jaclang/vendor/mypy/fastparse.py +66 -215
  351. jaclang/vendor/mypy/find_sources.py +4 -14
  352. jaclang/vendor/mypy/fixup.py +5 -10
  353. jaclang/vendor/mypy/indirection.py +1 -3
  354. jaclang/vendor/mypy/infer.py +2 -6
  355. jaclang/vendor/mypy/inspections.py +3 -13
  356. jaclang/vendor/mypy/ipc.py +7 -28
  357. jaclang/vendor/mypy/join.py +20 -39
  358. jaclang/vendor/mypy/literals.py +2 -10
  359. jaclang/vendor/mypy/main.py +39 -138
  360. jaclang/vendor/mypy/maptype.py +2 -6
  361. jaclang/vendor/mypy/meet.py +23 -77
  362. jaclang/vendor/mypy/message_registry.py +33 -88
  363. jaclang/vendor/mypy/messages.py +146 -447
  364. jaclang/vendor/mypy/metastore.py +2 -6
  365. jaclang/vendor/mypy/modulefinder.py +29 -76
  366. jaclang/vendor/mypy/moduleinspect.py +5 -17
  367. jaclang/vendor/mypy/mro.py +1 -3
  368. jaclang/vendor/mypy/nodes.py +35 -119
  369. jaclang/vendor/mypy/operators.py +2 -11
  370. jaclang/vendor/mypy/options.py +3 -9
  371. jaclang/vendor/mypy/parse.py +1 -3
  372. jaclang/vendor/mypy/plugin.py +25 -75
  373. jaclang/vendor/mypy/plugins/attrs.py +53 -119
  374. jaclang/vendor/mypy/plugins/common.py +9 -29
  375. jaclang/vendor/mypy/plugins/ctypes.py +5 -15
  376. jaclang/vendor/mypy/plugins/dataclasses.py +42 -107
  377. jaclang/vendor/mypy/plugins/default.py +26 -45
  378. jaclang/vendor/mypy/plugins/enums.py +4 -17
  379. jaclang/vendor/mypy/plugins/functools.py +2 -11
  380. jaclang/vendor/mypy/plugins/proper_plugin.py +2 -6
  381. jaclang/vendor/mypy/plugins/singledispatch.py +7 -33
  382. jaclang/vendor/mypy/reachability.py +2 -8
  383. jaclang/vendor/mypy/refinfo.py +1 -3
  384. jaclang/vendor/mypy/report.py +23 -52
  385. jaclang/vendor/mypy/semanal.py +385 -693
  386. jaclang/vendor/mypy/semanal_classprop.py +9 -34
  387. jaclang/vendor/mypy/semanal_enum.py +7 -19
  388. jaclang/vendor/mypy/semanal_infer.py +1 -3
  389. jaclang/vendor/mypy/semanal_main.py +5 -25
  390. jaclang/vendor/mypy/semanal_namedtuple.py +17 -56
  391. jaclang/vendor/mypy/semanal_newtype.py +8 -27
  392. jaclang/vendor/mypy/semanal_pass1.py +2 -6
  393. jaclang/vendor/mypy/semanal_shared.py +9 -27
  394. jaclang/vendor/mypy/semanal_typeargs.py +12 -41
  395. jaclang/vendor/mypy/semanal_typeddict.py +18 -59
  396. jaclang/vendor/mypy/server/astdiff.py +9 -34
  397. jaclang/vendor/mypy/server/astmerge.py +2 -6
  398. jaclang/vendor/mypy/server/deps.py +22 -71
  399. jaclang/vendor/mypy/server/mergecheck.py +1 -3
  400. jaclang/vendor/mypy/server/objgraph.py +2 -8
  401. jaclang/vendor/mypy/server/update.py +18 -54
  402. jaclang/vendor/mypy/solve.py +4 -17
  403. jaclang/vendor/mypy/split_namespace.py +1 -3
  404. jaclang/vendor/mypy/stats.py +6 -24
  405. jaclang/vendor/mypy/strconv.py +8 -31
  406. jaclang/vendor/mypy/stubdoc.py +8 -38
  407. jaclang/vendor/mypy/stubgen.py +79 -144
  408. jaclang/vendor/mypy/stubgenc.py +22 -69
  409. jaclang/vendor/mypy/stubtest.py +62 -167
  410. jaclang/vendor/mypy/stubutil.py +45 -61
  411. jaclang/vendor/mypy/subtypes.py +57 -133
  412. jaclang/vendor/mypy/suggestions.py +19 -53
  413. jaclang/vendor/mypy/test/data.py +13 -40
  414. jaclang/vendor/mypy/test/helpers.py +18 -43
  415. jaclang/vendor/mypy/test/meta/_pytest.py +2 -13
  416. jaclang/vendor/mypy/test/meta/test_parse_data.py +5 -9
  417. jaclang/vendor/mypy/test/meta/test_update_data.py +1 -3
  418. jaclang/vendor/mypy/test/test_find_sources.py +14 -32
  419. jaclang/vendor/mypy/test/test_ref_info.py +3 -9
  420. jaclang/vendor/mypy/test/testargs.py +1 -4
  421. jaclang/vendor/mypy/test/testcheck.py +14 -47
  422. jaclang/vendor/mypy/test/testcmdline.py +3 -14
  423. jaclang/vendor/mypy/test/testconstraints.py +8 -26
  424. jaclang/vendor/mypy/test/testdaemon.py +2 -9
  425. jaclang/vendor/mypy/test/testdeps.py +4 -12
  426. jaclang/vendor/mypy/test/testdiff.py +2 -6
  427. jaclang/vendor/mypy/test/testerrorstream.py +1 -3
  428. jaclang/vendor/mypy/test/testfinegrained.py +18 -56
  429. jaclang/vendor/mypy/test/testgraph.py +3 -18
  430. jaclang/vendor/mypy/test/testinfer.py +13 -55
  431. jaclang/vendor/mypy/test/testipc.py +3 -9
  432. jaclang/vendor/mypy/test/testmerge.py +5 -17
  433. jaclang/vendor/mypy/test/testmodulefinder.py +8 -30
  434. jaclang/vendor/mypy/test/testmypyc.py +1 -3
  435. jaclang/vendor/mypy/test/testparse.py +1 -3
  436. jaclang/vendor/mypy/test/testpep561.py +4 -13
  437. jaclang/vendor/mypy/test/testpythoneval.py +2 -6
  438. jaclang/vendor/mypy/test/testreports.py +1 -2
  439. jaclang/vendor/mypy/test/testsemanal.py +3 -10
  440. jaclang/vendor/mypy/test/testsolve.py +5 -15
  441. jaclang/vendor/mypy/test/teststubgen.py +69 -210
  442. jaclang/vendor/mypy/test/teststubtest.py +123 -163
  443. jaclang/vendor/mypy/test/testsubtypes.py +14 -34
  444. jaclang/vendor/mypy/test/testtransform.py +2 -8
  445. jaclang/vendor/mypy/test/testtypegen.py +2 -8
  446. jaclang/vendor/mypy/test/testtypes.py +77 -253
  447. jaclang/vendor/mypy/test/testutil.py +1 -3
  448. jaclang/vendor/mypy/test/typefixture.py +11 -38
  449. jaclang/vendor/mypy/test/update_data.py +4 -15
  450. jaclang/vendor/mypy/test/visitors.py +1 -9
  451. jaclang/vendor/mypy/treetransform.py +8 -25
  452. jaclang/vendor/mypy/tvar_scope.py +23 -3
  453. jaclang/vendor/mypy/type_visitor.py +3 -10
  454. jaclang/vendor/mypy/typeanal.py +183 -309
  455. jaclang/vendor/mypy/typeops.py +27 -73
  456. jaclang/vendor/mypy/types.py +77 -185
  457. jaclang/vendor/mypy/types_utils.py +7 -20
  458. jaclang/vendor/mypy/typeshed/LICENSE +237 -0
  459. jaclang/vendor/mypy/typeshed/stdlib/VERSIONS +309 -0
  460. jaclang/vendor/mypy/typeshed/stdlib/__future__.pyi +36 -0
  461. jaclang/vendor/mypy/typeshed/stdlib/__main__.pyi +3 -0
  462. jaclang/vendor/mypy/typeshed/stdlib/_ast.pyi +591 -0
  463. jaclang/vendor/mypy/typeshed/stdlib/_bisect.pyi +84 -0
  464. jaclang/vendor/mypy/typeshed/stdlib/_bootlocale.pyi +1 -0
  465. jaclang/vendor/mypy/typeshed/stdlib/_codecs.pyi +133 -0
  466. jaclang/vendor/mypy/typeshed/stdlib/_collections_abc.pyi +94 -0
  467. jaclang/vendor/mypy/typeshed/stdlib/_compat_pickle.pyi +8 -0
  468. jaclang/vendor/mypy/typeshed/stdlib/_compression.pyi +25 -0
  469. jaclang/vendor/mypy/typeshed/stdlib/_csv.pyi +90 -0
  470. jaclang/vendor/mypy/typeshed/stdlib/_ctypes.pyi +207 -0
  471. jaclang/vendor/mypy/typeshed/stdlib/_curses.pyi +566 -0
  472. jaclang/vendor/mypy/typeshed/stdlib/_decimal.pyi +281 -0
  473. jaclang/vendor/mypy/typeshed/stdlib/_dummy_thread.pyi +33 -0
  474. jaclang/vendor/mypy/typeshed/stdlib/_dummy_threading.pyi +164 -0
  475. jaclang/vendor/mypy/typeshed/stdlib/_heapq.pyi +11 -0
  476. jaclang/vendor/mypy/typeshed/stdlib/_imp.pyi +28 -0
  477. jaclang/vendor/mypy/typeshed/stdlib/_json.pyi +49 -0
  478. jaclang/vendor/mypy/typeshed/stdlib/_locale.pyi +100 -0
  479. jaclang/vendor/mypy/typeshed/stdlib/_lsprof.pyi +35 -0
  480. jaclang/vendor/mypy/typeshed/stdlib/_markupbase.pyi +16 -0
  481. jaclang/vendor/mypy/typeshed/stdlib/_msi.pyi +92 -0
  482. jaclang/vendor/mypy/typeshed/stdlib/_operator.pyi +147 -0
  483. jaclang/vendor/mypy/typeshed/stdlib/_osx_support.pyi +34 -0
  484. jaclang/vendor/mypy/typeshed/stdlib/_posixsubprocess.pyi +33 -0
  485. jaclang/vendor/mypy/typeshed/stdlib/_py_abc.pyi +14 -0
  486. jaclang/vendor/mypy/typeshed/stdlib/_pydecimal.pyi +43 -0
  487. jaclang/vendor/mypy/typeshed/stdlib/_random.pyi +12 -0
  488. jaclang/vendor/mypy/typeshed/stdlib/_sitebuiltins.pyi +16 -0
  489. jaclang/vendor/mypy/typeshed/stdlib/_socket.pyi +803 -0
  490. jaclang/vendor/mypy/typeshed/stdlib/_stat.pyi +103 -0
  491. jaclang/vendor/mypy/typeshed/stdlib/_thread.pyi +59 -0
  492. jaclang/vendor/mypy/typeshed/stdlib/_threading_local.pyi +17 -0
  493. jaclang/vendor/mypy/typeshed/stdlib/_tkinter.pyi +121 -0
  494. jaclang/vendor/mypy/typeshed/stdlib/_tracemalloc.pyi +17 -0
  495. jaclang/vendor/mypy/typeshed/stdlib/_typeshed/__init__.pyi +347 -0
  496. jaclang/vendor/mypy/typeshed/stdlib/_typeshed/dbapi.pyi +37 -0
  497. jaclang/vendor/mypy/typeshed/stdlib/_typeshed/wsgi.pyi +44 -0
  498. jaclang/vendor/mypy/typeshed/stdlib/_typeshed/xml.pyi +9 -0
  499. jaclang/vendor/mypy/typeshed/stdlib/_warnings.pyi +55 -0
  500. jaclang/vendor/mypy/typeshed/stdlib/_weakref.pyi +41 -0
  501. jaclang/vendor/mypy/typeshed/stdlib/_weakrefset.pyi +51 -0
  502. jaclang/vendor/mypy/typeshed/stdlib/_winapi.pyi +255 -0
  503. jaclang/vendor/mypy/typeshed/stdlib/abc.pyi +51 -0
  504. jaclang/vendor/mypy/typeshed/stdlib/aifc.pyi +91 -0
  505. jaclang/vendor/mypy/typeshed/stdlib/antigravity.pyi +3 -0
  506. jaclang/vendor/mypy/typeshed/stdlib/argparse.pyi +595 -0
  507. jaclang/vendor/mypy/typeshed/stdlib/array.pyi +92 -0
  508. jaclang/vendor/mypy/typeshed/stdlib/ast.pyi +277 -0
  509. jaclang/vendor/mypy/typeshed/stdlib/asynchat.pyi +21 -0
  510. jaclang/vendor/mypy/typeshed/stdlib/asyncio/__init__.pyi +41 -0
  511. jaclang/vendor/mypy/typeshed/stdlib/asyncio/base_events.pyi +440 -0
  512. jaclang/vendor/mypy/typeshed/stdlib/asyncio/base_futures.pyi +19 -0
  513. jaclang/vendor/mypy/typeshed/stdlib/asyncio/base_subprocess.pyi +63 -0
  514. jaclang/vendor/mypy/typeshed/stdlib/asyncio/base_tasks.pyi +9 -0
  515. jaclang/vendor/mypy/typeshed/stdlib/asyncio/constants.pyi +20 -0
  516. jaclang/vendor/mypy/typeshed/stdlib/asyncio/coroutines.pyi +26 -0
  517. jaclang/vendor/mypy/typeshed/stdlib/asyncio/events.pyi +580 -0
  518. jaclang/vendor/mypy/typeshed/stdlib/asyncio/exceptions.pyi +43 -0
  519. jaclang/vendor/mypy/typeshed/stdlib/asyncio/format_helpers.pyi +20 -0
  520. jaclang/vendor/mypy/typeshed/stdlib/asyncio/futures.pyi +57 -0
  521. jaclang/vendor/mypy/typeshed/stdlib/asyncio/locks.pyi +121 -0
  522. jaclang/vendor/mypy/typeshed/stdlib/asyncio/log.pyi +3 -0
  523. jaclang/vendor/mypy/typeshed/stdlib/asyncio/mixins.pyi +9 -0
  524. jaclang/vendor/mypy/typeshed/stdlib/asyncio/proactor_events.pyi +64 -0
  525. jaclang/vendor/mypy/typeshed/stdlib/asyncio/protocols.pyi +34 -0
  526. jaclang/vendor/mypy/typeshed/stdlib/asyncio/queues.pyi +47 -0
  527. jaclang/vendor/mypy/typeshed/stdlib/asyncio/runners.pyi +32 -0
  528. jaclang/vendor/mypy/typeshed/stdlib/asyncio/selector_events.pyi +8 -0
  529. jaclang/vendor/mypy/typeshed/stdlib/asyncio/sslproto.pyi +165 -0
  530. jaclang/vendor/mypy/typeshed/stdlib/asyncio/staggered.pyi +10 -0
  531. jaclang/vendor/mypy/typeshed/stdlib/asyncio/streams.pyi +153 -0
  532. jaclang/vendor/mypy/typeshed/stdlib/asyncio/subprocess.pyi +229 -0
  533. jaclang/vendor/mypy/typeshed/stdlib/asyncio/taskgroups.pyi +25 -0
  534. jaclang/vendor/mypy/typeshed/stdlib/asyncio/tasks.pyi +497 -0
  535. jaclang/vendor/mypy/typeshed/stdlib/asyncio/threads.pyi +9 -0
  536. jaclang/vendor/mypy/typeshed/stdlib/asyncio/timeouts.pyi +19 -0
  537. jaclang/vendor/mypy/typeshed/stdlib/asyncio/transports.pyi +47 -0
  538. jaclang/vendor/mypy/typeshed/stdlib/asyncio/trsock.pyi +94 -0
  539. jaclang/vendor/mypy/typeshed/stdlib/asyncio/unix_events.pyi +196 -0
  540. jaclang/vendor/mypy/typeshed/stdlib/asyncio/windows_events.pyi +85 -0
  541. jaclang/vendor/mypy/typeshed/stdlib/asyncio/windows_utils.pyi +49 -0
  542. jaclang/vendor/mypy/typeshed/stdlib/asyncore.pyi +90 -0
  543. jaclang/vendor/mypy/typeshed/stdlib/atexit.pyi +12 -0
  544. jaclang/vendor/mypy/typeshed/stdlib/audioop.pyi +43 -0
  545. jaclang/vendor/mypy/typeshed/stdlib/base64.pyi +59 -0
  546. jaclang/vendor/mypy/typeshed/stdlib/bdb.pyi +102 -0
  547. jaclang/vendor/mypy/typeshed/stdlib/binascii.pyi +36 -0
  548. jaclang/vendor/mypy/typeshed/stdlib/binhex.pyi +45 -0
  549. jaclang/vendor/mypy/typeshed/stdlib/bisect.pyi +4 -0
  550. jaclang/vendor/mypy/typeshed/stdlib/builtins.pyi +1936 -0
  551. jaclang/vendor/mypy/typeshed/stdlib/bz2.pyi +146 -0
  552. jaclang/vendor/mypy/typeshed/stdlib/cProfile.pyi +31 -0
  553. jaclang/vendor/mypy/typeshed/stdlib/calendar.pyi +208 -0
  554. jaclang/vendor/mypy/typeshed/stdlib/cgi.pyi +118 -0
  555. jaclang/vendor/mypy/typeshed/stdlib/cgitb.pyi +32 -0
  556. jaclang/vendor/mypy/typeshed/stdlib/chunk.pyi +20 -0
  557. jaclang/vendor/mypy/typeshed/stdlib/cmath.pyi +36 -0
  558. jaclang/vendor/mypy/typeshed/stdlib/cmd.pyi +45 -0
  559. jaclang/vendor/mypy/typeshed/stdlib/code.pyi +33 -0
  560. jaclang/vendor/mypy/typeshed/stdlib/codecs.pyi +285 -0
  561. jaclang/vendor/mypy/typeshed/stdlib/codeop.pyi +13 -0
  562. jaclang/vendor/mypy/typeshed/stdlib/collections/__init__.pyi +485 -0
  563. jaclang/vendor/mypy/typeshed/stdlib/collections/abc.pyi +2 -0
  564. jaclang/vendor/mypy/typeshed/stdlib/colorsys.pyi +13 -0
  565. jaclang/vendor/mypy/typeshed/stdlib/compileall.pyi +111 -0
  566. jaclang/vendor/mypy/typeshed/stdlib/concurrent/__init__.pyi +0 -0
  567. jaclang/vendor/mypy/typeshed/stdlib/concurrent/futures/__init__.pyi +32 -0
  568. jaclang/vendor/mypy/typeshed/stdlib/concurrent/futures/_base.pyi +126 -0
  569. jaclang/vendor/mypy/typeshed/stdlib/concurrent/futures/process.pyi +233 -0
  570. jaclang/vendor/mypy/typeshed/stdlib/concurrent/futures/thread.pyi +80 -0
  571. jaclang/vendor/mypy/typeshed/stdlib/configparser.pyi +313 -0
  572. jaclang/vendor/mypy/typeshed/stdlib/contextlib.pyi +208 -0
  573. jaclang/vendor/mypy/typeshed/stdlib/contextvars.pyi +63 -0
  574. jaclang/vendor/mypy/typeshed/stdlib/copy.pyi +16 -0
  575. jaclang/vendor/mypy/typeshed/stdlib/copyreg.pyi +21 -0
  576. jaclang/vendor/mypy/typeshed/stdlib/crypt.pyi +12 -0
  577. jaclang/vendor/mypy/typeshed/stdlib/csv.pyi +147 -0
  578. jaclang/vendor/mypy/typeshed/stdlib/ctypes/__init__.pyi +187 -0
  579. jaclang/vendor/mypy/typeshed/stdlib/ctypes/_endian.pyi +19 -0
  580. jaclang/vendor/mypy/typeshed/stdlib/ctypes/util.pyi +6 -0
  581. jaclang/vendor/mypy/typeshed/stdlib/ctypes/wintypes.pyi +298 -0
  582. jaclang/vendor/mypy/typeshed/stdlib/curses/__init__.pyi +22 -0
  583. jaclang/vendor/mypy/typeshed/stdlib/curses/ascii.pyi +62 -0
  584. jaclang/vendor/mypy/typeshed/stdlib/curses/has_key.pyi +1 -0
  585. jaclang/vendor/mypy/typeshed/stdlib/curses/panel.pyi +22 -0
  586. jaclang/vendor/mypy/typeshed/stdlib/curses/textpad.pyi +11 -0
  587. jaclang/vendor/mypy/typeshed/stdlib/dataclasses.pyi +315 -0
  588. jaclang/vendor/mypy/typeshed/stdlib/datetime.pyi +295 -0
  589. jaclang/vendor/mypy/typeshed/stdlib/dbm/__init__.pyi +95 -0
  590. jaclang/vendor/mypy/typeshed/stdlib/dbm/dumb.pyi +31 -0
  591. jaclang/vendor/mypy/typeshed/stdlib/dbm/gnu.pyi +41 -0
  592. jaclang/vendor/mypy/typeshed/stdlib/dbm/ndbm.pyi +37 -0
  593. jaclang/vendor/mypy/typeshed/stdlib/decimal.pyi +2 -0
  594. jaclang/vendor/mypy/typeshed/stdlib/difflib.pyi +140 -0
  595. jaclang/vendor/mypy/typeshed/stdlib/dis.pyi +144 -0
  596. jaclang/vendor/mypy/typeshed/stdlib/distutils/__init__.pyi +5 -0
  597. jaclang/vendor/mypy/typeshed/stdlib/distutils/archive_util.pyi +20 -0
  598. jaclang/vendor/mypy/typeshed/stdlib/distutils/bcppcompiler.pyi +3 -0
  599. jaclang/vendor/mypy/typeshed/stdlib/distutils/ccompiler.pyi +152 -0
  600. jaclang/vendor/mypy/typeshed/stdlib/distutils/cmd.pyi +66 -0
  601. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/__init__.pyi +0 -0
  602. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/bdist.pyi +25 -0
  603. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/bdist_dumb.pyi +21 -0
  604. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/bdist_msi.pyi +45 -0
  605. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/bdist_packager.pyi +0 -0
  606. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/bdist_rpm.pyi +52 -0
  607. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/bdist_wininst.pyi +16 -0
  608. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/build.pyi +31 -0
  609. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/build_clib.pyi +27 -0
  610. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/build_ext.pyi +50 -0
  611. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/build_py.pyi +44 -0
  612. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/build_scripts.pyi +24 -0
  613. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/check.pyi +39 -0
  614. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/clean.pyi +17 -0
  615. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/config.pyi +83 -0
  616. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/install.pyi +63 -0
  617. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/install_data.pyi +19 -0
  618. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/install_egg_info.pyi +18 -0
  619. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/install_headers.pyi +16 -0
  620. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/install_lib.pyi +25 -0
  621. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/install_scripts.pyi +18 -0
  622. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/register.pyi +18 -0
  623. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/sdist.pyi +42 -0
  624. jaclang/vendor/mypy/typeshed/stdlib/distutils/command/upload.pyi +17 -0
  625. jaclang/vendor/mypy/typeshed/stdlib/distutils/config.pyi +17 -0
  626. jaclang/vendor/mypy/typeshed/stdlib/distutils/core.pyi +57 -0
  627. jaclang/vendor/mypy/typeshed/stdlib/distutils/cygwinccompiler.pyi +20 -0
  628. jaclang/vendor/mypy/typeshed/stdlib/distutils/debug.pyi +1 -0
  629. jaclang/vendor/mypy/typeshed/stdlib/distutils/dep_util.pyi +3 -0
  630. jaclang/vendor/mypy/typeshed/stdlib/distutils/dir_util.pyi +13 -0
  631. jaclang/vendor/mypy/typeshed/stdlib/distutils/dist.pyi +146 -0
  632. jaclang/vendor/mypy/typeshed/stdlib/distutils/errors.pyi +19 -0
  633. jaclang/vendor/mypy/typeshed/stdlib/distutils/extension.pyi +36 -0
  634. jaclang/vendor/mypy/typeshed/stdlib/distutils/fancy_getopt.pyi +34 -0
  635. jaclang/vendor/mypy/typeshed/stdlib/distutils/file_util.pyi +14 -0
  636. jaclang/vendor/mypy/typeshed/stdlib/distutils/filelist.pyi +50 -0
  637. jaclang/vendor/mypy/typeshed/stdlib/distutils/log.pyi +25 -0
  638. jaclang/vendor/mypy/typeshed/stdlib/distutils/msvccompiler.pyi +3 -0
  639. jaclang/vendor/mypy/typeshed/stdlib/distutils/spawn.pyi +2 -0
  640. jaclang/vendor/mypy/typeshed/stdlib/distutils/sysconfig.pyi +31 -0
  641. jaclang/vendor/mypy/typeshed/stdlib/distutils/text_file.pyi +21 -0
  642. jaclang/vendor/mypy/typeshed/stdlib/distutils/unixccompiler.pyi +3 -0
  643. jaclang/vendor/mypy/typeshed/stdlib/distutils/util.pyi +46 -0
  644. jaclang/vendor/mypy/typeshed/stdlib/distutils/version.pyi +36 -0
  645. jaclang/vendor/mypy/typeshed/stdlib/doctest.pyi +248 -0
  646. jaclang/vendor/mypy/typeshed/stdlib/dummy_threading.pyi +2 -0
  647. jaclang/vendor/mypy/typeshed/stdlib/email/__init__.pyi +29 -0
  648. jaclang/vendor/mypy/typeshed/stdlib/email/_header_value_parser.pyi +392 -0
  649. jaclang/vendor/mypy/typeshed/stdlib/email/_policybase.pyi +51 -0
  650. jaclang/vendor/mypy/typeshed/stdlib/email/base64mime.pyi +13 -0
  651. jaclang/vendor/mypy/typeshed/stdlib/email/charset.pyi +34 -0
  652. jaclang/vendor/mypy/typeshed/stdlib/email/contentmanager.pyi +11 -0
  653. jaclang/vendor/mypy/typeshed/stdlib/email/encoders.pyi +8 -0
  654. jaclang/vendor/mypy/typeshed/stdlib/email/errors.pyi +39 -0
  655. jaclang/vendor/mypy/typeshed/stdlib/email/feedparser.pyi +23 -0
  656. jaclang/vendor/mypy/typeshed/stdlib/email/generator.pyi +40 -0
  657. jaclang/vendor/mypy/typeshed/stdlib/email/header.pyi +31 -0
  658. jaclang/vendor/mypy/typeshed/stdlib/email/headerregistry.pyi +178 -0
  659. jaclang/vendor/mypy/typeshed/stdlib/email/iterators.pyi +12 -0
  660. jaclang/vendor/mypy/typeshed/stdlib/email/message.pyi +165 -0
  661. jaclang/vendor/mypy/typeshed/stdlib/email/mime/__init__.pyi +0 -0
  662. jaclang/vendor/mypy/typeshed/stdlib/email/mime/application.pyi +17 -0
  663. jaclang/vendor/mypy/typeshed/stdlib/email/mime/audio.pyi +17 -0
  664. jaclang/vendor/mypy/typeshed/stdlib/email/mime/base.pyi +8 -0
  665. jaclang/vendor/mypy/typeshed/stdlib/email/mime/image.pyi +17 -0
  666. jaclang/vendor/mypy/typeshed/stdlib/email/mime/message.pyi +8 -0
  667. jaclang/vendor/mypy/typeshed/stdlib/email/mime/multipart.pyi +18 -0
  668. jaclang/vendor/mypy/typeshed/stdlib/email/mime/nonmultipart.pyi +5 -0
  669. jaclang/vendor/mypy/typeshed/stdlib/email/mime/text.pyi +9 -0
  670. jaclang/vendor/mypy/typeshed/stdlib/email/parser.pyi +26 -0
  671. jaclang/vendor/mypy/typeshed/stdlib/email/policy.pyi +38 -0
  672. jaclang/vendor/mypy/typeshed/stdlib/email/quoprimime.pyi +28 -0
  673. jaclang/vendor/mypy/typeshed/stdlib/email/utils.pyi +70 -0
  674. jaclang/vendor/mypy/typeshed/stdlib/encodings/__init__.pyi +10 -0
  675. jaclang/vendor/mypy/typeshed/stdlib/encodings/utf_8.pyi +21 -0
  676. jaclang/vendor/mypy/typeshed/stdlib/encodings/utf_8_sig.pyi +22 -0
  677. jaclang/vendor/mypy/typeshed/stdlib/ensurepip/__init__.pyi +12 -0
  678. jaclang/vendor/mypy/typeshed/stdlib/enum.pyi +320 -0
  679. jaclang/vendor/mypy/typeshed/stdlib/errno.pyi +222 -0
  680. jaclang/vendor/mypy/typeshed/stdlib/faulthandler.pyi +13 -0
  681. jaclang/vendor/mypy/typeshed/stdlib/fcntl.pyi +127 -0
  682. jaclang/vendor/mypy/typeshed/stdlib/filecmp.pyi +57 -0
  683. jaclang/vendor/mypy/typeshed/stdlib/fileinput.pyi +213 -0
  684. jaclang/vendor/mypy/typeshed/stdlib/fnmatch.pyi +9 -0
  685. jaclang/vendor/mypy/typeshed/stdlib/formatter.pyi +88 -0
  686. jaclang/vendor/mypy/typeshed/stdlib/fractions.pyi +150 -0
  687. jaclang/vendor/mypy/typeshed/stdlib/ftplib.pyi +178 -0
  688. jaclang/vendor/mypy/typeshed/stdlib/functools.pyi +213 -0
  689. jaclang/vendor/mypy/typeshed/stdlib/gc.pyi +37 -0
  690. jaclang/vendor/mypy/typeshed/stdlib/genericpath.pyi +52 -0
  691. jaclang/vendor/mypy/typeshed/stdlib/getopt.pyi +11 -0
  692. jaclang/vendor/mypy/typeshed/stdlib/getpass.pyi +8 -0
  693. jaclang/vendor/mypy/typeshed/stdlib/gettext.pyi +169 -0
  694. jaclang/vendor/mypy/typeshed/stdlib/glob.pyi +42 -0
  695. jaclang/vendor/mypy/typeshed/stdlib/graphlib.pyi +28 -0
  696. jaclang/vendor/mypy/typeshed/stdlib/grp.pyi +22 -0
  697. jaclang/vendor/mypy/typeshed/stdlib/gzip.pyi +160 -0
  698. jaclang/vendor/mypy/typeshed/stdlib/hashlib.pyi +167 -0
  699. jaclang/vendor/mypy/typeshed/stdlib/heapq.pyi +17 -0
  700. jaclang/vendor/mypy/typeshed/stdlib/hmac.pyi +38 -0
  701. jaclang/vendor/mypy/typeshed/stdlib/html/__init__.pyi +6 -0
  702. jaclang/vendor/mypy/typeshed/stdlib/html/entities.pyi +6 -0
  703. jaclang/vendor/mypy/typeshed/stdlib/html/parser.pyi +34 -0
  704. jaclang/vendor/mypy/typeshed/stdlib/http/__init__.pyi +105 -0
  705. jaclang/vendor/mypy/typeshed/stdlib/http/client.pyi +259 -0
  706. jaclang/vendor/mypy/typeshed/stdlib/http/cookiejar.pyi +159 -0
  707. jaclang/vendor/mypy/typeshed/stdlib/http/cookies.pyi +60 -0
  708. jaclang/vendor/mypy/typeshed/stdlib/http/server.pyi +83 -0
  709. jaclang/vendor/mypy/typeshed/stdlib/imaplib.pyi +168 -0
  710. jaclang/vendor/mypy/typeshed/stdlib/imghdr.pyi +17 -0
  711. jaclang/vendor/mypy/typeshed/stdlib/imp.pyi +62 -0
  712. jaclang/vendor/mypy/typeshed/stdlib/importlib/__init__.pyi +24 -0
  713. jaclang/vendor/mypy/typeshed/stdlib/importlib/_abc.pyi +15 -0
  714. jaclang/vendor/mypy/typeshed/stdlib/importlib/abc.pyi +172 -0
  715. jaclang/vendor/mypy/typeshed/stdlib/importlib/machinery.pyi +179 -0
  716. jaclang/vendor/mypy/typeshed/stdlib/importlib/metadata/__init__.pyi +285 -0
  717. jaclang/vendor/mypy/typeshed/stdlib/importlib/metadata/_meta.pyi +49 -0
  718. jaclang/vendor/mypy/typeshed/stdlib/importlib/readers.pyi +68 -0
  719. jaclang/vendor/mypy/typeshed/stdlib/importlib/resources/__init__.pyi +46 -0
  720. jaclang/vendor/mypy/typeshed/stdlib/importlib/resources/abc.pyi +12 -0
  721. jaclang/vendor/mypy/typeshed/stdlib/importlib/resources/readers.pyi +14 -0
  722. jaclang/vendor/mypy/typeshed/stdlib/importlib/resources/simple.pyi +56 -0
  723. jaclang/vendor/mypy/typeshed/stdlib/importlib/simple.pyi +11 -0
  724. jaclang/vendor/mypy/typeshed/stdlib/importlib/util.pyi +43 -0
  725. jaclang/vendor/mypy/typeshed/stdlib/inspect.pyi +632 -0
  726. jaclang/vendor/mypy/typeshed/stdlib/io.pyi +238 -0
  727. jaclang/vendor/mypy/typeshed/stdlib/ipaddress.pyi +208 -0
  728. jaclang/vendor/mypy/typeshed/stdlib/itertools.pyi +273 -0
  729. jaclang/vendor/mypy/typeshed/stdlib/json/__init__.pyi +61 -0
  730. jaclang/vendor/mypy/typeshed/stdlib/json/decoder.pyi +32 -0
  731. jaclang/vendor/mypy/typeshed/stdlib/json/encoder.pyi +40 -0
  732. jaclang/vendor/mypy/typeshed/stdlib/json/tool.pyi +1 -0
  733. jaclang/vendor/mypy/typeshed/stdlib/keyword.pyi +21 -0
  734. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/__init__.pyi +0 -0
  735. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/btm_matcher.pyi +28 -0
  736. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixer_base.pyi +42 -0
  737. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/__init__.pyi +0 -0
  738. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_apply.pyi +8 -0
  739. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_asserts.pyi +10 -0
  740. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_basestring.pyi +8 -0
  741. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_buffer.pyi +8 -0
  742. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_dict.pyi +16 -0
  743. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_except.pyi +14 -0
  744. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_exec.pyi +8 -0
  745. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_execfile.pyi +8 -0
  746. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_exitfunc.pyi +13 -0
  747. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_filter.pyi +9 -0
  748. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_funcattrs.pyi +8 -0
  749. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_future.pyi +8 -0
  750. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_getcwdu.pyi +8 -0
  751. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_has_key.pyi +8 -0
  752. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_idioms.pyi +15 -0
  753. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_import.pyi +16 -0
  754. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_imports.pyi +21 -0
  755. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_imports2.pyi +6 -0
  756. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_input.pyi +11 -0
  757. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_intern.pyi +9 -0
  758. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_isinstance.pyi +8 -0
  759. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_itertools.pyi +9 -0
  760. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_itertools_imports.pyi +7 -0
  761. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_long.pyi +7 -0
  762. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_map.pyi +9 -0
  763. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_metaclass.pyi +17 -0
  764. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_methodattrs.pyi +10 -0
  765. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_ne.pyi +8 -0
  766. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_next.pyi +19 -0
  767. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_nonzero.pyi +8 -0
  768. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_numliterals.pyi +8 -0
  769. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_operator.pyi +12 -0
  770. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_paren.pyi +8 -0
  771. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_print.pyi +12 -0
  772. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_raise.pyi +8 -0
  773. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_raw_input.pyi +8 -0
  774. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_reduce.pyi +8 -0
  775. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_reload.pyi +9 -0
  776. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_renames.pyi +17 -0
  777. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_repr.pyi +8 -0
  778. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_set_literal.pyi +7 -0
  779. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_standarderror.pyi +8 -0
  780. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_sys_exc.pyi +9 -0
  781. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_throw.pyi +8 -0
  782. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_tuple_params.pyi +17 -0
  783. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_types.pyi +8 -0
  784. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_unicode.pyi +12 -0
  785. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_urllib.pyi +15 -0
  786. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_ws_comma.pyi +12 -0
  787. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_xrange.pyi +20 -0
  788. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_xreadlines.pyi +8 -0
  789. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/fixes/fix_zip.pyi +9 -0
  790. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/main.pyi +42 -0
  791. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/pgen2/__init__.pyi +9 -0
  792. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/pgen2/driver.pyi +27 -0
  793. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/pgen2/grammar.pyi +24 -0
  794. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/pgen2/literals.pyi +7 -0
  795. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/pgen2/parse.pyi +30 -0
  796. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/pgen2/pgen.pyi +50 -0
  797. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/pgen2/token.pyi +67 -0
  798. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/pgen2/tokenize.pyi +96 -0
  799. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/pygram.pyi +114 -0
  800. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/pytree.pyi +117 -0
  801. jaclang/vendor/mypy/typeshed/stdlib/lib2to3/refactor.pyi +82 -0
  802. jaclang/vendor/mypy/typeshed/stdlib/linecache.pyi +23 -0
  803. jaclang/vendor/mypy/typeshed/stdlib/locale.pyi +152 -0
  804. jaclang/vendor/mypy/typeshed/stdlib/logging/__init__.pyi +658 -0
  805. jaclang/vendor/mypy/typeshed/stdlib/logging/config.pyi +134 -0
  806. jaclang/vendor/mypy/typeshed/stdlib/logging/handlers.pyi +275 -0
  807. jaclang/vendor/mypy/typeshed/stdlib/lzma.pyi +197 -0
  808. jaclang/vendor/mypy/typeshed/stdlib/mailbox.pyi +256 -0
  809. jaclang/vendor/mypy/typeshed/stdlib/mailcap.pyi +11 -0
  810. jaclang/vendor/mypy/typeshed/stdlib/marshal.pyi +33 -0
  811. jaclang/vendor/mypy/typeshed/stdlib/math.pyi +125 -0
  812. jaclang/vendor/mypy/typeshed/stdlib/mimetypes.pyi +46 -0
  813. jaclang/vendor/mypy/typeshed/stdlib/mmap.pyi +113 -0
  814. jaclang/vendor/mypy/typeshed/stdlib/modulefinder.pyi +66 -0
  815. jaclang/vendor/mypy/typeshed/stdlib/msilib/__init__.pyi +177 -0
  816. jaclang/vendor/mypy/typeshed/stdlib/msilib/schema.pyi +94 -0
  817. jaclang/vendor/mypy/typeshed/stdlib/msilib/sequence.pyi +13 -0
  818. jaclang/vendor/mypy/typeshed/stdlib/msilib/text.pyi +7 -0
  819. jaclang/vendor/mypy/typeshed/stdlib/msvcrt.pyi +32 -0
  820. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/__init__.pyi +90 -0
  821. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/connection.pyi +75 -0
  822. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/context.pyi +189 -0
  823. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/dummy/__init__.pyi +77 -0
  824. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/dummy/connection.pyi +39 -0
  825. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/forkserver.pyi +31 -0
  826. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/heap.pyi +36 -0
  827. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/managers.pyi +212 -0
  828. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/pool.pyi +103 -0
  829. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/popen_fork.pyi +23 -0
  830. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/popen_forkserver.pyi +16 -0
  831. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/popen_spawn_posix.pyi +20 -0
  832. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/popen_spawn_win32.pyi +30 -0
  833. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/process.pyi +39 -0
  834. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/queues.pyi +41 -0
  835. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/reduction.pyi +90 -0
  836. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/resource_sharer.pyi +20 -0
  837. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/resource_tracker.pyi +18 -0
  838. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/shared_memory.pyi +40 -0
  839. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/sharedctypes.pyi +107 -0
  840. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/spawn.pyi +32 -0
  841. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/synchronize.pyi +54 -0
  842. jaclang/vendor/mypy/typeshed/stdlib/multiprocessing/util.pyi +98 -0
  843. jaclang/vendor/mypy/typeshed/stdlib/netrc.pyi +23 -0
  844. jaclang/vendor/mypy/typeshed/stdlib/nis.pyi +9 -0
  845. jaclang/vendor/mypy/typeshed/stdlib/nntplib.pyi +125 -0
  846. jaclang/vendor/mypy/typeshed/stdlib/nt.pyi +111 -0
  847. jaclang/vendor/mypy/typeshed/stdlib/ntpath.pyi +119 -0
  848. jaclang/vendor/mypy/typeshed/stdlib/nturl2path.pyi +2 -0
  849. jaclang/vendor/mypy/typeshed/stdlib/numbers.pyi +209 -0
  850. jaclang/vendor/mypy/typeshed/stdlib/opcode.pyi +59 -0
  851. jaclang/vendor/mypy/typeshed/stdlib/operator.pyi +110 -0
  852. jaclang/vendor/mypy/typeshed/stdlib/optparse.pyi +255 -0
  853. jaclang/vendor/mypy/typeshed/stdlib/os/__init__.pyi +1157 -0
  854. jaclang/vendor/mypy/typeshed/stdlib/os/path.pyi +8 -0
  855. jaclang/vendor/mypy/typeshed/stdlib/ossaudiodev.pyi +131 -0
  856. jaclang/vendor/mypy/typeshed/stdlib/parser.pyi +24 -0
  857. jaclang/vendor/mypy/typeshed/stdlib/pathlib.pyi +232 -0
  858. jaclang/vendor/mypy/typeshed/stdlib/pdb.pyi +181 -0
  859. jaclang/vendor/mypy/typeshed/stdlib/pickle.pyi +271 -0
  860. jaclang/vendor/mypy/typeshed/stdlib/pickletools.pyi +167 -0
  861. jaclang/vendor/mypy/typeshed/stdlib/pipes.pyi +16 -0
  862. jaclang/vendor/mypy/typeshed/stdlib/pkgutil.pyi +53 -0
  863. jaclang/vendor/mypy/typeshed/stdlib/platform.pyi +42 -0
  864. jaclang/vendor/mypy/typeshed/stdlib/plistlib.pyi +113 -0
  865. jaclang/vendor/mypy/typeshed/stdlib/poplib.pyi +71 -0
  866. jaclang/vendor/mypy/typeshed/stdlib/posix.pyi +361 -0
  867. jaclang/vendor/mypy/typeshed/stdlib/posixpath.pyi +161 -0
  868. jaclang/vendor/mypy/typeshed/stdlib/pprint.pyi +112 -0
  869. jaclang/vendor/mypy/typeshed/stdlib/profile.pyi +31 -0
  870. jaclang/vendor/mypy/typeshed/stdlib/pstats.pyi +80 -0
  871. jaclang/vendor/mypy/typeshed/stdlib/pty.pyi +19 -0
  872. jaclang/vendor/mypy/typeshed/stdlib/pwd.pyi +28 -0
  873. jaclang/vendor/mypy/typeshed/stdlib/py_compile.pyi +34 -0
  874. jaclang/vendor/mypy/typeshed/stdlib/pyclbr.pyi +74 -0
  875. jaclang/vendor/mypy/typeshed/stdlib/pydoc.pyi +261 -0
  876. jaclang/vendor/mypy/typeshed/stdlib/pydoc_data/__init__.pyi +0 -0
  877. jaclang/vendor/mypy/typeshed/stdlib/pydoc_data/topics.pyi +1 -0
  878. jaclang/vendor/mypy/typeshed/stdlib/pyexpat/__init__.pyi +85 -0
  879. jaclang/vendor/mypy/typeshed/stdlib/pyexpat/errors.pyi +49 -0
  880. jaclang/vendor/mypy/typeshed/stdlib/pyexpat/model.pyi +11 -0
  881. jaclang/vendor/mypy/typeshed/stdlib/queue.pyi +66 -0
  882. jaclang/vendor/mypy/typeshed/stdlib/quopri.pyi +11 -0
  883. jaclang/vendor/mypy/typeshed/stdlib/random.pyi +138 -0
  884. jaclang/vendor/mypy/typeshed/stdlib/re.pyi +290 -0
  885. jaclang/vendor/mypy/typeshed/stdlib/readline.pyi +36 -0
  886. jaclang/vendor/mypy/typeshed/stdlib/reprlib.pyi +65 -0
  887. jaclang/vendor/mypy/typeshed/stdlib/resource.pyi +94 -0
  888. jaclang/vendor/mypy/typeshed/stdlib/rlcompleter.pyi +9 -0
  889. jaclang/vendor/mypy/typeshed/stdlib/runpy.pyi +24 -0
  890. jaclang/vendor/mypy/typeshed/stdlib/sched.pyi +42 -0
  891. jaclang/vendor/mypy/typeshed/stdlib/secrets.pyi +15 -0
  892. jaclang/vendor/mypy/typeshed/stdlib/select.pyi +155 -0
  893. jaclang/vendor/mypy/typeshed/stdlib/selectors.pyi +67 -0
  894. jaclang/vendor/mypy/typeshed/stdlib/shelve.pyi +46 -0
  895. jaclang/vendor/mypy/typeshed/stdlib/shlex.pyi +63 -0
  896. jaclang/vendor/mypy/typeshed/stdlib/shutil.pyi +185 -0
  897. jaclang/vendor/mypy/typeshed/stdlib/signal.pyi +188 -0
  898. jaclang/vendor/mypy/typeshed/stdlib/site.pyi +27 -0
  899. jaclang/vendor/mypy/typeshed/stdlib/smtpd.pyi +91 -0
  900. jaclang/vendor/mypy/typeshed/stdlib/smtplib.pyi +204 -0
  901. jaclang/vendor/mypy/typeshed/stdlib/sndhdr.pyi +14 -0
  902. jaclang/vendor/mypy/typeshed/stdlib/socket.pyi +825 -0
  903. jaclang/vendor/mypy/typeshed/stdlib/socketserver.pyi +168 -0
  904. jaclang/vendor/mypy/typeshed/stdlib/spwd.pyi +41 -0
  905. jaclang/vendor/mypy/typeshed/stdlib/sqlite3/__init__.pyi +1 -0
  906. jaclang/vendor/mypy/typeshed/stdlib/sqlite3/dbapi2.pyi +551 -0
  907. jaclang/vendor/mypy/typeshed/stdlib/sre_compile.pyi +11 -0
  908. jaclang/vendor/mypy/typeshed/stdlib/sre_constants.pyi +130 -0
  909. jaclang/vendor/mypy/typeshed/stdlib/sre_parse.pyi +104 -0
  910. jaclang/vendor/mypy/typeshed/stdlib/ssl.pyi +537 -0
  911. jaclang/vendor/mypy/typeshed/stdlib/stat.pyi +1 -0
  912. jaclang/vendor/mypy/typeshed/stdlib/statistics.pyi +132 -0
  913. jaclang/vendor/mypy/typeshed/stdlib/string.pyi +83 -0
  914. jaclang/vendor/mypy/typeshed/stdlib/stringprep.pyi +27 -0
  915. jaclang/vendor/mypy/typeshed/stdlib/struct.pyi +26 -0
  916. jaclang/vendor/mypy/typeshed/stdlib/subprocess.pyi +2615 -0
  917. jaclang/vendor/mypy/typeshed/stdlib/sunau.pyi +86 -0
  918. jaclang/vendor/mypy/typeshed/stdlib/symbol.pyi +93 -0
  919. jaclang/vendor/mypy/typeshed/stdlib/symtable.pyi +58 -0
  920. jaclang/vendor/mypy/typeshed/stdlib/sys/__init__.pyi +373 -0
  921. jaclang/vendor/mypy/typeshed/stdlib/sys/_monitoring.pyi +52 -0
  922. jaclang/vendor/mypy/typeshed/stdlib/sysconfig.pyi +48 -0
  923. jaclang/vendor/mypy/typeshed/stdlib/syslog.pyi +46 -0
  924. jaclang/vendor/mypy/typeshed/stdlib/tabnanny.pyi +16 -0
  925. jaclang/vendor/mypy/typeshed/stdlib/tarfile.pyi +441 -0
  926. jaclang/vendor/mypy/typeshed/stdlib/telnetlib.pyi +122 -0
  927. jaclang/vendor/mypy/typeshed/stdlib/tempfile.pyi +477 -0
  928. jaclang/vendor/mypy/typeshed/stdlib/termios.pyi +267 -0
  929. jaclang/vendor/mypy/typeshed/stdlib/textwrap.pyi +103 -0
  930. jaclang/vendor/mypy/typeshed/stdlib/this.pyi +2 -0
  931. jaclang/vendor/mypy/typeshed/stdlib/threading.pyi +187 -0
  932. jaclang/vendor/mypy/typeshed/stdlib/time.pyi +108 -0
  933. jaclang/vendor/mypy/typeshed/stdlib/timeit.pyi +32 -0
  934. jaclang/vendor/mypy/typeshed/stdlib/tkinter/__init__.pyi +3654 -0
  935. jaclang/vendor/mypy/typeshed/stdlib/tkinter/colorchooser.pyi +20 -0
  936. jaclang/vendor/mypy/typeshed/stdlib/tkinter/commondialog.pyi +14 -0
  937. jaclang/vendor/mypy/typeshed/stdlib/tkinter/constants.pyi +80 -0
  938. jaclang/vendor/mypy/typeshed/stdlib/tkinter/dialog.pyi +16 -0
  939. jaclang/vendor/mypy/typeshed/stdlib/tkinter/dnd.pyi +20 -0
  940. jaclang/vendor/mypy/typeshed/stdlib/tkinter/filedialog.pyi +151 -0
  941. jaclang/vendor/mypy/typeshed/stdlib/tkinter/font.pyi +116 -0
  942. jaclang/vendor/mypy/typeshed/stdlib/tkinter/messagebox.pyi +44 -0
  943. jaclang/vendor/mypy/typeshed/stdlib/tkinter/scrolledtext.pyi +9 -0
  944. jaclang/vendor/mypy/typeshed/stdlib/tkinter/simpledialog.pyi +54 -0
  945. jaclang/vendor/mypy/typeshed/stdlib/tkinter/tix.pyi +299 -0
  946. jaclang/vendor/mypy/typeshed/stdlib/tkinter/ttk.pyi +1204 -0
  947. jaclang/vendor/mypy/typeshed/stdlib/token.pyi +159 -0
  948. jaclang/vendor/mypy/typeshed/stdlib/tokenize.pyi +177 -0
  949. jaclang/vendor/mypy/typeshed/stdlib/tomllib.pyi +10 -0
  950. jaclang/vendor/mypy/typeshed/stdlib/trace.pyi +79 -0
  951. jaclang/vendor/mypy/typeshed/stdlib/traceback.pyi +262 -0
  952. jaclang/vendor/mypy/typeshed/stdlib/tracemalloc.pyi +124 -0
  953. jaclang/vendor/mypy/typeshed/stdlib/tty.pyi +30 -0
  954. jaclang/vendor/mypy/typeshed/stdlib/turtle.pyi +713 -0
  955. jaclang/vendor/mypy/typeshed/stdlib/types.pyi +614 -0
  956. jaclang/vendor/mypy/typeshed/stdlib/typing.pyi +976 -0
  957. jaclang/vendor/mypy/typeshed/stdlib/typing_extensions.pyi +509 -0
  958. jaclang/vendor/mypy/typeshed/stdlib/unicodedata.pyi +73 -0
  959. jaclang/vendor/mypy/typeshed/stdlib/unittest/__init__.pyi +67 -0
  960. jaclang/vendor/mypy/typeshed/stdlib/unittest/_log.pyi +27 -0
  961. jaclang/vendor/mypy/typeshed/stdlib/unittest/async_case.pyi +21 -0
  962. jaclang/vendor/mypy/typeshed/stdlib/unittest/case.pyi +342 -0
  963. jaclang/vendor/mypy/typeshed/stdlib/unittest/loader.pyi +51 -0
  964. jaclang/vendor/mypy/typeshed/stdlib/unittest/main.pyi +69 -0
  965. jaclang/vendor/mypy/typeshed/stdlib/unittest/mock.pyi +430 -0
  966. jaclang/vendor/mypy/typeshed/stdlib/unittest/result.pyi +47 -0
  967. jaclang/vendor/mypy/typeshed/stdlib/unittest/runner.pyi +72 -0
  968. jaclang/vendor/mypy/typeshed/stdlib/unittest/signals.pyi +15 -0
  969. jaclang/vendor/mypy/typeshed/stdlib/unittest/suite.pyi +22 -0
  970. jaclang/vendor/mypy/typeshed/stdlib/unittest/util.pyi +23 -0
  971. jaclang/vendor/mypy/typeshed/stdlib/urllib/__init__.pyi +0 -0
  972. jaclang/vendor/mypy/typeshed/stdlib/urllib/error.pyi +23 -0
  973. jaclang/vendor/mypy/typeshed/stdlib/urllib/parse.pyi +210 -0
  974. jaclang/vendor/mypy/typeshed/stdlib/urllib/request.pyi +400 -0
  975. jaclang/vendor/mypy/typeshed/stdlib/urllib/response.pyi +43 -0
  976. jaclang/vendor/mypy/typeshed/stdlib/urllib/robotparser.pyi +20 -0
  977. jaclang/vendor/mypy/typeshed/stdlib/uu.pyi +13 -0
  978. jaclang/vendor/mypy/typeshed/stdlib/uuid.pyi +100 -0
  979. jaclang/vendor/mypy/typeshed/stdlib/warnings.pyi +112 -0
  980. jaclang/vendor/mypy/typeshed/stdlib/wave.pyi +85 -0
  981. jaclang/vendor/mypy/typeshed/stdlib/weakref.pyi +149 -0
  982. jaclang/vendor/mypy/typeshed/stdlib/webbrowser.pyi +74 -0
  983. jaclang/vendor/mypy/typeshed/stdlib/winreg.pyi +132 -0
  984. jaclang/vendor/mypy/typeshed/stdlib/winsound.pyi +28 -0
  985. jaclang/vendor/mypy/typeshed/stdlib/wsgiref/__init__.pyi +0 -0
  986. jaclang/vendor/mypy/typeshed/stdlib/wsgiref/handlers.pyi +91 -0
  987. jaclang/vendor/mypy/typeshed/stdlib/wsgiref/headers.pyi +26 -0
  988. jaclang/vendor/mypy/typeshed/stdlib/wsgiref/simple_server.pyi +37 -0
  989. jaclang/vendor/mypy/typeshed/stdlib/wsgiref/types.pyi +32 -0
  990. jaclang/vendor/mypy/typeshed/stdlib/wsgiref/util.pyi +24 -0
  991. jaclang/vendor/mypy/typeshed/stdlib/wsgiref/validate.pyi +50 -0
  992. jaclang/vendor/mypy/typeshed/stdlib/xdrlib.pyi +57 -0
  993. jaclang/vendor/mypy/typeshed/stdlib/xml/__init__.pyi +1 -0
  994. jaclang/vendor/mypy/typeshed/stdlib/xml/dom/NodeFilter.pyi +19 -0
  995. jaclang/vendor/mypy/typeshed/stdlib/xml/dom/__init__.pyi +69 -0
  996. jaclang/vendor/mypy/typeshed/stdlib/xml/dom/domreg.pyi +8 -0
  997. jaclang/vendor/mypy/typeshed/stdlib/xml/dom/expatbuilder.pyi +100 -0
  998. jaclang/vendor/mypy/typeshed/stdlib/xml/dom/minicompat.pyi +22 -0
  999. jaclang/vendor/mypy/typeshed/stdlib/xml/dom/minidom.pyi +404 -0
  1000. jaclang/vendor/mypy/typeshed/stdlib/xml/dom/pulldom.pyi +94 -0
  1001. jaclang/vendor/mypy/typeshed/stdlib/xml/dom/xmlbuilder.pyi +108 -0
  1002. jaclang/vendor/mypy/typeshed/stdlib/xml/etree/ElementInclude.pyi +28 -0
  1003. jaclang/vendor/mypy/typeshed/stdlib/xml/etree/ElementPath.pyi +34 -0
  1004. jaclang/vendor/mypy/typeshed/stdlib/xml/etree/ElementTree.pyi +327 -0
  1005. jaclang/vendor/mypy/typeshed/stdlib/xml/etree/__init__.pyi +0 -0
  1006. jaclang/vendor/mypy/typeshed/stdlib/xml/etree/cElementTree.pyi +1 -0
  1007. jaclang/vendor/mypy/typeshed/stdlib/xml/parsers/__init__.pyi +1 -0
  1008. jaclang/vendor/mypy/typeshed/stdlib/xml/parsers/expat/__init__.pyi +1 -0
  1009. jaclang/vendor/mypy/typeshed/stdlib/xml/parsers/expat/errors.pyi +1 -0
  1010. jaclang/vendor/mypy/typeshed/stdlib/xml/parsers/expat/model.pyi +1 -0
  1011. jaclang/vendor/mypy/typeshed/stdlib/xml/sax/__init__.pyi +25 -0
  1012. jaclang/vendor/mypy/typeshed/stdlib/xml/sax/_exceptions.pyi +19 -0
  1013. jaclang/vendor/mypy/typeshed/stdlib/xml/sax/handler.pyi +55 -0
  1014. jaclang/vendor/mypy/typeshed/stdlib/xml/sax/saxutils.pyi +60 -0
  1015. jaclang/vendor/mypy/typeshed/stdlib/xml/sax/xmlreader.pyi +87 -0
  1016. jaclang/vendor/mypy/typeshed/stdlib/xmlrpc/__init__.pyi +0 -0
  1017. jaclang/vendor/mypy/typeshed/stdlib/xmlrpc/client.pyi +296 -0
  1018. jaclang/vendor/mypy/typeshed/stdlib/xmlrpc/server.pyi +143 -0
  1019. jaclang/vendor/mypy/typeshed/stdlib/xxlimited.pyi +22 -0
  1020. jaclang/vendor/mypy/typeshed/stdlib/zipapp.pyi +20 -0
  1021. jaclang/vendor/mypy/typeshed/stdlib/zipfile/__init__.pyi +306 -0
  1022. jaclang/vendor/mypy/typeshed/stdlib/zipfile/_path.pyi +95 -0
  1023. jaclang/vendor/mypy/typeshed/stdlib/zipimport.pyi +32 -0
  1024. jaclang/vendor/mypy/typeshed/stdlib/zlib.pyi +56 -0
  1025. jaclang/vendor/mypy/typeshed/stdlib/zoneinfo/__init__.pyi +38 -0
  1026. jaclang/vendor/mypy/typeshed/stubs/mypy-extensions/mypy_extensions.pyi +218 -0
  1027. jaclang/vendor/mypy/typestate.py +5 -15
  1028. jaclang/vendor/mypy/typetraverser.py +9 -3
  1029. jaclang/vendor/mypy/typevars.py +2 -8
  1030. jaclang/vendor/mypy/util.py +14 -45
  1031. jaclang/vendor/mypy/version.py +1 -19
  1032. jaclang/vendor/mypy/visitor.py +3 -9
  1033. jaclang/vendor/mypy/xml/mypy-html.css +104 -0
  1034. jaclang/vendor/mypy/xml/mypy-html.xslt +81 -0
  1035. jaclang/vendor/mypy/xml/mypy-txt.xslt +100 -0
  1036. jaclang/vendor/mypy/xml/mypy.xsd +50 -0
  1037. jaclang/vendor/mypy-1.10.0.dist-info/LICENSE +229 -0
  1038. jaclang/vendor/mypy-1.10.0.dist-info/METADATA +48 -0
  1039. jaclang/vendor/mypy-1.10.0.dist-info/RECORD +1241 -0
  1040. jaclang/vendor/mypy-1.10.0.dist-info/WHEEL +6 -0
  1041. jaclang/vendor/mypy-1.10.0.dist-info/entry_points.txt +6 -0
  1042. jaclang/vendor/mypy-1.10.0.dist-info/top_level.txt +3 -0
  1043. jaclang/vendor/mypy_extensions-1.0.0.dist-info/LICENSE +27 -0
  1044. jaclang/vendor/mypy_extensions-1.0.0.dist-info/METADATA +29 -0
  1045. jaclang/vendor/mypy_extensions-1.0.0.dist-info/RECORD +6 -0
  1046. jaclang/vendor/mypy_extensions-1.0.0.dist-info/WHEEL +5 -0
  1047. jaclang/vendor/mypy_extensions-1.0.0.dist-info/top_level.txt +1 -0
  1048. jaclang/vendor/mypy_extensions.py +21 -40
  1049. jaclang/vendor/mypyc/README.md +133 -0
  1050. jaclang/vendor/mypyc/__main__.py +1 -3
  1051. jaclang/vendor/mypyc/analysis/attrdefined.py +6 -22
  1052. jaclang/vendor/mypyc/analysis/dataflow.py +5 -3
  1053. jaclang/vendor/mypyc/analysis/ircheck.py +13 -26
  1054. jaclang/vendor/mypyc/analysis/selfleaks.py +4 -0
  1055. jaclang/vendor/mypyc/build.py +6 -19
  1056. jaclang/vendor/mypyc/codegen/emit.py +20 -73
  1057. jaclang/vendor/mypyc/codegen/emitclass.py +22 -72
  1058. jaclang/vendor/mypyc/codegen/emitfunc.py +20 -62
  1059. jaclang/vendor/mypyc/codegen/emitmodule.py +50 -117
  1060. jaclang/vendor/mypyc/codegen/emitwrapper.py +22 -78
  1061. jaclang/vendor/mypyc/codegen/literals.py +1 -3
  1062. jaclang/vendor/mypyc/common.py +1 -3
  1063. jaclang/vendor/mypyc/doc/Makefile +20 -0
  1064. jaclang/vendor/mypyc/doc/bool_operations.rst +27 -0
  1065. jaclang/vendor/mypyc/doc/compilation_units.rst +20 -0
  1066. jaclang/vendor/mypyc/doc/conf.py +59 -0
  1067. jaclang/vendor/mypyc/doc/cpython-timings.md +25 -0
  1068. jaclang/vendor/mypyc/doc/dev-intro.md +548 -0
  1069. jaclang/vendor/mypyc/doc/dict_operations.rst +59 -0
  1070. jaclang/vendor/mypyc/doc/differences_from_python.rst +332 -0
  1071. jaclang/vendor/mypyc/doc/float_operations.rst +50 -0
  1072. jaclang/vendor/mypyc/doc/future.md +42 -0
  1073. jaclang/vendor/mypyc/doc/getting_started.rst +240 -0
  1074. jaclang/vendor/mypyc/doc/index.rst +61 -0
  1075. jaclang/vendor/mypyc/doc/int_operations.rst +162 -0
  1076. jaclang/vendor/mypyc/doc/introduction.rst +150 -0
  1077. jaclang/vendor/mypyc/doc/list_operations.rst +65 -0
  1078. jaclang/vendor/mypyc/doc/make.bat +35 -0
  1079. jaclang/vendor/mypyc/doc/native_classes.rst +206 -0
  1080. jaclang/vendor/mypyc/doc/native_operations.rst +55 -0
  1081. jaclang/vendor/mypyc/doc/performance_tips_and_tricks.rst +244 -0
  1082. jaclang/vendor/mypyc/doc/set_operations.rst +47 -0
  1083. jaclang/vendor/mypyc/doc/str_operations.rst +35 -0
  1084. jaclang/vendor/mypyc/doc/tuple_operations.rst +33 -0
  1085. jaclang/vendor/mypyc/doc/using_type_annotations.rst +398 -0
  1086. jaclang/vendor/mypyc/external/googletest/LICENSE +28 -0
  1087. jaclang/vendor/mypyc/external/googletest/README.md +280 -0
  1088. jaclang/vendor/mypyc/external/googletest/include/gtest/gtest-death-test.h +294 -0
  1089. jaclang/vendor/mypyc/external/googletest/include/gtest/gtest-message.h +250 -0
  1090. jaclang/vendor/mypyc/external/googletest/include/gtest/gtest-param-test.h +1444 -0
  1091. jaclang/vendor/mypyc/external/googletest/include/gtest/gtest-param-test.h.pump +510 -0
  1092. jaclang/vendor/mypyc/external/googletest/include/gtest/gtest-printers.h +993 -0
  1093. jaclang/vendor/mypyc/external/googletest/include/gtest/gtest-spi.h +232 -0
  1094. jaclang/vendor/mypyc/external/googletest/include/gtest/gtest-test-part.h +179 -0
  1095. jaclang/vendor/mypyc/external/googletest/include/gtest/gtest-typed-test.h +263 -0
  1096. jaclang/vendor/mypyc/external/googletest/include/gtest/gtest.h +2236 -0
  1097. jaclang/vendor/mypyc/external/googletest/include/gtest/gtest_pred_impl.h +358 -0
  1098. jaclang/vendor/mypyc/external/googletest/include/gtest/gtest_prod.h +58 -0
  1099. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/custom/gtest-port.h +69 -0
  1100. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/custom/gtest-printers.h +42 -0
  1101. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/custom/gtest.h +41 -0
  1102. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-death-test-internal.h +319 -0
  1103. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-filepath.h +206 -0
  1104. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-internal.h +1238 -0
  1105. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-linked_ptr.h +243 -0
  1106. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-param-util-generated.h +5146 -0
  1107. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-param-util-generated.h.pump +286 -0
  1108. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-param-util.h +731 -0
  1109. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-port-arch.h +93 -0
  1110. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-port.h +2560 -0
  1111. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-string.h +167 -0
  1112. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-tuple.h +1020 -0
  1113. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-tuple.h.pump +347 -0
  1114. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-type-util.h +3331 -0
  1115. jaclang/vendor/mypyc/external/googletest/include/gtest/internal/gtest-type-util.h.pump +297 -0
  1116. jaclang/vendor/mypyc/external/googletest/make/Makefile +61 -0
  1117. jaclang/vendor/mypyc/external/googletest/src/gtest-all.cc +48 -0
  1118. jaclang/vendor/mypyc/external/googletest/src/gtest-death-test.cc +1342 -0
  1119. jaclang/vendor/mypyc/external/googletest/src/gtest-filepath.cc +387 -0
  1120. jaclang/vendor/mypyc/external/googletest/src/gtest-internal-inl.h +1183 -0
  1121. jaclang/vendor/mypyc/external/googletest/src/gtest-port.cc +1259 -0
  1122. jaclang/vendor/mypyc/external/googletest/src/gtest-printers.cc +373 -0
  1123. jaclang/vendor/mypyc/external/googletest/src/gtest-test-part.cc +110 -0
  1124. jaclang/vendor/mypyc/external/googletest/src/gtest-typed-test.cc +118 -0
  1125. jaclang/vendor/mypyc/external/googletest/src/gtest.cc +5388 -0
  1126. jaclang/vendor/mypyc/external/googletest/src/gtest_main.cc +38 -0
  1127. jaclang/vendor/mypyc/ir/class_ir.py +8 -24
  1128. jaclang/vendor/mypyc/ir/func_ir.py +3 -16
  1129. jaclang/vendor/mypyc/ir/module_ir.py +2 -6
  1130. jaclang/vendor/mypyc/ir/ops.py +103 -66
  1131. jaclang/vendor/mypyc/ir/pprint.py +35 -55
  1132. jaclang/vendor/mypyc/ir/rtypes.py +16 -48
  1133. jaclang/vendor/mypyc/irbuild/ast_helpers.py +4 -1
  1134. jaclang/vendor/mypyc/irbuild/builder.py +46 -148
  1135. jaclang/vendor/mypyc/irbuild/callable_class.py +5 -19
  1136. jaclang/vendor/mypyc/irbuild/classdef.py +27 -83
  1137. jaclang/vendor/mypyc/irbuild/env_class.py +3 -9
  1138. jaclang/vendor/mypyc/irbuild/expression.py +42 -100
  1139. jaclang/vendor/mypyc/irbuild/for_helpers.py +56 -105
  1140. jaclang/vendor/mypyc/irbuild/format_str_tokenizer.py +1 -4
  1141. jaclang/vendor/mypyc/irbuild/function.py +40 -132
  1142. jaclang/vendor/mypyc/irbuild/generator.py +14 -49
  1143. jaclang/vendor/mypyc/irbuild/ll_builder.py +197 -426
  1144. jaclang/vendor/mypyc/irbuild/mapper.py +2 -13
  1145. jaclang/vendor/mypyc/irbuild/match.py +11 -36
  1146. jaclang/vendor/mypyc/irbuild/nonlocalcontrol.py +2 -7
  1147. jaclang/vendor/mypyc/irbuild/prebuildvisitor.py +1 -4
  1148. jaclang/vendor/mypyc/irbuild/prepare.py +25 -83
  1149. jaclang/vendor/mypyc/irbuild/specialize.py +22 -72
  1150. jaclang/vendor/mypyc/irbuild/statement.py +30 -96
  1151. jaclang/vendor/mypyc/irbuild/targets.py +1 -3
  1152. jaclang/vendor/mypyc/irbuild/util.py +2 -8
  1153. jaclang/vendor/mypyc/irbuild/vtable.py +1 -3
  1154. jaclang/vendor/mypyc/lib-rt/CPy.h +638 -0
  1155. jaclang/vendor/mypyc/lib-rt/bytes_ops.c +143 -0
  1156. jaclang/vendor/mypyc/lib-rt/dict_ops.c +446 -0
  1157. jaclang/vendor/mypyc/lib-rt/exc_ops.c +259 -0
  1158. jaclang/vendor/mypyc/lib-rt/float_ops.c +192 -0
  1159. jaclang/vendor/mypyc/lib-rt/generic_ops.c +64 -0
  1160. jaclang/vendor/mypyc/lib-rt/getargs.c +450 -0
  1161. jaclang/vendor/mypyc/lib-rt/getargsfast.c +569 -0
  1162. jaclang/vendor/mypyc/lib-rt/init.c +13 -0
  1163. jaclang/vendor/mypyc/lib-rt/int_ops.c +803 -0
  1164. jaclang/vendor/mypyc/lib-rt/list_ops.c +335 -0
  1165. jaclang/vendor/mypyc/lib-rt/misc_ops.c +942 -0
  1166. jaclang/vendor/mypyc/lib-rt/module_shim.tmpl +18 -0
  1167. jaclang/vendor/mypyc/lib-rt/mypyc_util.h +118 -0
  1168. jaclang/vendor/mypyc/lib-rt/pythoncapi_compat.h +497 -0
  1169. jaclang/vendor/mypyc/lib-rt/pythonsupport.h +533 -0
  1170. jaclang/vendor/mypyc/lib-rt/set_ops.c +17 -0
  1171. jaclang/vendor/mypyc/lib-rt/setup.py +70 -0
  1172. jaclang/vendor/mypyc/lib-rt/str_ops.c +241 -0
  1173. jaclang/vendor/mypyc/lib-rt/test_capi.cc +585 -0
  1174. jaclang/vendor/mypyc/lib-rt/tuple_ops.c +61 -0
  1175. jaclang/vendor/mypyc/lower/__init__.py +0 -0
  1176. jaclang/vendor/mypyc/lower/int_ops.py +113 -0
  1177. jaclang/vendor/mypyc/lower/list_ops.py +45 -0
  1178. jaclang/vendor/mypyc/lower/misc_ops.py +12 -0
  1179. jaclang/vendor/mypyc/lower/registry.py +26 -0
  1180. jaclang/vendor/mypyc/options.py +1 -3
  1181. jaclang/vendor/mypyc/primitives/dict_ops.py +1 -4
  1182. jaclang/vendor/mypyc/primitives/exc_ops.py +3 -12
  1183. jaclang/vendor/mypyc/primitives/int_ops.py +22 -32
  1184. jaclang/vendor/mypyc/primitives/list_ops.py +10 -0
  1185. jaclang/vendor/mypyc/primitives/misc_ops.py +28 -22
  1186. jaclang/vendor/mypyc/primitives/registry.py +56 -19
  1187. jaclang/vendor/mypyc/primitives/set_ops.py +1 -3
  1188. jaclang/vendor/mypyc/rt_subtype.py +1 -2
  1189. jaclang/vendor/mypyc/sametype.py +2 -5
  1190. jaclang/vendor/mypyc/subtype.py +3 -12
  1191. jaclang/vendor/mypyc/test/test_alwaysdefined.py +2 -6
  1192. jaclang/vendor/mypyc/test/test_analysis.py +8 -24
  1193. jaclang/vendor/mypyc/test/test_cheader.py +12 -4
  1194. jaclang/vendor/mypyc/test/test_emit.py +4 -14
  1195. jaclang/vendor/mypyc/test/test_emitclass.py +1 -8
  1196. jaclang/vendor/mypyc/test/test_emitfunc.py +30 -77
  1197. jaclang/vendor/mypyc/test/test_emitwrapper.py +1 -3
  1198. jaclang/vendor/mypyc/test/test_exceptions.py +4 -12
  1199. jaclang/vendor/mypyc/test/test_external.py +1 -5
  1200. jaclang/vendor/mypyc/test/test_irbuild.py +2 -6
  1201. jaclang/vendor/mypyc/test/test_ircheck.py +6 -17
  1202. jaclang/vendor/mypyc/test/test_literals.py +1 -4
  1203. jaclang/vendor/mypyc/test/test_lowering.py +56 -0
  1204. jaclang/vendor/mypyc/test/test_namegen.py +1 -4
  1205. jaclang/vendor/mypyc/test/test_optimizations.py +68 -0
  1206. jaclang/vendor/mypyc/test/test_refcount.py +3 -9
  1207. jaclang/vendor/mypyc/test/test_run.py +12 -38
  1208. jaclang/vendor/mypyc/test/test_serialization.py +1 -3
  1209. jaclang/vendor/mypyc/test/test_struct.py +3 -11
  1210. jaclang/vendor/mypyc/test/test_tuplename.py +4 -13
  1211. jaclang/vendor/mypyc/test/test_typeops.py +1 -4
  1212. jaclang/vendor/mypyc/test/testutil.py +2 -6
  1213. jaclang/vendor/mypyc/test-data/alwaysdefined.test +732 -0
  1214. jaclang/vendor/mypyc/test-data/analysis.test +470 -0
  1215. jaclang/vendor/mypyc/test-data/commandline.test +245 -0
  1216. jaclang/vendor/mypyc/test-data/driver/driver.py +48 -0
  1217. jaclang/vendor/mypyc/test-data/exceptions-freq.test +125 -0
  1218. jaclang/vendor/mypyc/test-data/exceptions.test +699 -0
  1219. jaclang/vendor/mypyc/test-data/fixtures/ir.py +373 -0
  1220. jaclang/vendor/mypyc/test-data/fixtures/testutil.py +103 -0
  1221. jaclang/vendor/mypyc/test-data/fixtures/typing-full.pyi +169 -0
  1222. jaclang/vendor/mypyc/test-data/irbuild-any.test +236 -0
  1223. jaclang/vendor/mypyc/test-data/irbuild-basic.test +3399 -0
  1224. jaclang/vendor/mypyc/test-data/irbuild-bool.test +424 -0
  1225. jaclang/vendor/mypyc/test-data/irbuild-bytes.test +181 -0
  1226. jaclang/vendor/mypyc/test-data/irbuild-classes.test +1302 -0
  1227. jaclang/vendor/mypyc/test-data/irbuild-constant-fold.test +480 -0
  1228. jaclang/vendor/mypyc/test-data/irbuild-dict.test +584 -0
  1229. jaclang/vendor/mypyc/test-data/irbuild-dunders.test +215 -0
  1230. jaclang/vendor/mypyc/test-data/irbuild-float.test +497 -0
  1231. jaclang/vendor/mypyc/test-data/irbuild-generics.test +150 -0
  1232. jaclang/vendor/mypyc/test-data/irbuild-glue-methods.test +437 -0
  1233. jaclang/vendor/mypyc/test-data/irbuild-i16.test +526 -0
  1234. jaclang/vendor/mypyc/test-data/irbuild-i32.test +598 -0
  1235. jaclang/vendor/mypyc/test-data/irbuild-i64.test +2144 -0
  1236. jaclang/vendor/mypyc/test-data/irbuild-int.test +194 -0
  1237. jaclang/vendor/mypyc/test-data/irbuild-isinstance.test +109 -0
  1238. jaclang/vendor/mypyc/test-data/irbuild-lists.test +513 -0
  1239. jaclang/vendor/mypyc/test-data/irbuild-match.test +1717 -0
  1240. jaclang/vendor/mypyc/test-data/irbuild-math.test +64 -0
  1241. jaclang/vendor/mypyc/test-data/irbuild-nested.test +807 -0
  1242. jaclang/vendor/mypyc/test-data/irbuild-optional.test +536 -0
  1243. jaclang/vendor/mypyc/test-data/irbuild-set.test +806 -0
  1244. jaclang/vendor/mypyc/test-data/irbuild-singledispatch.test +257 -0
  1245. jaclang/vendor/mypyc/test-data/irbuild-statements.test +1060 -0
  1246. jaclang/vendor/mypyc/test-data/irbuild-str.test +312 -0
  1247. jaclang/vendor/mypyc/test-data/irbuild-strip-asserts.test +12 -0
  1248. jaclang/vendor/mypyc/test-data/irbuild-try.test +523 -0
  1249. jaclang/vendor/mypyc/test-data/irbuild-tuple.test +386 -0
  1250. jaclang/vendor/mypyc/test-data/irbuild-u8.test +543 -0
  1251. jaclang/vendor/mypyc/test-data/irbuild-unreachable.test +241 -0
  1252. jaclang/vendor/mypyc/test-data/irbuild-vectorcall.test +153 -0
  1253. jaclang/vendor/mypyc/test-data/lowering-int.test +377 -0
  1254. jaclang/vendor/mypyc/test-data/lowering-list.test +33 -0
  1255. jaclang/vendor/mypyc/test-data/opt-copy-propagation.test +400 -0
  1256. jaclang/vendor/mypyc/test-data/opt-flag-elimination.test +296 -0
  1257. jaclang/vendor/mypyc/test-data/refcount.test +1482 -0
  1258. jaclang/vendor/mypyc/test-data/run-async.test +173 -0
  1259. jaclang/vendor/mypyc/test-data/run-attrs.test +318 -0
  1260. jaclang/vendor/mypyc/test-data/run-bench.test +196 -0
  1261. jaclang/vendor/mypyc/test-data/run-bools.test +229 -0
  1262. jaclang/vendor/mypyc/test-data/run-bytes.test +302 -0
  1263. jaclang/vendor/mypyc/test-data/run-classes.test +2505 -0
  1264. jaclang/vendor/mypyc/test-data/run-dicts.test +334 -0
  1265. jaclang/vendor/mypyc/test-data/run-dunders.test +945 -0
  1266. jaclang/vendor/mypyc/test-data/run-exceptions.test +448 -0
  1267. jaclang/vendor/mypyc/test-data/run-floats.test +516 -0
  1268. jaclang/vendor/mypyc/test-data/run-functions.test +1310 -0
  1269. jaclang/vendor/mypyc/test-data/run-generators.test +682 -0
  1270. jaclang/vendor/mypyc/test-data/run-i16.test +338 -0
  1271. jaclang/vendor/mypyc/test-data/run-i32.test +336 -0
  1272. jaclang/vendor/mypyc/test-data/run-i64.test +1519 -0
  1273. jaclang/vendor/mypyc/test-data/run-imports.test +265 -0
  1274. jaclang/vendor/mypyc/test-data/run-integers.test +540 -0
  1275. jaclang/vendor/mypyc/test-data/run-lists.test +411 -0
  1276. jaclang/vendor/mypyc/test-data/run-loops.test +485 -0
  1277. jaclang/vendor/mypyc/test-data/run-match.test +283 -0
  1278. jaclang/vendor/mypyc/test-data/run-math.test +106 -0
  1279. jaclang/vendor/mypyc/test-data/run-misc.test +1170 -0
  1280. jaclang/vendor/mypyc/test-data/run-multimodule.test +887 -0
  1281. jaclang/vendor/mypyc/test-data/run-mypy-sim.test +138 -0
  1282. jaclang/vendor/mypyc/test-data/run-primitives.test +375 -0
  1283. jaclang/vendor/mypyc/test-data/run-python37.test +159 -0
  1284. jaclang/vendor/mypyc/test-data/run-python38.test +88 -0
  1285. jaclang/vendor/mypyc/test-data/run-sets.test +150 -0
  1286. jaclang/vendor/mypyc/test-data/run-singledispatch.test +698 -0
  1287. jaclang/vendor/mypyc/test-data/run-strings.test +641 -0
  1288. jaclang/vendor/mypyc/test-data/run-traits.test +411 -0
  1289. jaclang/vendor/mypyc/test-data/run-tuples.test +258 -0
  1290. jaclang/vendor/mypyc/test-data/run-u8.test +303 -0
  1291. jaclang/vendor/mypyc/transform/copy_propagation.py +94 -0
  1292. jaclang/vendor/mypyc/transform/exceptions.py +1 -5
  1293. jaclang/vendor/mypyc/transform/flag_elimination.py +108 -0
  1294. jaclang/vendor/mypyc/transform/ir_transform.py +368 -0
  1295. jaclang/vendor/mypyc/transform/lower.py +33 -0
  1296. jaclang/vendor/mypyc/transform/refcount.py +7 -30
  1297. jaclang/vendor/mypyc/transform/uninit.py +4 -15
  1298. jaclang/vendor/pluggy/__init__.py +15 -11
  1299. jaclang/vendor/pluggy/_callers.py +34 -5
  1300. jaclang/vendor/pluggy/_hooks.py +35 -7
  1301. jaclang/vendor/pluggy/_manager.py +26 -3
  1302. jaclang/vendor/pluggy/_result.py +0 -15
  1303. jaclang/vendor/pluggy/_version.py +16 -0
  1304. jaclang/vendor/pluggy/_warnings.py +27 -0
  1305. jaclang/vendor/pluggy-1.5.0.dist-info/LICENSE +21 -0
  1306. jaclang/vendor/pluggy-1.5.0.dist-info/METADATA +155 -0
  1307. jaclang/vendor/pluggy-1.5.0.dist-info/RECORD +14 -0
  1308. jaclang/vendor/pluggy-1.5.0.dist-info/top_level.txt +1 -0
  1309. jaclang/vendor/pygls/__init__.py +25 -0
  1310. jaclang/vendor/pygls/capabilities.py +460 -0
  1311. jaclang/vendor/pygls/client.py +176 -0
  1312. jaclang/vendor/pygls/constants.py +26 -0
  1313. jaclang/vendor/pygls/exceptions.py +215 -0
  1314. jaclang/vendor/pygls/feature_manager.py +244 -0
  1315. jaclang/vendor/pygls/lsp/__init__.py +139 -0
  1316. jaclang/vendor/pygls/lsp/client.py +1961 -0
  1317. jaclang/vendor/pygls/progress.py +79 -0
  1318. jaclang/vendor/pygls/protocol/__init__.py +78 -0
  1319. jaclang/vendor/pygls/protocol/json_rpc.py +560 -0
  1320. jaclang/vendor/pygls/protocol/language_server.py +569 -0
  1321. jaclang/vendor/pygls/protocol/lsp_meta.py +51 -0
  1322. jaclang/vendor/pygls/py.typed +2 -0
  1323. jaclang/vendor/pygls/server.py +616 -0
  1324. jaclang/vendor/pygls/uris.py +184 -0
  1325. jaclang/vendor/pygls/workspace/__init__.py +97 -0
  1326. jaclang/vendor/pygls/workspace/position_codec.py +206 -0
  1327. jaclang/vendor/pygls/workspace/text_document.py +238 -0
  1328. jaclang/vendor/pygls/workspace/workspace.py +323 -0
  1329. jaclang/vendor/pygls-1.3.1.dist-info/LICENSE.txt +201 -0
  1330. jaclang/vendor/pygls-1.3.1.dist-info/METADATA +105 -0
  1331. jaclang/vendor/pygls-1.3.1.dist-info/RECORD +24 -0
  1332. jaclang/vendor/pygls-1.3.1.dist-info/WHEEL +4 -0
  1333. jaclang/vendor/typing_extensions-4.12.2.dist-info/LICENSE +279 -0
  1334. jaclang/vendor/typing_extensions-4.12.2.dist-info/METADATA +67 -0
  1335. jaclang/vendor/typing_extensions-4.12.2.dist-info/RECORD +5 -0
  1336. jaclang/vendor/typing_extensions-4.12.2.dist-info/WHEEL +4 -0
  1337. jaclang/vendor/typing_extensions.py +1209 -641
  1338. jaclang-0.6.5.dist-info/METADATA +106 -0
  1339. jaclang-0.6.5.dist-info/RECORD +1476 -0
  1340. jaclang-0.6.5.dist-info/WHEEL +4 -0
  1341. jaclang-0.6.5.dist-info/entry_points.txt +3 -0
  1342. jaclang/compiler/generated/jac_parser.py +0 -4069
  1343. jaclang-0.6.0.dist-info/METADATA +0 -17
  1344. jaclang-0.6.0.dist-info/RECORD +0 -426
  1345. jaclang-0.6.0.dist-info/entry_points.txt +0 -2
  1346. jaclang-0.6.0.dist-info/top_level.txt +0 -1
  1347. /jaclang/{compiler/generated/__init__.py → vendor/attr/py.typed} +0 -0
  1348. {jaclang-0.6.0.dist-info → jaclang/vendor/pluggy-1.5.0.dist-info}/WHEEL +0 -0
@@ -1,923 +1,810 @@
1
- """"This module implements an SPPF implementation
2
-
3
- This is used as the primary output mechanism for the Earley parser
4
- in order to store complex ambiguities.
5
-
6
- Full reference and more details is here:
7
- https://web.archive.org/web/20190616123959/http://www.bramvandersanden.com/post/2014/06/shared-packed-parse-forest/
8
- """
9
-
10
- from typing import Type, AbstractSet
11
- from random import randint
12
- from collections import deque
13
- from operator import attrgetter
14
- from importlib import import_module
15
- from functools import partial
16
-
17
- from ..parse_tree_builder import AmbiguousIntermediateExpander
18
- from ..visitors import Discard
19
- from ..utils import logger, OrderedSet
20
- from ..tree import Tree
21
-
22
-
23
- class ForestNode:
24
- pass
25
-
26
-
27
- class SymbolNode(ForestNode):
28
- """
29
- A Symbol Node represents a symbol (or Intermediate LR0).
30
-
31
- Symbol nodes are keyed by the symbol (s). For intermediate nodes
32
- s will be an LR0, stored as a tuple of (rule, ptr). For completed symbol
33
- nodes, s will be a string representing the non-terminal origin (i.e.
34
- the left hand side of the rule).
35
-
36
- The children of a Symbol or Intermediate Node will always be Packed Nodes;
37
- with each Packed Node child representing a single derivation of a production.
38
-
39
- Hence a Symbol Node with a single child is unambiguous.
40
-
41
- Parameters:
42
- s: A Symbol, or a tuple of (rule, ptr) for an intermediate node.
43
- start: The index of the start of the substring matched by this symbol (inclusive).
44
- end: The index of the end of the substring matched by this symbol (exclusive).
45
-
46
- Properties:
47
- is_intermediate: True if this node is an intermediate node.
48
- priority: The priority of the node's symbol.
49
- """
50
-
51
- Set: Type[AbstractSet] = set # Overridden by StableSymbolNode
52
- __slots__ = (
53
- "s",
54
- "start",
55
- "end",
56
- "_children",
57
- "paths",
58
- "paths_loaded",
59
- "priority",
60
- "is_intermediate",
61
- "_hash",
62
- )
63
-
64
- def __init__(self, s, start, end):
65
- self.s = s
66
- self.start = start
67
- self.end = end
68
- self._children = self.Set()
69
- self.paths = self.Set()
70
- self.paths_loaded = False
71
-
72
- ### We use inf here as it can be safely negated without resorting to conditionals,
73
- # unlike None or float('NaN'), and sorts appropriately.
74
- self.priority = float("-inf")
75
- self.is_intermediate = isinstance(s, tuple)
76
- self._hash = hash((self.s, self.start, self.end))
77
-
78
- def add_family(self, lr0, rule, start, left, right):
79
- self._children.add(PackedNode(self, lr0, rule, start, left, right))
80
-
81
- def add_path(self, transitive, node):
82
- self.paths.add((transitive, node))
83
-
84
- def load_paths(self):
85
- for transitive, node in self.paths:
86
- if transitive.next_titem is not None:
87
- vn = type(self)(
88
- transitive.next_titem.s, transitive.next_titem.start, self.end
89
- )
90
- vn.add_path(transitive.next_titem, node)
91
- self.add_family(
92
- transitive.reduction.rule.origin,
93
- transitive.reduction.rule,
94
- transitive.reduction.start,
95
- transitive.reduction.node,
96
- vn,
97
- )
98
- else:
99
- self.add_family(
100
- transitive.reduction.rule.origin,
101
- transitive.reduction.rule,
102
- transitive.reduction.start,
103
- transitive.reduction.node,
104
- node,
105
- )
106
- self.paths_loaded = True
107
-
108
- @property
109
- def is_ambiguous(self):
110
- """Returns True if this node is ambiguous."""
111
- return len(self.children) > 1
112
-
113
- @property
114
- def children(self):
115
- """Returns a list of this node's children sorted from greatest to
116
- least priority."""
117
- if not self.paths_loaded:
118
- self.load_paths()
119
- return sorted(self._children, key=attrgetter("sort_key"))
120
-
121
- def __iter__(self):
122
- return iter(self._children)
123
-
124
- def __eq__(self, other):
125
- if not isinstance(other, SymbolNode):
126
- return False
127
- return self is other or (
128
- type(self.s) == type(other.s)
129
- and self.s == other.s
130
- and self.start == other.start
131
- and self.end is other.end
132
- )
133
-
134
- def __hash__(self):
135
- return self._hash
136
-
137
- def __repr__(self):
138
- if self.is_intermediate:
139
- rule = self.s[0]
140
- ptr = self.s[1]
141
- before = (expansion.name for expansion in rule.expansion[:ptr])
142
- after = (expansion.name for expansion in rule.expansion[ptr:])
143
- symbol = "{} ::= {}* {}".format(
144
- rule.origin.name, " ".join(before), " ".join(after)
145
- )
146
- else:
147
- symbol = self.s.name
148
- return "({}, {}, {}, {})".format(symbol, self.start, self.end, self.priority)
149
-
150
-
151
- class StableSymbolNode(SymbolNode):
152
- "A version of SymbolNode that uses OrderedSet for output stability"
153
- Set = OrderedSet
154
-
155
-
156
- class PackedNode(ForestNode):
157
- """
158
- A Packed Node represents a single derivation in a symbol node.
159
-
160
- Parameters:
161
- rule: The rule associated with this node.
162
- parent: The parent of this node.
163
- left: The left child of this node. ``None`` if one does not exist.
164
- right: The right child of this node. ``None`` if one does not exist.
165
- priority: The priority of this node.
166
- """
167
-
168
- __slots__ = ("parent", "s", "rule", "start", "left", "right", "priority", "_hash")
169
-
170
- def __init__(self, parent, s, rule, start, left, right):
171
- self.parent = parent
172
- self.s = s
173
- self.start = start
174
- self.rule = rule
175
- self.left = left
176
- self.right = right
177
- self.priority = float("-inf")
178
- self._hash = hash((self.left, self.right))
179
-
180
- @property
181
- def is_empty(self):
182
- return self.left is None and self.right is None
183
-
184
- @property
185
- def sort_key(self):
186
- """
187
- Used to sort PackedNode children of SymbolNodes.
188
- A SymbolNode has multiple PackedNodes if it matched
189
- ambiguously. Hence, we use the sort order to identify
190
- the order in which ambiguous children should be considered.
191
- """
192
- return self.is_empty, -self.priority, self.rule.order
193
-
194
- @property
195
- def children(self):
196
- """Returns a list of this node's children."""
197
- return [x for x in [self.left, self.right] if x is not None]
198
-
199
- def __iter__(self):
200
- yield self.left
201
- yield self.right
202
-
203
- def __eq__(self, other):
204
- if not isinstance(other, PackedNode):
205
- return False
206
- return self is other or (self.left == other.left and self.right == other.right)
207
-
208
- def __hash__(self):
209
- return self._hash
210
-
211
- def __repr__(self):
212
- if isinstance(self.s, tuple):
213
- rule = self.s[0]
214
- ptr = self.s[1]
215
- before = (expansion.name for expansion in rule.expansion[:ptr])
216
- after = (expansion.name for expansion in rule.expansion[ptr:])
217
- symbol = "{} ::= {}* {}".format(
218
- rule.origin.name, " ".join(before), " ".join(after)
219
- )
220
- else:
221
- symbol = self.s.name
222
- return "({}, {}, {}, {})".format(
223
- symbol, self.start, self.priority, self.rule.order
224
- )
225
-
226
-
227
- class TokenNode(ForestNode):
228
- """
229
- A Token Node represents a matched terminal and is always a leaf node.
230
-
231
- Parameters:
232
- token: The Token associated with this node.
233
- term: The TerminalDef matched by the token.
234
- priority: The priority of this node.
235
- """
236
-
237
- __slots__ = ("token", "term", "priority", "_hash")
238
-
239
- def __init__(self, token, term, priority=None):
240
- self.token = token
241
- self.term = term
242
- if priority is not None:
243
- self.priority = priority
244
- else:
245
- self.priority = term.priority if term is not None else 0
246
- self._hash = hash(token)
247
-
248
- def __eq__(self, other):
249
- if not isinstance(other, TokenNode):
250
- return False
251
- return self is other or (self.token == other.token)
252
-
253
- def __hash__(self):
254
- return self._hash
255
-
256
- def __repr__(self):
257
- return repr(self.token)
258
-
259
-
260
- class ForestVisitor:
261
- """
262
- An abstract base class for building forest visitors.
263
-
264
- This class performs a controllable depth-first walk of an SPPF.
265
- The visitor will not enter cycles and will backtrack if one is encountered.
266
- Subclasses are notified of cycles through the ``on_cycle`` method.
267
-
268
- Behavior for visit events is defined by overriding the
269
- ``visit*node*`` functions.
270
-
271
- The walk is controlled by the return values of the ``visit*node_in``
272
- methods. Returning a node(s) will schedule them to be visited. The visitor
273
- will begin to backtrack if no nodes are returned.
274
-
275
- Parameters:
276
- single_visit: If ``True``, non-Token nodes will only be visited once.
277
- """
278
-
279
- def __init__(self, single_visit=False):
280
- self.single_visit = single_visit
281
-
282
- def visit_token_node(self, node):
283
- """Called when a ``Token`` is visited. ``Token`` nodes are always leaves."""
284
- pass
285
-
286
- def visit_symbol_node_in(self, node):
287
- """Called when a symbol node is visited. Nodes that are returned
288
- will be scheduled to be visited. If ``visit_intermediate_node_in``
289
- is not implemented, this function will be called for intermediate
290
- nodes as well."""
291
- pass
292
-
293
- def visit_symbol_node_out(self, node):
294
- """Called after all nodes returned from a corresponding ``visit_symbol_node_in``
295
- call have been visited. If ``visit_intermediate_node_out``
296
- is not implemented, this function will be called for intermediate
297
- nodes as well."""
298
- pass
299
-
300
- def visit_packed_node_in(self, node):
301
- """Called when a packed node is visited. Nodes that are returned
302
- will be scheduled to be visited."""
303
- pass
304
-
305
- def visit_packed_node_out(self, node):
306
- """Called after all nodes returned from a corresponding ``visit_packed_node_in``
307
- call have been visited."""
308
- pass
309
-
310
- def on_cycle(self, node, path):
311
- """Called when a cycle is encountered.
312
-
313
- Parameters:
314
- node: The node that causes a cycle.
315
- path: The list of nodes being visited: nodes that have been
316
- entered but not exited. The first element is the root in a forest
317
- visit, and the last element is the node visited most recently.
318
- ``path`` should be treated as read-only.
319
- """
320
- pass
321
-
322
- def get_cycle_in_path(self, node, path):
323
- """A utility function for use in ``on_cycle`` to obtain a slice of
324
- ``path`` that only contains the nodes that make up the cycle."""
325
- index = len(path) - 1
326
- while id(path[index]) != id(node):
327
- index -= 1
328
- return path[index:]
329
-
330
- def visit(self, root):
331
- # Visiting is a list of IDs of all symbol/intermediate nodes currently in
332
- # the stack. It serves two purposes: to detect when we 'recurse' in and out
333
- # of a symbol/intermediate so that we can process both up and down. Also,
334
- # since the SPPF can have cycles it allows us to detect if we're trying
335
- # to recurse into a node that's already on the stack (infinite recursion).
336
- visiting = set()
337
-
338
- # set of all nodes that have been visited
339
- visited = set()
340
-
341
- # a list of nodes that are currently being visited
342
- # used for the `on_cycle` callback
343
- path = []
344
-
345
- # We do not use recursion here to walk the Forest due to the limited
346
- # stack size in python. Therefore input_stack is essentially our stack.
347
- input_stack = deque([root])
348
-
349
- # It is much faster to cache these as locals since they are called
350
- # many times in large parses.
351
- vpno = getattr(self, "visit_packed_node_out")
352
- vpni = getattr(self, "visit_packed_node_in")
353
- vsno = getattr(self, "visit_symbol_node_out")
354
- vsni = getattr(self, "visit_symbol_node_in")
355
- vino = getattr(self, "visit_intermediate_node_out", vsno)
356
- vini = getattr(self, "visit_intermediate_node_in", vsni)
357
- vtn = getattr(self, "visit_token_node")
358
- oc = getattr(self, "on_cycle")
359
-
360
- while input_stack:
361
- current = next(reversed(input_stack))
362
- try:
363
- next_node = next(current)
364
- except StopIteration:
365
- input_stack.pop()
366
- continue
367
- except TypeError:
368
- ### If the current object is not an iterator, pass through to Token/SymbolNode
369
- pass
370
- else:
371
- if next_node is None:
372
- continue
373
-
374
- if id(next_node) in visiting:
375
- oc(next_node, path)
376
- continue
377
-
378
- input_stack.append(next_node)
379
- continue
380
-
381
- if isinstance(current, TokenNode):
382
- vtn(current.token)
383
- input_stack.pop()
384
- continue
385
-
386
- current_id = id(current)
387
- if current_id in visiting:
388
- if isinstance(current, PackedNode):
389
- vpno(current)
390
- elif current.is_intermediate:
391
- vino(current)
392
- else:
393
- vsno(current)
394
- input_stack.pop()
395
- path.pop()
396
- visiting.remove(current_id)
397
- visited.add(current_id)
398
- elif self.single_visit and current_id in visited:
399
- input_stack.pop()
400
- else:
401
- visiting.add(current_id)
402
- path.append(current)
403
- if isinstance(current, PackedNode):
404
- next_node = vpni(current)
405
- elif current.is_intermediate:
406
- next_node = vini(current)
407
- else:
408
- next_node = vsni(current)
409
- if next_node is None:
410
- continue
411
-
412
- if not isinstance(next_node, ForestNode):
413
- next_node = iter(next_node)
414
- elif id(next_node) in visiting:
415
- oc(next_node, path)
416
- continue
417
-
418
- input_stack.append(next_node)
419
-
420
-
421
- class ForestTransformer(ForestVisitor):
422
- """The base class for a bottom-up forest transformation. Most users will
423
- want to use ``TreeForestTransformer`` instead as it has a friendlier
424
- interface and covers most use cases.
425
-
426
- Transformations are applied via inheritance and overriding of the
427
- ``transform*node`` methods.
428
-
429
- ``transform_token_node`` receives a ``Token`` as an argument.
430
- All other methods receive the node that is being transformed and
431
- a list of the results of the transformations of that node's children.
432
- The return value of these methods are the resulting transformations.
433
-
434
- If ``Discard`` is raised in a node's transformation, no data from that node
435
- will be passed to its parent's transformation.
436
- """
437
-
438
- def __init__(self):
439
- super(ForestTransformer, self).__init__()
440
- # results of transformations
441
- self.data = dict()
442
- # used to track parent nodes
443
- self.node_stack = deque()
444
-
445
- def transform(self, root):
446
- """Perform a transformation on an SPPF."""
447
- self.node_stack.append("result")
448
- self.data["result"] = []
449
- self.visit(root)
450
- assert len(self.data["result"]) <= 1
451
- if self.data["result"]:
452
- return self.data["result"][0]
453
-
454
- def transform_symbol_node(self, node, data):
455
- """Transform a symbol node."""
456
- return node
457
-
458
- def transform_intermediate_node(self, node, data):
459
- """Transform an intermediate node."""
460
- return node
461
-
462
- def transform_packed_node(self, node, data):
463
- """Transform a packed node."""
464
- return node
465
-
466
- def transform_token_node(self, node):
467
- """Transform a ``Token``."""
468
- return node
469
-
470
- def visit_symbol_node_in(self, node):
471
- self.node_stack.append(id(node))
472
- self.data[id(node)] = []
473
- return node.children
474
-
475
- def visit_packed_node_in(self, node):
476
- self.node_stack.append(id(node))
477
- self.data[id(node)] = []
478
- return node.children
479
-
480
- def visit_token_node(self, node):
481
- transformed = self.transform_token_node(node)
482
- if transformed is not Discard:
483
- self.data[self.node_stack[-1]].append(transformed)
484
-
485
- def _visit_node_out_helper(self, node, method):
486
- self.node_stack.pop()
487
- transformed = method(node, self.data[id(node)])
488
- if transformed is not Discard:
489
- self.data[self.node_stack[-1]].append(transformed)
490
- del self.data[id(node)]
491
-
492
- def visit_symbol_node_out(self, node):
493
- self._visit_node_out_helper(node, self.transform_symbol_node)
494
-
495
- def visit_intermediate_node_out(self, node):
496
- self._visit_node_out_helper(node, self.transform_intermediate_node)
497
-
498
- def visit_packed_node_out(self, node):
499
- self._visit_node_out_helper(node, self.transform_packed_node)
500
-
501
-
502
- class ForestSumVisitor(ForestVisitor):
503
- """
504
- A visitor for prioritizing ambiguous parts of the Forest.
505
-
506
- This visitor is used when support for explicit priorities on
507
- rules is requested (whether normal, or invert). It walks the
508
- forest (or subsets thereof) and cascades properties upwards
509
- from the leaves.
510
-
511
- It would be ideal to do this during parsing, however this would
512
- require processing each Earley item multiple times. That's
513
- a big performance drawback; so running a forest walk is the
514
- lesser of two evils: there can be significantly more Earley
515
- items created during parsing than there are SPPF nodes in the
516
- final tree.
517
- """
518
-
519
- def __init__(self):
520
- super(ForestSumVisitor, self).__init__(single_visit=True)
521
-
522
- def visit_packed_node_in(self, node):
523
- yield node.left
524
- yield node.right
525
-
526
- def visit_symbol_node_in(self, node):
527
- return iter(node.children)
528
-
529
- def visit_packed_node_out(self, node):
530
- priority = (
531
- node.rule.options.priority
532
- if not node.parent.is_intermediate and node.rule.options.priority
533
- else 0
534
- )
535
- priority += getattr(node.right, "priority", 0)
536
- priority += getattr(node.left, "priority", 0)
537
- node.priority = priority
538
-
539
- def visit_symbol_node_out(self, node):
540
- node.priority = max(child.priority for child in node.children)
541
-
542
-
543
- class PackedData:
544
- """Used in transformationss of packed nodes to distinguish the data
545
- that comes from the left child and the right child.
546
- """
547
-
548
- class _NoData:
549
- pass
550
-
551
- NO_DATA = _NoData()
552
-
553
- def __init__(self, node, data):
554
- self.left = self.NO_DATA
555
- self.right = self.NO_DATA
556
- if data:
557
- if node.left is not None:
558
- self.left = data[0]
559
- if len(data) > 1:
560
- self.right = data[1]
561
- else:
562
- self.right = data[0]
563
-
564
-
565
- class ForestToParseTree(ForestTransformer):
566
- """Used by the earley parser when ambiguity equals 'resolve' or
567
- 'explicit'. Transforms an SPPF into an (ambiguous) parse tree.
568
-
569
- Parameters:
570
- tree_class: The tree class to use for construction
571
- callbacks: A dictionary of rules to functions that output a tree
572
- prioritizer: A ``ForestVisitor`` that manipulates the priorities of ForestNodes
573
- resolve_ambiguity: If True, ambiguities will be resolved based on
574
- priorities. Otherwise, `_ambig` nodes will be in the resulting tree.
575
- use_cache: If True, the results of packed node transformations will be cached.
576
- """
577
-
578
- def __init__(
579
- self,
580
- tree_class=Tree,
581
- callbacks=dict(),
582
- prioritizer=ForestSumVisitor(),
583
- resolve_ambiguity=True,
584
- use_cache=True,
585
- ):
586
- super(ForestToParseTree, self).__init__()
587
- self.tree_class = tree_class
588
- self.callbacks = callbacks
589
- self.prioritizer = prioritizer
590
- self.resolve_ambiguity = resolve_ambiguity
591
- self._use_cache = use_cache
592
- self._cache = {}
593
- self._on_cycle_retreat = False
594
- self._cycle_node = None
595
- self._successful_visits = set()
596
-
597
- def visit(self, root):
598
- if self.prioritizer:
599
- self.prioritizer.visit(root)
600
- super(ForestToParseTree, self).visit(root)
601
- self._cache = {}
602
-
603
- def on_cycle(self, node, path):
604
- logger.debug(
605
- "Cycle encountered in the SPPF at node: %s. "
606
- "As infinite ambiguities cannot be represented in a tree, "
607
- "this family of derivations will be discarded.",
608
- node,
609
- )
610
- self._cycle_node = node
611
- self._on_cycle_retreat = True
612
-
613
- def _check_cycle(self, node):
614
- if self._on_cycle_retreat:
615
- if id(node) == id(self._cycle_node) or id(node) in self._successful_visits:
616
- self._cycle_node = None
617
- self._on_cycle_retreat = False
618
- else:
619
- return Discard
620
-
621
- def _collapse_ambig(self, children):
622
- new_children = []
623
- for child in children:
624
- if hasattr(child, "data") and child.data == "_ambig":
625
- new_children += child.children
626
- else:
627
- new_children.append(child)
628
- return new_children
629
-
630
- def _call_rule_func(self, node, data):
631
- # called when transforming children of symbol nodes
632
- # data is a list of trees or tokens that correspond to the
633
- # symbol's rule expansion
634
- return self.callbacks[node.rule](data)
635
-
636
- def _call_ambig_func(self, node, data):
637
- # called when transforming a symbol node
638
- # data is a list of trees where each tree's data is
639
- # equal to the name of the symbol or one of its aliases.
640
- if len(data) > 1:
641
- return self.tree_class("_ambig", data)
642
- elif data:
643
- return data[0]
644
- return Discard
645
-
646
- def transform_symbol_node(self, node, data):
647
- if id(node) not in self._successful_visits:
648
- return Discard
649
- r = self._check_cycle(node)
650
- if r is Discard:
651
- return r
652
- self._successful_visits.remove(id(node))
653
- data = self._collapse_ambig(data)
654
- return self._call_ambig_func(node, data)
655
-
656
- def transform_intermediate_node(self, node, data):
657
- if id(node) not in self._successful_visits:
658
- return Discard
659
- r = self._check_cycle(node)
660
- if r is Discard:
661
- return r
662
- self._successful_visits.remove(id(node))
663
- if len(data) > 1:
664
- children = [self.tree_class("_inter", c) for c in data]
665
- return self.tree_class("_iambig", children)
666
- return data[0]
667
-
668
- def transform_packed_node(self, node, data):
669
- r = self._check_cycle(node)
670
- if r is Discard:
671
- return r
672
- if self.resolve_ambiguity and id(node.parent) in self._successful_visits:
673
- return Discard
674
- if self._use_cache and id(node) in self._cache:
675
- return self._cache[id(node)]
676
- children = []
677
- assert len(data) <= 2
678
- data = PackedData(node, data)
679
- if data.left is not PackedData.NO_DATA:
680
- if node.left.is_intermediate and isinstance(data.left, list):
681
- children += data.left
682
- else:
683
- children.append(data.left)
684
- if data.right is not PackedData.NO_DATA:
685
- children.append(data.right)
686
- if node.parent.is_intermediate:
687
- return self._cache.setdefault(id(node), children)
688
- return self._cache.setdefault(id(node), self._call_rule_func(node, children))
689
-
690
- def visit_symbol_node_in(self, node):
691
- super(ForestToParseTree, self).visit_symbol_node_in(node)
692
- if self._on_cycle_retreat:
693
- return
694
- return node.children
695
-
696
- def visit_packed_node_in(self, node):
697
- self._on_cycle_retreat = False
698
- to_visit = super(ForestToParseTree, self).visit_packed_node_in(node)
699
- if not self.resolve_ambiguity or id(node.parent) not in self._successful_visits:
700
- if not self._use_cache or id(node) not in self._cache:
701
- return to_visit
702
-
703
- def visit_packed_node_out(self, node):
704
- super(ForestToParseTree, self).visit_packed_node_out(node)
705
- if not self._on_cycle_retreat:
706
- self._successful_visits.add(id(node.parent))
707
-
708
-
709
- def handles_ambiguity(func):
710
- """Decorator for methods of subclasses of ``TreeForestTransformer``.
711
- Denotes that the method should receive a list of transformed derivations."""
712
- func.handles_ambiguity = True
713
- return func
714
-
715
-
716
- class TreeForestTransformer(ForestToParseTree):
717
- """A ``ForestTransformer`` with a tree ``Transformer``-like interface.
718
- By default, it will construct a tree.
719
-
720
- Methods provided via inheritance are called based on the rule/symbol
721
- names of nodes in the forest.
722
-
723
- Methods that act on rules will receive a list of the results of the
724
- transformations of the rule's children. By default, trees and tokens.
725
-
726
- Methods that act on tokens will receive a token.
727
-
728
- Alternatively, methods that act on rules may be annotated with
729
- ``handles_ambiguity``. In this case, the function will receive a list
730
- of all the transformations of all the derivations of the rule.
731
- By default, a list of trees where each tree.data is equal to the
732
- rule name or one of its aliases.
733
-
734
- Non-tree transformations are made possible by override of
735
- ``__default__``, ``__default_token__``, and ``__default_ambig__``.
736
-
737
- Note:
738
- Tree shaping features such as inlined rules and token filtering are
739
- not built into the transformation. Positions are also not propagated.
740
-
741
- Parameters:
742
- tree_class: The tree class to use for construction
743
- prioritizer: A ``ForestVisitor`` that manipulates the priorities of nodes in the SPPF.
744
- resolve_ambiguity: If True, ambiguities will be resolved based on priorities.
745
- use_cache (bool): If True, caches the results of some transformations,
746
- potentially improving performance when ``resolve_ambiguity==False``.
747
- Only use if you know what you are doing: i.e. All transformation
748
- functions are pure and referentially transparent.
749
- """
750
-
751
- def __init__(
752
- self,
753
- tree_class=Tree,
754
- prioritizer=ForestSumVisitor(),
755
- resolve_ambiguity=True,
756
- use_cache=False,
757
- ):
758
- super(TreeForestTransformer, self).__init__(
759
- tree_class, dict(), prioritizer, resolve_ambiguity, use_cache
760
- )
761
-
762
- def __default__(self, name, data):
763
- """Default operation on tree (for override).
764
-
765
- Returns a tree with name with data as children.
766
- """
767
- return self.tree_class(name, data)
768
-
769
- def __default_ambig__(self, name, data):
770
- """Default operation on ambiguous rule (for override).
771
-
772
- Wraps data in an '_ambig_' node if it contains more than
773
- one element.
774
- """
775
- if len(data) > 1:
776
- return self.tree_class("_ambig", data)
777
- elif data:
778
- return data[0]
779
- return Discard
780
-
781
- def __default_token__(self, node):
782
- """Default operation on ``Token`` (for override).
783
-
784
- Returns ``node``.
785
- """
786
- return node
787
-
788
- def transform_token_node(self, node):
789
- return getattr(self, node.type, self.__default_token__)(node)
790
-
791
- def _call_rule_func(self, node, data):
792
- name = (
793
- node.rule.alias
794
- or node.rule.options.template_source
795
- or node.rule.origin.name
796
- )
797
- user_func = getattr(self, name, self.__default__)
798
- if user_func == self.__default__ or hasattr(user_func, "handles_ambiguity"):
799
- user_func = partial(self.__default__, name)
800
- if not self.resolve_ambiguity:
801
- wrapper = partial(AmbiguousIntermediateExpander, self.tree_class)
802
- user_func = wrapper(user_func)
803
- return user_func(data)
804
-
805
- def _call_ambig_func(self, node, data):
806
- name = node.s.name
807
- user_func = getattr(self, name, self.__default_ambig__)
808
- if user_func == self.__default_ambig__ or not hasattr(
809
- user_func, "handles_ambiguity"
810
- ):
811
- user_func = partial(self.__default_ambig__, name)
812
- return user_func(data)
813
-
814
-
815
- class ForestToPyDotVisitor(ForestVisitor):
816
- """
817
- A Forest visitor which writes the SPPF to a PNG.
818
-
819
- The SPPF can get really large, really quickly because
820
- of the amount of meta-data it stores, so this is probably
821
- only useful for trivial trees and learning how the SPPF
822
- is structured.
823
- """
824
-
825
- def __init__(self, rankdir="TB"):
826
- super(ForestToPyDotVisitor, self).__init__(single_visit=True)
827
- self.pydot = import_module("pydot")
828
- self.graph = self.pydot.Dot(graph_type="digraph", rankdir=rankdir)
829
-
830
- def visit(self, root, filename):
831
- super(ForestToPyDotVisitor, self).visit(root)
832
- try:
833
- self.graph.write_png(filename)
834
- except FileNotFoundError as e:
835
- logger.error("Could not write png: ", e)
836
-
837
- def visit_token_node(self, node):
838
- graph_node_id = str(id(node))
839
- graph_node_label = '"{}"'.format(node.value.replace('"', '\\"'))
840
- graph_node_color = 0x808080
841
- graph_node_style = '"filled,rounded"'
842
- graph_node_shape = "diamond"
843
- graph_node = self.pydot.Node(
844
- graph_node_id,
845
- style=graph_node_style,
846
- fillcolor="#{:06x}".format(graph_node_color),
847
- shape=graph_node_shape,
848
- label=graph_node_label,
849
- )
850
- self.graph.add_node(graph_node)
851
-
852
- def visit_packed_node_in(self, node):
853
- graph_node_id = str(id(node))
854
- graph_node_label = repr(node)
855
- graph_node_color = 0x808080
856
- graph_node_style = "filled"
857
- graph_node_shape = "diamond"
858
- graph_node = self.pydot.Node(
859
- graph_node_id,
860
- style=graph_node_style,
861
- fillcolor="#{:06x}".format(graph_node_color),
862
- shape=graph_node_shape,
863
- label=graph_node_label,
864
- )
865
- self.graph.add_node(graph_node)
866
- yield node.left
867
- yield node.right
868
-
869
- def visit_packed_node_out(self, node):
870
- graph_node_id = str(id(node))
871
- graph_node = self.graph.get_node(graph_node_id)[0]
872
- for child in [node.left, node.right]:
873
- if child is not None:
874
- child_graph_node_id = str(
875
- id(child.token if isinstance(child, TokenNode) else child)
876
- )
877
- child_graph_node = self.graph.get_node(child_graph_node_id)[0]
878
- self.graph.add_edge(self.pydot.Edge(graph_node, child_graph_node))
879
- else:
880
- #### Try and be above the Python object ID range; probably impl. specific, but maybe this is okay.
881
- child_graph_node_id = str(
882
- randint(
883
- 100000000000000000000000000000, 123456789012345678901234567890
884
- )
885
- )
886
- child_graph_node_style = "invis"
887
- child_graph_node = self.pydot.Node(
888
- child_graph_node_id, style=child_graph_node_style, label="None"
889
- )
890
- child_edge_style = "invis"
891
- self.graph.add_node(child_graph_node)
892
- self.graph.add_edge(
893
- self.pydot.Edge(
894
- graph_node, child_graph_node, style=child_edge_style
895
- )
896
- )
897
-
898
- def visit_symbol_node_in(self, node):
899
- graph_node_id = str(id(node))
900
- graph_node_label = repr(node)
901
- graph_node_color = 0x808080
902
- graph_node_style = '"filled"'
903
- if node.is_intermediate:
904
- graph_node_shape = "ellipse"
905
- else:
906
- graph_node_shape = "rectangle"
907
- graph_node = self.pydot.Node(
908
- graph_node_id,
909
- style=graph_node_style,
910
- fillcolor="#{:06x}".format(graph_node_color),
911
- shape=graph_node_shape,
912
- label=graph_node_label,
913
- )
914
- self.graph.add_node(graph_node)
915
- return iter(node.children)
916
-
917
- def visit_symbol_node_out(self, node):
918
- graph_node_id = str(id(node))
919
- graph_node = self.graph.get_node(graph_node_id)[0]
920
- for child in node.children:
921
- child_graph_node_id = str(id(child))
922
- child_graph_node = self.graph.get_node(child_graph_node_id)[0]
923
- self.graph.add_edge(self.pydot.Edge(graph_node, child_graph_node))
1
+ """"This module implements an SPPF implementation
2
+
3
+ This is used as the primary output mechanism for the Earley parser
4
+ in order to store complex ambiguities.
5
+
6
+ Full reference and more details is here:
7
+ https://web.archive.org/web/20190616123959/http://www.bramvandersanden.com/post/2014/06/shared-packed-parse-forest/
8
+ """
9
+
10
+ from typing import Type, AbstractSet
11
+ from random import randint
12
+ from collections import deque
13
+ from operator import attrgetter
14
+ from importlib import import_module
15
+ from functools import partial
16
+
17
+ from ..parse_tree_builder import AmbiguousIntermediateExpander
18
+ from ..visitors import Discard
19
+ from ..utils import logger, OrderedSet
20
+ from ..tree import Tree
21
+
22
+ class ForestNode:
23
+ pass
24
+
25
+ class SymbolNode(ForestNode):
26
+ """
27
+ A Symbol Node represents a symbol (or Intermediate LR0).
28
+
29
+ Symbol nodes are keyed by the symbol (s). For intermediate nodes
30
+ s will be an LR0, stored as a tuple of (rule, ptr). For completed symbol
31
+ nodes, s will be a string representing the non-terminal origin (i.e.
32
+ the left hand side of the rule).
33
+
34
+ The children of a Symbol or Intermediate Node will always be Packed Nodes;
35
+ with each Packed Node child representing a single derivation of a production.
36
+
37
+ Hence a Symbol Node with a single child is unambiguous.
38
+
39
+ Parameters:
40
+ s: A Symbol, or a tuple of (rule, ptr) for an intermediate node.
41
+ start: The index of the start of the substring matched by this symbol (inclusive).
42
+ end: The index of the end of the substring matched by this symbol (exclusive).
43
+
44
+ Properties:
45
+ is_intermediate: True if this node is an intermediate node.
46
+ priority: The priority of the node's symbol.
47
+ """
48
+ Set: Type[AbstractSet] = set # Overridden by StableSymbolNode
49
+ __slots__ = ('s', 'start', 'end', '_children', 'paths', 'paths_loaded', 'priority', 'is_intermediate', '_hash')
50
+ def __init__(self, s, start, end):
51
+ self.s = s
52
+ self.start = start
53
+ self.end = end
54
+ self._children = self.Set()
55
+ self.paths = self.Set()
56
+ self.paths_loaded = False
57
+
58
+ ### We use inf here as it can be safely negated without resorting to conditionals,
59
+ # unlike None or float('NaN'), and sorts appropriately.
60
+ self.priority = float('-inf')
61
+ self.is_intermediate = isinstance(s, tuple)
62
+ self._hash = hash((self.s, self.start, self.end))
63
+
64
+ def add_family(self, lr0, rule, start, left, right):
65
+ self._children.add(PackedNode(self, lr0, rule, start, left, right))
66
+
67
+ def add_path(self, transitive, node):
68
+ self.paths.add((transitive, node))
69
+
70
+ def load_paths(self):
71
+ for transitive, node in self.paths:
72
+ if transitive.next_titem is not None:
73
+ vn = type(self)(transitive.next_titem.s, transitive.next_titem.start, self.end)
74
+ vn.add_path(transitive.next_titem, node)
75
+ self.add_family(transitive.reduction.rule.origin, transitive.reduction.rule, transitive.reduction.start, transitive.reduction.node, vn)
76
+ else:
77
+ self.add_family(transitive.reduction.rule.origin, transitive.reduction.rule, transitive.reduction.start, transitive.reduction.node, node)
78
+ self.paths_loaded = True
79
+
80
+ @property
81
+ def is_ambiguous(self):
82
+ """Returns True if this node is ambiguous."""
83
+ return len(self.children) > 1
84
+
85
+ @property
86
+ def children(self):
87
+ """Returns a list of this node's children sorted from greatest to
88
+ least priority."""
89
+ if not self.paths_loaded:
90
+ self.load_paths()
91
+ return sorted(self._children, key=attrgetter('sort_key'))
92
+
93
+ def __iter__(self):
94
+ return iter(self._children)
95
+
96
+ def __eq__(self, other):
97
+ if not isinstance(other, SymbolNode):
98
+ return False
99
+ return self is other or (type(self.s) == type(other.s) and self.s == other.s and self.start == other.start and self.end is other.end)
100
+
101
+ def __hash__(self):
102
+ return self._hash
103
+
104
+ def __repr__(self):
105
+ if self.is_intermediate:
106
+ rule = self.s[0]
107
+ ptr = self.s[1]
108
+ before = ( expansion.name for expansion in rule.expansion[:ptr] )
109
+ after = ( expansion.name for expansion in rule.expansion[ptr:] )
110
+ symbol = "{} ::= {}* {}".format(rule.origin.name, ' '.join(before), ' '.join(after))
111
+ else:
112
+ symbol = self.s.name
113
+ return "({}, {}, {}, {})".format(symbol, self.start, self.end, self.priority)
114
+
115
+ class StableSymbolNode(SymbolNode):
116
+ "A version of SymbolNode that uses OrderedSet for output stability"
117
+ Set = OrderedSet
118
+
119
+ class PackedNode(ForestNode):
120
+ """
121
+ A Packed Node represents a single derivation in a symbol node.
122
+
123
+ Parameters:
124
+ rule: The rule associated with this node.
125
+ parent: The parent of this node.
126
+ left: The left child of this node. ``None`` if one does not exist.
127
+ right: The right child of this node. ``None`` if one does not exist.
128
+ priority: The priority of this node.
129
+ """
130
+ __slots__ = ('parent', 's', 'rule', 'start', 'left', 'right', 'priority', '_hash')
131
+ def __init__(self, parent, s, rule, start, left, right):
132
+ self.parent = parent
133
+ self.s = s
134
+ self.start = start
135
+ self.rule = rule
136
+ self.left = left
137
+ self.right = right
138
+ self.priority = float('-inf')
139
+ self._hash = hash((self.left, self.right))
140
+
141
+ @property
142
+ def is_empty(self):
143
+ return self.left is None and self.right is None
144
+
145
+ @property
146
+ def sort_key(self):
147
+ """
148
+ Used to sort PackedNode children of SymbolNodes.
149
+ A SymbolNode has multiple PackedNodes if it matched
150
+ ambiguously. Hence, we use the sort order to identify
151
+ the order in which ambiguous children should be considered.
152
+ """
153
+ return self.is_empty, -self.priority, self.rule.order
154
+
155
+ @property
156
+ def children(self):
157
+ """Returns a list of this node's children."""
158
+ return [x for x in [self.left, self.right] if x is not None]
159
+
160
+ def __iter__(self):
161
+ yield self.left
162
+ yield self.right
163
+
164
+ def __eq__(self, other):
165
+ if not isinstance(other, PackedNode):
166
+ return False
167
+ return self is other or (self.left == other.left and self.right == other.right)
168
+
169
+ def __hash__(self):
170
+ return self._hash
171
+
172
+ def __repr__(self):
173
+ if isinstance(self.s, tuple):
174
+ rule = self.s[0]
175
+ ptr = self.s[1]
176
+ before = ( expansion.name for expansion in rule.expansion[:ptr] )
177
+ after = ( expansion.name for expansion in rule.expansion[ptr:] )
178
+ symbol = "{} ::= {}* {}".format(rule.origin.name, ' '.join(before), ' '.join(after))
179
+ else:
180
+ symbol = self.s.name
181
+ return "({}, {}, {}, {})".format(symbol, self.start, self.priority, self.rule.order)
182
+
183
+ class TokenNode(ForestNode):
184
+ """
185
+ A Token Node represents a matched terminal and is always a leaf node.
186
+
187
+ Parameters:
188
+ token: The Token associated with this node.
189
+ term: The TerminalDef matched by the token.
190
+ priority: The priority of this node.
191
+ """
192
+ __slots__ = ('token', 'term', 'priority', '_hash')
193
+ def __init__(self, token, term, priority=None):
194
+ self.token = token
195
+ self.term = term
196
+ if priority is not None:
197
+ self.priority = priority
198
+ else:
199
+ self.priority = term.priority if term is not None else 0
200
+ self._hash = hash(token)
201
+
202
+ def __eq__(self, other):
203
+ if not isinstance(other, TokenNode):
204
+ return False
205
+ return self is other or (self.token == other.token)
206
+
207
+ def __hash__(self):
208
+ return self._hash
209
+
210
+ def __repr__(self):
211
+ return repr(self.token)
212
+
213
+ class ForestVisitor:
214
+ """
215
+ An abstract base class for building forest visitors.
216
+
217
+ This class performs a controllable depth-first walk of an SPPF.
218
+ The visitor will not enter cycles and will backtrack if one is encountered.
219
+ Subclasses are notified of cycles through the ``on_cycle`` method.
220
+
221
+ Behavior for visit events is defined by overriding the
222
+ ``visit*node*`` functions.
223
+
224
+ The walk is controlled by the return values of the ``visit*node_in``
225
+ methods. Returning a node(s) will schedule them to be visited. The visitor
226
+ will begin to backtrack if no nodes are returned.
227
+
228
+ Parameters:
229
+ single_visit: If ``True``, non-Token nodes will only be visited once.
230
+ """
231
+
232
+ def __init__(self, single_visit=False):
233
+ self.single_visit = single_visit
234
+
235
+ def visit_token_node(self, node):
236
+ """Called when a ``Token`` is visited. ``Token`` nodes are always leaves."""
237
+ pass
238
+
239
+ def visit_symbol_node_in(self, node):
240
+ """Called when a symbol node is visited. Nodes that are returned
241
+ will be scheduled to be visited. If ``visit_intermediate_node_in``
242
+ is not implemented, this function will be called for intermediate
243
+ nodes as well."""
244
+ pass
245
+
246
+ def visit_symbol_node_out(self, node):
247
+ """Called after all nodes returned from a corresponding ``visit_symbol_node_in``
248
+ call have been visited. If ``visit_intermediate_node_out``
249
+ is not implemented, this function will be called for intermediate
250
+ nodes as well."""
251
+ pass
252
+
253
+ def visit_packed_node_in(self, node):
254
+ """Called when a packed node is visited. Nodes that are returned
255
+ will be scheduled to be visited. """
256
+ pass
257
+
258
+ def visit_packed_node_out(self, node):
259
+ """Called after all nodes returned from a corresponding ``visit_packed_node_in``
260
+ call have been visited."""
261
+ pass
262
+
263
+ def on_cycle(self, node, path):
264
+ """Called when a cycle is encountered.
265
+
266
+ Parameters:
267
+ node: The node that causes a cycle.
268
+ path: The list of nodes being visited: nodes that have been
269
+ entered but not exited. The first element is the root in a forest
270
+ visit, and the last element is the node visited most recently.
271
+ ``path`` should be treated as read-only.
272
+ """
273
+ pass
274
+
275
+ def get_cycle_in_path(self, node, path):
276
+ """A utility function for use in ``on_cycle`` to obtain a slice of
277
+ ``path`` that only contains the nodes that make up the cycle."""
278
+ index = len(path) - 1
279
+ while id(path[index]) != id(node):
280
+ index -= 1
281
+ return path[index:]
282
+
283
+ def visit(self, root):
284
+ # Visiting is a list of IDs of all symbol/intermediate nodes currently in
285
+ # the stack. It serves two purposes: to detect when we 'recurse' in and out
286
+ # of a symbol/intermediate so that we can process both up and down. Also,
287
+ # since the SPPF can have cycles it allows us to detect if we're trying
288
+ # to recurse into a node that's already on the stack (infinite recursion).
289
+ visiting = set()
290
+
291
+ # set of all nodes that have been visited
292
+ visited = set()
293
+
294
+ # a list of nodes that are currently being visited
295
+ # used for the `on_cycle` callback
296
+ path = []
297
+
298
+ # We do not use recursion here to walk the Forest due to the limited
299
+ # stack size in python. Therefore input_stack is essentially our stack.
300
+ input_stack = deque([root])
301
+
302
+ # It is much faster to cache these as locals since they are called
303
+ # many times in large parses.
304
+ vpno = getattr(self, 'visit_packed_node_out')
305
+ vpni = getattr(self, 'visit_packed_node_in')
306
+ vsno = getattr(self, 'visit_symbol_node_out')
307
+ vsni = getattr(self, 'visit_symbol_node_in')
308
+ vino = getattr(self, 'visit_intermediate_node_out', vsno)
309
+ vini = getattr(self, 'visit_intermediate_node_in', vsni)
310
+ vtn = getattr(self, 'visit_token_node')
311
+ oc = getattr(self, 'on_cycle')
312
+
313
+ while input_stack:
314
+ current = next(reversed(input_stack))
315
+ try:
316
+ next_node = next(current)
317
+ except StopIteration:
318
+ input_stack.pop()
319
+ continue
320
+ except TypeError:
321
+ ### If the current object is not an iterator, pass through to Token/SymbolNode
322
+ pass
323
+ else:
324
+ if next_node is None:
325
+ continue
326
+
327
+ if id(next_node) in visiting:
328
+ oc(next_node, path)
329
+ continue
330
+
331
+ input_stack.append(next_node)
332
+ continue
333
+
334
+ if isinstance(current, TokenNode):
335
+ vtn(current.token)
336
+ input_stack.pop()
337
+ continue
338
+
339
+ current_id = id(current)
340
+ if current_id in visiting:
341
+ if isinstance(current, PackedNode):
342
+ vpno(current)
343
+ elif current.is_intermediate:
344
+ vino(current)
345
+ else:
346
+ vsno(current)
347
+ input_stack.pop()
348
+ path.pop()
349
+ visiting.remove(current_id)
350
+ visited.add(current_id)
351
+ elif self.single_visit and current_id in visited:
352
+ input_stack.pop()
353
+ else:
354
+ visiting.add(current_id)
355
+ path.append(current)
356
+ if isinstance(current, PackedNode):
357
+ next_node = vpni(current)
358
+ elif current.is_intermediate:
359
+ next_node = vini(current)
360
+ else:
361
+ next_node = vsni(current)
362
+ if next_node is None:
363
+ continue
364
+
365
+ if not isinstance(next_node, ForestNode):
366
+ next_node = iter(next_node)
367
+ elif id(next_node) in visiting:
368
+ oc(next_node, path)
369
+ continue
370
+
371
+ input_stack.append(next_node)
372
+
373
+ class ForestTransformer(ForestVisitor):
374
+ """The base class for a bottom-up forest transformation. Most users will
375
+ want to use ``TreeForestTransformer`` instead as it has a friendlier
376
+ interface and covers most use cases.
377
+
378
+ Transformations are applied via inheritance and overriding of the
379
+ ``transform*node`` methods.
380
+
381
+ ``transform_token_node`` receives a ``Token`` as an argument.
382
+ All other methods receive the node that is being transformed and
383
+ a list of the results of the transformations of that node's children.
384
+ The return value of these methods are the resulting transformations.
385
+
386
+ If ``Discard`` is raised in a node's transformation, no data from that node
387
+ will be passed to its parent's transformation.
388
+ """
389
+
390
+ def __init__(self):
391
+ super(ForestTransformer, self).__init__()
392
+ # results of transformations
393
+ self.data = dict()
394
+ # used to track parent nodes
395
+ self.node_stack = deque()
396
+
397
+ def transform(self, root):
398
+ """Perform a transformation on an SPPF."""
399
+ self.node_stack.append('result')
400
+ self.data['result'] = []
401
+ self.visit(root)
402
+ assert len(self.data['result']) <= 1
403
+ if self.data['result']:
404
+ return self.data['result'][0]
405
+
406
+ def transform_symbol_node(self, node, data):
407
+ """Transform a symbol node."""
408
+ return node
409
+
410
+ def transform_intermediate_node(self, node, data):
411
+ """Transform an intermediate node."""
412
+ return node
413
+
414
+ def transform_packed_node(self, node, data):
415
+ """Transform a packed node."""
416
+ return node
417
+
418
+ def transform_token_node(self, node):
419
+ """Transform a ``Token``."""
420
+ return node
421
+
422
+ def visit_symbol_node_in(self, node):
423
+ self.node_stack.append(id(node))
424
+ self.data[id(node)] = []
425
+ return node.children
426
+
427
+ def visit_packed_node_in(self, node):
428
+ self.node_stack.append(id(node))
429
+ self.data[id(node)] = []
430
+ return node.children
431
+
432
+ def visit_token_node(self, node):
433
+ transformed = self.transform_token_node(node)
434
+ if transformed is not Discard:
435
+ self.data[self.node_stack[-1]].append(transformed)
436
+
437
+ def _visit_node_out_helper(self, node, method):
438
+ self.node_stack.pop()
439
+ transformed = method(node, self.data[id(node)])
440
+ if transformed is not Discard:
441
+ self.data[self.node_stack[-1]].append(transformed)
442
+ del self.data[id(node)]
443
+
444
+ def visit_symbol_node_out(self, node):
445
+ self._visit_node_out_helper(node, self.transform_symbol_node)
446
+
447
+ def visit_intermediate_node_out(self, node):
448
+ self._visit_node_out_helper(node, self.transform_intermediate_node)
449
+
450
+ def visit_packed_node_out(self, node):
451
+ self._visit_node_out_helper(node, self.transform_packed_node)
452
+
453
+
454
+ class ForestSumVisitor(ForestVisitor):
455
+ """
456
+ A visitor for prioritizing ambiguous parts of the Forest.
457
+
458
+ This visitor is used when support for explicit priorities on
459
+ rules is requested (whether normal, or invert). It walks the
460
+ forest (or subsets thereof) and cascades properties upwards
461
+ from the leaves.
462
+
463
+ It would be ideal to do this during parsing, however this would
464
+ require processing each Earley item multiple times. That's
465
+ a big performance drawback; so running a forest walk is the
466
+ lesser of two evils: there can be significantly more Earley
467
+ items created during parsing than there are SPPF nodes in the
468
+ final tree.
469
+ """
470
+ def __init__(self):
471
+ super(ForestSumVisitor, self).__init__(single_visit=True)
472
+
473
+ def visit_packed_node_in(self, node):
474
+ yield node.left
475
+ yield node.right
476
+
477
+ def visit_symbol_node_in(self, node):
478
+ return iter(node.children)
479
+
480
+ def visit_packed_node_out(self, node):
481
+ priority = node.rule.options.priority if not node.parent.is_intermediate and node.rule.options.priority else 0
482
+ priority += getattr(node.right, 'priority', 0)
483
+ priority += getattr(node.left, 'priority', 0)
484
+ node.priority = priority
485
+
486
+ def visit_symbol_node_out(self, node):
487
+ node.priority = max(child.priority for child in node.children)
488
+
489
+ class PackedData():
490
+ """Used in transformationss of packed nodes to distinguish the data
491
+ that comes from the left child and the right child.
492
+ """
493
+
494
+ class _NoData():
495
+ pass
496
+
497
+ NO_DATA = _NoData()
498
+
499
+ def __init__(self, node, data):
500
+ self.left = self.NO_DATA
501
+ self.right = self.NO_DATA
502
+ if data:
503
+ if node.left is not None:
504
+ self.left = data[0]
505
+ if len(data) > 1:
506
+ self.right = data[1]
507
+ else:
508
+ self.right = data[0]
509
+
510
+ class ForestToParseTree(ForestTransformer):
511
+ """Used by the earley parser when ambiguity equals 'resolve' or
512
+ 'explicit'. Transforms an SPPF into an (ambiguous) parse tree.
513
+
514
+ Parameters:
515
+ tree_class: The tree class to use for construction
516
+ callbacks: A dictionary of rules to functions that output a tree
517
+ prioritizer: A ``ForestVisitor`` that manipulates the priorities of ForestNodes
518
+ resolve_ambiguity: If True, ambiguities will be resolved based on
519
+ priorities. Otherwise, `_ambig` nodes will be in the resulting tree.
520
+ use_cache: If True, the results of packed node transformations will be cached.
521
+ """
522
+
523
+ def __init__(self, tree_class=Tree, callbacks=dict(), prioritizer=ForestSumVisitor(), resolve_ambiguity=True, use_cache=True):
524
+ super(ForestToParseTree, self).__init__()
525
+ self.tree_class = tree_class
526
+ self.callbacks = callbacks
527
+ self.prioritizer = prioritizer
528
+ self.resolve_ambiguity = resolve_ambiguity
529
+ self._use_cache = use_cache
530
+ self._cache = {}
531
+ self._on_cycle_retreat = False
532
+ self._cycle_node = None
533
+ self._successful_visits = set()
534
+
535
+ def visit(self, root):
536
+ if self.prioritizer:
537
+ self.prioritizer.visit(root)
538
+ super(ForestToParseTree, self).visit(root)
539
+ self._cache = {}
540
+
541
+ def on_cycle(self, node, path):
542
+ logger.debug("Cycle encountered in the SPPF at node: %s. "
543
+ "As infinite ambiguities cannot be represented in a tree, "
544
+ "this family of derivations will be discarded.", node)
545
+ self._cycle_node = node
546
+ self._on_cycle_retreat = True
547
+
548
+ def _check_cycle(self, node):
549
+ if self._on_cycle_retreat:
550
+ if id(node) == id(self._cycle_node) or id(node) in self._successful_visits:
551
+ self._cycle_node = None
552
+ self._on_cycle_retreat = False
553
+ else:
554
+ return Discard
555
+
556
+ def _collapse_ambig(self, children):
557
+ new_children = []
558
+ for child in children:
559
+ if hasattr(child, 'data') and child.data == '_ambig':
560
+ new_children += child.children
561
+ else:
562
+ new_children.append(child)
563
+ return new_children
564
+
565
+ def _call_rule_func(self, node, data):
566
+ # called when transforming children of symbol nodes
567
+ # data is a list of trees or tokens that correspond to the
568
+ # symbol's rule expansion
569
+ return self.callbacks[node.rule](data)
570
+
571
+ def _call_ambig_func(self, node, data):
572
+ # called when transforming a symbol node
573
+ # data is a list of trees where each tree's data is
574
+ # equal to the name of the symbol or one of its aliases.
575
+ if len(data) > 1:
576
+ return self.tree_class('_ambig', data)
577
+ elif data:
578
+ return data[0]
579
+ return Discard
580
+
581
+ def transform_symbol_node(self, node, data):
582
+ if id(node) not in self._successful_visits:
583
+ return Discard
584
+ r = self._check_cycle(node)
585
+ if r is Discard:
586
+ return r
587
+ self._successful_visits.remove(id(node))
588
+ data = self._collapse_ambig(data)
589
+ return self._call_ambig_func(node, data)
590
+
591
+ def transform_intermediate_node(self, node, data):
592
+ if id(node) not in self._successful_visits:
593
+ return Discard
594
+ r = self._check_cycle(node)
595
+ if r is Discard:
596
+ return r
597
+ self._successful_visits.remove(id(node))
598
+ if len(data) > 1:
599
+ children = [self.tree_class('_inter', c) for c in data]
600
+ return self.tree_class('_iambig', children)
601
+ return data[0]
602
+
603
+ def transform_packed_node(self, node, data):
604
+ r = self._check_cycle(node)
605
+ if r is Discard:
606
+ return r
607
+ if self.resolve_ambiguity and id(node.parent) in self._successful_visits:
608
+ return Discard
609
+ if self._use_cache and id(node) in self._cache:
610
+ return self._cache[id(node)]
611
+ children = []
612
+ assert len(data) <= 2
613
+ data = PackedData(node, data)
614
+ if data.left is not PackedData.NO_DATA:
615
+ if node.left.is_intermediate and isinstance(data.left, list):
616
+ children += data.left
617
+ else:
618
+ children.append(data.left)
619
+ if data.right is not PackedData.NO_DATA:
620
+ children.append(data.right)
621
+ if node.parent.is_intermediate:
622
+ return self._cache.setdefault(id(node), children)
623
+ return self._cache.setdefault(id(node), self._call_rule_func(node, children))
624
+
625
+ def visit_symbol_node_in(self, node):
626
+ super(ForestToParseTree, self).visit_symbol_node_in(node)
627
+ if self._on_cycle_retreat:
628
+ return
629
+ return node.children
630
+
631
+ def visit_packed_node_in(self, node):
632
+ self._on_cycle_retreat = False
633
+ to_visit = super(ForestToParseTree, self).visit_packed_node_in(node)
634
+ if not self.resolve_ambiguity or id(node.parent) not in self._successful_visits:
635
+ if not self._use_cache or id(node) not in self._cache:
636
+ return to_visit
637
+
638
+ def visit_packed_node_out(self, node):
639
+ super(ForestToParseTree, self).visit_packed_node_out(node)
640
+ if not self._on_cycle_retreat:
641
+ self._successful_visits.add(id(node.parent))
642
+
643
+ def handles_ambiguity(func):
644
+ """Decorator for methods of subclasses of ``TreeForestTransformer``.
645
+ Denotes that the method should receive a list of transformed derivations."""
646
+ func.handles_ambiguity = True
647
+ return func
648
+
649
+ class TreeForestTransformer(ForestToParseTree):
650
+ """A ``ForestTransformer`` with a tree ``Transformer``-like interface.
651
+ By default, it will construct a tree.
652
+
653
+ Methods provided via inheritance are called based on the rule/symbol
654
+ names of nodes in the forest.
655
+
656
+ Methods that act on rules will receive a list of the results of the
657
+ transformations of the rule's children. By default, trees and tokens.
658
+
659
+ Methods that act on tokens will receive a token.
660
+
661
+ Alternatively, methods that act on rules may be annotated with
662
+ ``handles_ambiguity``. In this case, the function will receive a list
663
+ of all the transformations of all the derivations of the rule.
664
+ By default, a list of trees where each tree.data is equal to the
665
+ rule name or one of its aliases.
666
+
667
+ Non-tree transformations are made possible by override of
668
+ ``__default__``, ``__default_token__``, and ``__default_ambig__``.
669
+
670
+ Note:
671
+ Tree shaping features such as inlined rules and token filtering are
672
+ not built into the transformation. Positions are also not propagated.
673
+
674
+ Parameters:
675
+ tree_class: The tree class to use for construction
676
+ prioritizer: A ``ForestVisitor`` that manipulates the priorities of nodes in the SPPF.
677
+ resolve_ambiguity: If True, ambiguities will be resolved based on priorities.
678
+ use_cache (bool): If True, caches the results of some transformations,
679
+ potentially improving performance when ``resolve_ambiguity==False``.
680
+ Only use if you know what you are doing: i.e. All transformation
681
+ functions are pure and referentially transparent.
682
+ """
683
+
684
+ def __init__(self, tree_class=Tree, prioritizer=ForestSumVisitor(), resolve_ambiguity=True, use_cache=False):
685
+ super(TreeForestTransformer, self).__init__(tree_class, dict(), prioritizer, resolve_ambiguity, use_cache)
686
+
687
+ def __default__(self, name, data):
688
+ """Default operation on tree (for override).
689
+
690
+ Returns a tree with name with data as children.
691
+ """
692
+ return self.tree_class(name, data)
693
+
694
+ def __default_ambig__(self, name, data):
695
+ """Default operation on ambiguous rule (for override).
696
+
697
+ Wraps data in an '_ambig_' node if it contains more than
698
+ one element.
699
+ """
700
+ if len(data) > 1:
701
+ return self.tree_class('_ambig', data)
702
+ elif data:
703
+ return data[0]
704
+ return Discard
705
+
706
+ def __default_token__(self, node):
707
+ """Default operation on ``Token`` (for override).
708
+
709
+ Returns ``node``.
710
+ """
711
+ return node
712
+
713
+ def transform_token_node(self, node):
714
+ return getattr(self, node.type, self.__default_token__)(node)
715
+
716
+ def _call_rule_func(self, node, data):
717
+ name = node.rule.alias or node.rule.options.template_source or node.rule.origin.name
718
+ user_func = getattr(self, name, self.__default__)
719
+ if user_func == self.__default__ or hasattr(user_func, 'handles_ambiguity'):
720
+ user_func = partial(self.__default__, name)
721
+ if not self.resolve_ambiguity:
722
+ wrapper = partial(AmbiguousIntermediateExpander, self.tree_class)
723
+ user_func = wrapper(user_func)
724
+ return user_func(data)
725
+
726
+ def _call_ambig_func(self, node, data):
727
+ name = node.s.name
728
+ user_func = getattr(self, name, self.__default_ambig__)
729
+ if user_func == self.__default_ambig__ or not hasattr(user_func, 'handles_ambiguity'):
730
+ user_func = partial(self.__default_ambig__, name)
731
+ return user_func(data)
732
+
733
+ class ForestToPyDotVisitor(ForestVisitor):
734
+ """
735
+ A Forest visitor which writes the SPPF to a PNG.
736
+
737
+ The SPPF can get really large, really quickly because
738
+ of the amount of meta-data it stores, so this is probably
739
+ only useful for trivial trees and learning how the SPPF
740
+ is structured.
741
+ """
742
+ def __init__(self, rankdir="TB"):
743
+ super(ForestToPyDotVisitor, self).__init__(single_visit=True)
744
+ self.pydot = import_module('pydot')
745
+ self.graph = self.pydot.Dot(graph_type='digraph', rankdir=rankdir)
746
+
747
+ def visit(self, root, filename):
748
+ super(ForestToPyDotVisitor, self).visit(root)
749
+ try:
750
+ self.graph.write_png(filename)
751
+ except FileNotFoundError as e:
752
+ logger.error("Could not write png: ", e)
753
+
754
+ def visit_token_node(self, node):
755
+ graph_node_id = str(id(node))
756
+ graph_node_label = "\"{}\"".format(node.value.replace('"', '\\"'))
757
+ graph_node_color = 0x808080
758
+ graph_node_style = "\"filled,rounded\""
759
+ graph_node_shape = "diamond"
760
+ graph_node = self.pydot.Node(graph_node_id, style=graph_node_style, fillcolor="#{:06x}".format(graph_node_color), shape=graph_node_shape, label=graph_node_label)
761
+ self.graph.add_node(graph_node)
762
+
763
+ def visit_packed_node_in(self, node):
764
+ graph_node_id = str(id(node))
765
+ graph_node_label = repr(node)
766
+ graph_node_color = 0x808080
767
+ graph_node_style = "filled"
768
+ graph_node_shape = "diamond"
769
+ graph_node = self.pydot.Node(graph_node_id, style=graph_node_style, fillcolor="#{:06x}".format(graph_node_color), shape=graph_node_shape, label=graph_node_label)
770
+ self.graph.add_node(graph_node)
771
+ yield node.left
772
+ yield node.right
773
+
774
+ def visit_packed_node_out(self, node):
775
+ graph_node_id = str(id(node))
776
+ graph_node = self.graph.get_node(graph_node_id)[0]
777
+ for child in [node.left, node.right]:
778
+ if child is not None:
779
+ child_graph_node_id = str(id(child.token if isinstance(child, TokenNode) else child))
780
+ child_graph_node = self.graph.get_node(child_graph_node_id)[0]
781
+ self.graph.add_edge(self.pydot.Edge(graph_node, child_graph_node))
782
+ else:
783
+ #### Try and be above the Python object ID range; probably impl. specific, but maybe this is okay.
784
+ child_graph_node_id = str(randint(100000000000000000000000000000,123456789012345678901234567890))
785
+ child_graph_node_style = "invis"
786
+ child_graph_node = self.pydot.Node(child_graph_node_id, style=child_graph_node_style, label="None")
787
+ child_edge_style = "invis"
788
+ self.graph.add_node(child_graph_node)
789
+ self.graph.add_edge(self.pydot.Edge(graph_node, child_graph_node, style=child_edge_style))
790
+
791
+ def visit_symbol_node_in(self, node):
792
+ graph_node_id = str(id(node))
793
+ graph_node_label = repr(node)
794
+ graph_node_color = 0x808080
795
+ graph_node_style = "\"filled\""
796
+ if node.is_intermediate:
797
+ graph_node_shape = "ellipse"
798
+ else:
799
+ graph_node_shape = "rectangle"
800
+ graph_node = self.pydot.Node(graph_node_id, style=graph_node_style, fillcolor="#{:06x}".format(graph_node_color), shape=graph_node_shape, label=graph_node_label)
801
+ self.graph.add_node(graph_node)
802
+ return iter(node.children)
803
+
804
+ def visit_symbol_node_out(self, node):
805
+ graph_node_id = str(id(node))
806
+ graph_node = self.graph.get_node(graph_node_id)[0]
807
+ for child in node.children:
808
+ child_graph_node_id = str(id(child))
809
+ child_graph_node = self.graph.get_node(child_graph_node_id)[0]
810
+ self.graph.add_edge(self.pydot.Edge(graph_node, child_graph_node))