yoda-language-server 0.7.2 → 0.10.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (405) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/test.yml +23 -0
  3. data/.gitignore +1 -1
  4. data/.rspec +1 -0
  5. data/CHANGELOG.md +14 -0
  6. data/Gemfile +2 -0
  7. data/README.md +23 -11
  8. data/Rakefile +32 -0
  9. data/bin/bench +12 -0
  10. data/bin/local +7 -0
  11. data/client/atom/.gitignore +1 -0
  12. data/{package.json → client/atom/package.json} +1 -1
  13. data/{yarn.lock → client/atom/yarn.lock} +0 -0
  14. data/client/vscode/.gitignore +1 -1
  15. data/client/vscode/.vscode/launch.json +0 -11
  16. data/client/vscode/.vscode/settings.json +5 -1
  17. data/client/vscode/LICENSE.txt +21 -0
  18. data/client/vscode/README.md +4 -55
  19. data/client/vscode/package-lock.json +4299 -1373
  20. data/client/vscode/package.json +40 -15
  21. data/client/vscode/src/check-versions.ts +49 -0
  22. data/client/vscode/src/config.ts +20 -0
  23. data/client/vscode/src/extension.ts +12 -27
  24. data/client/vscode/src/install-tools.ts +109 -0
  25. data/client/vscode/src/language-server.ts +59 -0
  26. data/client/vscode/src/status.ts +3 -0
  27. data/client/vscode/src/test/runTest.ts +30 -0
  28. data/client/vscode/src/test/{completion.test.ts → suite/completion.test.ts} +2 -1
  29. data/client/vscode/src/test/suite/hover.test.ts +31 -0
  30. data/client/vscode/src/test/suite/index.ts +26 -0
  31. data/client/vscode/src/utils.ts +11 -0
  32. data/client/vscode/tsconfig.json +4 -1
  33. data/exe/yoda +1 -1
  34. data/lib/yoda/ast/array_node.rb +10 -0
  35. data/lib/yoda/ast/assignment_node.rb +15 -0
  36. data/lib/yoda/ast/block_call_node.rb +20 -0
  37. data/lib/yoda/ast/block_node.rb +10 -0
  38. data/lib/yoda/ast/case_node.rb +20 -0
  39. data/lib/yoda/ast/center_operator_node.rb +20 -0
  40. data/lib/yoda/ast/class_node.rb +22 -0
  41. data/lib/yoda/ast/comment_block/base_part.rb +12 -0
  42. data/lib/yoda/ast/comment_block/range_calculation.rb +58 -0
  43. data/lib/yoda/ast/comment_block/tag_part.rb +88 -0
  44. data/lib/yoda/ast/comment_block/tag_text_name_part.rb +35 -0
  45. data/lib/yoda/ast/comment_block/tag_text_type_part.rb +52 -0
  46. data/lib/yoda/ast/comment_block/text_part.rb +28 -0
  47. data/lib/yoda/ast/comment_block/token.rb +44 -0
  48. data/lib/yoda/ast/comment_block.rb +119 -0
  49. data/lib/yoda/ast/conditional_loop_node.rb +15 -0
  50. data/lib/yoda/ast/constant_assignment_node.rb +20 -0
  51. data/lib/yoda/ast/constant_base_node.rb +42 -0
  52. data/lib/yoda/ast/constant_node.rb +53 -0
  53. data/lib/yoda/ast/def_node.rb +27 -0
  54. data/lib/yoda/ast/def_singleton_node.rb +32 -0
  55. data/lib/yoda/ast/empty_vnode.rb +24 -0
  56. data/lib/yoda/ast/ensure_node.rb +15 -0
  57. data/lib/yoda/ast/for_node.rb +20 -0
  58. data/lib/yoda/ast/hash_node.rb +10 -0
  59. data/lib/yoda/ast/if_node.rb +20 -0
  60. data/lib/yoda/ast/interpolation_text_node.rb +10 -0
  61. data/lib/yoda/ast/kwsplat_node.rb +10 -0
  62. data/lib/yoda/ast/left_operator_node.rb +15 -0
  63. data/lib/yoda/ast/literal_node.rb +18 -0
  64. data/lib/yoda/ast/method_traversable.rb +22 -0
  65. data/lib/yoda/ast/module_node.rb +17 -0
  66. data/lib/yoda/ast/multiple_left_hand_side_node.rb +31 -0
  67. data/lib/yoda/ast/name_vnode.rb +28 -0
  68. data/lib/yoda/ast/namespace.rb +36 -0
  69. data/lib/yoda/ast/namespace_traversable.rb +39 -0
  70. data/lib/yoda/ast/node.rb +52 -0
  71. data/lib/yoda/ast/optional_parameter_node.rb +20 -0
  72. data/lib/yoda/ast/pair_node.rb +15 -0
  73. data/lib/yoda/ast/parameter_node.rb +25 -0
  74. data/lib/yoda/ast/parameters_node.rb +62 -0
  75. data/lib/yoda/ast/rescue_clause_node.rb +20 -0
  76. data/lib/yoda/ast/rescue_node.rb +20 -0
  77. data/lib/yoda/ast/root_vnode.rb +48 -0
  78. data/lib/yoda/ast/send_node.rb +100 -0
  79. data/lib/yoda/ast/singleton_class_node.rb +17 -0
  80. data/lib/yoda/ast/special_call_node.rb +10 -0
  81. data/lib/yoda/ast/traversable.rb +34 -0
  82. data/lib/yoda/ast/value_vnode.rb +28 -0
  83. data/lib/yoda/ast/variable_node.rb +15 -0
  84. data/lib/yoda/ast/vnode.rb +170 -0
  85. data/lib/yoda/ast/when_node.rb +15 -0
  86. data/lib/yoda/ast.rb +140 -0
  87. data/lib/yoda/cli/analyze_deps.rb +123 -0
  88. data/lib/yoda/{commands → cli}/base.rb +1 -1
  89. data/lib/yoda/{commands → cli}/complete.rb +12 -9
  90. data/lib/yoda/cli/console.rb +17 -0
  91. data/lib/yoda/{commands → cli}/file_cursor_parsable.rb +1 -1
  92. data/lib/yoda/{commands → cli}/infer.rb +4 -4
  93. data/lib/yoda/cli.rb +117 -0
  94. data/lib/yoda/has_services.rb +40 -0
  95. data/lib/yoda/id_mask.rb +84 -0
  96. data/lib/yoda/instrument.rb +21 -5
  97. data/lib/yoda/logger.rb +4 -2
  98. data/lib/yoda/missing_delegatable.rb +34 -0
  99. data/lib/yoda/model/completion_item.rb +43 -11
  100. data/lib/yoda/model/descriptions/base.rb +11 -0
  101. data/lib/yoda/model/descriptions/comment_token_description.rb +46 -0
  102. data/lib/yoda/model/descriptions/function_description.rb +19 -2
  103. data/lib/yoda/model/descriptions/node_description.rb +19 -8
  104. data/lib/yoda/model/descriptions/require_path_description.rb +45 -0
  105. data/lib/yoda/model/descriptions/variable_description.rb +41 -0
  106. data/lib/yoda/model/descriptions.rb +3 -0
  107. data/lib/yoda/model/environment/accessor_interface.rb +43 -0
  108. data/lib/yoda/model/environment/instance_accessor.rb +121 -0
  109. data/lib/yoda/model/environment/namespace_members.rb +104 -0
  110. data/lib/yoda/model/environment/singleton_accessor.rb +66 -0
  111. data/lib/yoda/model/environment/value_factory.rb +151 -0
  112. data/lib/yoda/model/environment/value_resolve_context.rb +62 -0
  113. data/lib/yoda/model/environment/with_cache.rb +14 -0
  114. data/lib/yoda/model/environment.rb +122 -0
  115. data/lib/yoda/model/function_signatures/base.rb +22 -2
  116. data/lib/yoda/model/function_signatures/constructor.rb +17 -1
  117. data/lib/yoda/model/function_signatures/method.rb +18 -2
  118. data/lib/yoda/model/function_signatures/overload.rb +17 -1
  119. data/lib/yoda/model/function_signatures/parameter_list.rb +17 -0
  120. data/lib/yoda/model/function_signatures/rbs_method.rb +91 -0
  121. data/lib/yoda/model/function_signatures/type_builder.rb +63 -31
  122. data/lib/yoda/model/function_signatures/wrapper.rb +46 -0
  123. data/lib/yoda/model/function_signatures.rb +2 -0
  124. data/lib/yoda/model/lexical_context.rb +40 -0
  125. data/lib/yoda/model/node_signatures/base.rb +42 -0
  126. data/lib/yoda/model/node_signatures/const.rb +20 -0
  127. data/lib/yoda/model/node_signatures/method_definition.rb +20 -0
  128. data/lib/yoda/model/node_signatures/node.rb +19 -0
  129. data/lib/yoda/model/node_signatures/send.rb +20 -0
  130. data/lib/yoda/model/node_signatures.rb +35 -0
  131. data/lib/yoda/model/parameters/base.rb +14 -0
  132. data/lib/yoda/model/parameters/binder.rb +148 -0
  133. data/lib/yoda/model/parameters/multiple.rb +36 -0
  134. data/lib/yoda/model/parameters/named.rb +20 -0
  135. data/lib/yoda/model/parameters/unnamed.rb +12 -0
  136. data/lib/yoda/model/parameters.rb +11 -0
  137. data/lib/yoda/model/path.rb +16 -0
  138. data/lib/yoda/model/primary_source_inferencer.rb +34 -0
  139. data/lib/yoda/model/scoped_path.rb +13 -2
  140. data/lib/yoda/model/{types → type_expressions}/any_type.rb +7 -3
  141. data/lib/yoda/model/{types → type_expressions}/base.rb +10 -3
  142. data/lib/yoda/model/{types → type_expressions}/duck_type.rb +8 -2
  143. data/lib/yoda/model/type_expressions/function_type/parameter.rb +95 -0
  144. data/lib/yoda/model/{types → type_expressions}/function_type.rb +61 -70
  145. data/lib/yoda/model/type_expressions/generator.rb +28 -0
  146. data/lib/yoda/model/{types → type_expressions}/generic_type.rb +17 -2
  147. data/lib/yoda/model/{types → type_expressions}/instance_type.rb +10 -2
  148. data/lib/yoda/model/{types → type_expressions}/module_type.rb +7 -1
  149. data/lib/yoda/model/type_expressions/self_type.rb +38 -0
  150. data/lib/yoda/model/{types → type_expressions}/sequence_type.rb +6 -1
  151. data/lib/yoda/model/{types → type_expressions}/union_type.rb +7 -3
  152. data/lib/yoda/model/{types → type_expressions}/unknown_type.rb +6 -1
  153. data/lib/yoda/model/{types → type_expressions}/value_type.rb +17 -1
  154. data/lib/yoda/model/type_expressions/void_type.rb +37 -0
  155. data/lib/yoda/model/type_expressions.rb +40 -0
  156. data/lib/yoda/model/values/base.rb +23 -8
  157. data/lib/yoda/model/values/empty_value.rb +39 -0
  158. data/lib/yoda/model/values/instance_value.rb +24 -43
  159. data/lib/yoda/model/values/intersection_value.rb +48 -0
  160. data/lib/yoda/model/values/literal_value.rb +26 -0
  161. data/lib/yoda/model/values/union_value.rb +50 -0
  162. data/lib/yoda/model/values.rb +5 -1
  163. data/lib/yoda/model/yard_type_parser.rb +35 -0
  164. data/lib/yoda/model.rb +7 -2
  165. data/lib/yoda/parsing/comment_tokenizer.rb +21 -4
  166. data/lib/yoda/parsing/location.rb +9 -0
  167. data/lib/yoda/parsing/node_objects/args_node.rb +85 -0
  168. data/lib/yoda/parsing/node_objects/const_node.rb +3 -3
  169. data/lib/yoda/parsing/node_objects/mlhs_node.rb +31 -0
  170. data/lib/yoda/parsing/node_objects.rb +2 -0
  171. data/lib/yoda/parsing/parser.rb +44 -5
  172. data/lib/yoda/parsing/query/current_comment_token_query.rb +4 -3
  173. data/lib/yoda/parsing/query/current_commenting_node_query.rb +7 -7
  174. data/lib/yoda/parsing/scopes/base.rb +1 -1
  175. data/lib/yoda/parsing/scopes/builder.rb +1 -1
  176. data/lib/yoda/parsing/source_cutter.rb +6 -2
  177. data/lib/yoda/parsing/traverser/matcher.rb +65 -0
  178. data/lib/yoda/parsing/traverser/query_interface.rb +68 -0
  179. data/lib/yoda/parsing/traverser/result_set.rb +37 -0
  180. data/lib/yoda/parsing/traverser.rb +29 -0
  181. data/lib/yoda/parsing/type_parser.rb +24 -20
  182. data/lib/yoda/parsing.rb +27 -1
  183. data/lib/yoda/presentation/code_completion/constant.rb +27 -0
  184. data/lib/yoda/server/concurrent_writer.rb +1 -1
  185. data/lib/yoda/server/lifecycle_handler.rb +125 -25
  186. data/lib/yoda/server/notifier.rb +79 -1
  187. data/lib/yoda/server/providers/completion.rb +31 -17
  188. data/lib/yoda/server/providers/definition.rb +38 -10
  189. data/lib/yoda/server/providers/hover.rb +26 -10
  190. data/lib/yoda/server/providers/reportable_progress.rb +75 -0
  191. data/lib/yoda/server/providers/signature.rb +20 -7
  192. data/lib/yoda/server/providers/text_document_did_change.rb +1 -1
  193. data/lib/yoda/server/providers/text_document_did_open.rb +1 -1
  194. data/lib/yoda/server/providers/with_timeout.rb +36 -0
  195. data/lib/yoda/server/providers/workspace_did_change_workspace_folders.rb +33 -0
  196. data/lib/yoda/server/providers/workspace_did_create_files.rb +21 -0
  197. data/lib/yoda/server/providers/workspace_did_delete_files.rb +21 -0
  198. data/lib/yoda/server/providers/workspace_did_rename_files.rb +22 -0
  199. data/lib/yoda/server/providers/workspace_symbol.rb +82 -0
  200. data/lib/yoda/server/providers.rb +12 -0
  201. data/lib/yoda/server/root_handler.rb +27 -23
  202. data/lib/yoda/server/rootless_workspace.rb +62 -0
  203. data/lib/yoda/server/scheduler.rb +50 -0
  204. data/lib/yoda/server/session.rb +71 -25
  205. data/lib/yoda/server/uri_decoder.rb +16 -0
  206. data/lib/yoda/server/workspace.rb +117 -0
  207. data/lib/yoda/server.rb +9 -2
  208. data/lib/yoda/services/code_completion/base_provider.rb +52 -0
  209. data/lib/yoda/{evaluation → services}/code_completion/const_provider.rb +35 -25
  210. data/lib/yoda/services/code_completion/keyword_provider.rb +67 -0
  211. data/lib/yoda/services/code_completion/local_variable_provider.rb +51 -0
  212. data/lib/yoda/{evaluation → services}/code_completion/method_provider.rb +14 -32
  213. data/lib/yoda/services/code_completion.rb +74 -0
  214. data/lib/yoda/{evaluation → services}/comment_completion/base_provider.rb +11 -6
  215. data/lib/yoda/{evaluation → services}/comment_completion/param_provider.rb +1 -1
  216. data/lib/yoda/{evaluation → services}/comment_completion/tag_provider.rb +1 -1
  217. data/lib/yoda/{evaluation → services}/comment_completion/type_provider.rb +6 -5
  218. data/lib/yoda/{evaluation → services}/comment_completion.rb +13 -13
  219. data/lib/yoda/services/current_node_explain/comment_signature.rb +77 -0
  220. data/lib/yoda/services/current_node_explain.rb +72 -0
  221. data/lib/yoda/services/evaluator.rb +44 -0
  222. data/lib/yoda/services/loadable_path_resolver.rb +33 -0
  223. data/lib/yoda/services/signature_discovery.rb +74 -0
  224. data/lib/yoda/services.rb +10 -0
  225. data/lib/yoda/store/actions/build_core_index.rb +38 -9
  226. data/lib/yoda/store/actions/import_core_library.rb +14 -19
  227. data/lib/yoda/store/actions/import_gem.rb +65 -33
  228. data/lib/yoda/store/actions/import_project_dependencies.rb +47 -0
  229. data/lib/yoda/store/actions/import_std_library.rb +13 -18
  230. data/lib/yoda/store/actions/read_file.rb +21 -6
  231. data/lib/yoda/store/actions/read_project_files.rb +13 -5
  232. data/lib/yoda/store/actions.rb +1 -0
  233. data/lib/yoda/store/adapters/base.rb +39 -0
  234. data/lib/yoda/store/adapters/gdbm_adapter/namespace_accessor.rb +152 -0
  235. data/lib/yoda/store/adapters/gdbm_adapter.rb +56 -0
  236. data/lib/yoda/store/adapters/lazy_adapter.rb +34 -0
  237. data/lib/yoda/store/adapters/memory_adapter.rb +22 -1
  238. data/lib/yoda/store/adapters.rb +12 -4
  239. data/lib/yoda/store/config.rb +43 -0
  240. data/lib/yoda/store/file_tree.rb +131 -0
  241. data/lib/yoda/store/objects/base.rb +73 -4
  242. data/lib/yoda/store/objects/class_object.rb +10 -1
  243. data/lib/yoda/store/objects/connected_delegation.rb +25 -0
  244. data/lib/yoda/store/objects/libraries_status.rb +67 -0
  245. data/lib/yoda/store/objects/library/core.rb +80 -0
  246. data/lib/yoda/store/objects/library/gem.rb +152 -0
  247. data/lib/yoda/store/objects/library/path_resolvable.rb +29 -0
  248. data/lib/yoda/store/objects/library/std.rb +81 -0
  249. data/lib/yoda/store/objects/library/with_registry.rb +28 -0
  250. data/lib/yoda/store/objects/library.rb +25 -0
  251. data/lib/yoda/store/objects/map.rb +61 -0
  252. data/lib/yoda/store/objects/merger.rb +6 -5
  253. data/lib/yoda/store/objects/meta_class_object.rb +28 -1
  254. data/lib/yoda/store/objects/method_object.rb +39 -6
  255. data/lib/yoda/store/objects/module_object.rb +3 -0
  256. data/lib/yoda/store/objects/namespace_object.rb +38 -1
  257. data/lib/yoda/store/objects/overload.rb +1 -1
  258. data/lib/yoda/store/objects/patch.rb +54 -11
  259. data/lib/yoda/store/objects/patch_set.rb +2 -2
  260. data/lib/yoda/store/objects/serializable.rb +17 -2
  261. data/lib/yoda/store/objects/serializable_set.rb +23 -0
  262. data/lib/yoda/store/objects/tag.rb +1 -1
  263. data/lib/yoda/store/objects/value_object.rb +5 -1
  264. data/lib/yoda/store/objects.rb +5 -1
  265. data/lib/yoda/store/project/dependency.rb +101 -0
  266. data/lib/yoda/store/project/file_finder.rb +121 -0
  267. data/lib/yoda/store/project/rbs_loader.rb +41 -0
  268. data/lib/yoda/store/project/setuper.rb +68 -0
  269. data/lib/yoda/store/project.rb +101 -41
  270. data/lib/yoda/store/query/ancestor_tree.rb +126 -0
  271. data/lib/yoda/store/query/associators/associate_ancestors.rb +2 -83
  272. data/lib/yoda/store/query/associators/associate_methods.rb +2 -2
  273. data/lib/yoda/store/query/constant_member_set.rb +33 -0
  274. data/lib/yoda/store/query/find_constant.rb +22 -4
  275. data/lib/yoda/store/query/find_meta_class.rb +1 -1
  276. data/lib/yoda/store/query/find_method.rb +9 -2
  277. data/lib/yoda/store/query/find_signature.rb +11 -3
  278. data/lib/yoda/store/query/find_workspace_objects.rb +36 -0
  279. data/lib/yoda/store/query/method_member_set.rb +50 -0
  280. data/lib/yoda/store/query.rb +4 -0
  281. data/lib/yoda/store/{registry_cache.rb → registry/cache.rb} +26 -1
  282. data/lib/yoda/store/registry/composer.rb +49 -0
  283. data/lib/yoda/store/registry/index.rb +120 -0
  284. data/lib/yoda/store/registry/library_registry.rb +71 -0
  285. data/lib/yoda/store/registry/library_registry_set.rb +133 -0
  286. data/lib/yoda/store/registry/local_store.rb +38 -0
  287. data/lib/yoda/store/registry/project_registry.rb +72 -0
  288. data/lib/yoda/store/registry.rb +25 -97
  289. data/lib/yoda/store/transformers/core_visibility.rb +61 -0
  290. data/lib/yoda/store/transformers.rb +7 -0
  291. data/lib/yoda/store/version_store.rb +71 -0
  292. data/lib/yoda/store/yard_importer.rb +13 -13
  293. data/lib/yoda/store.rb +15 -2
  294. data/lib/yoda/typing/constant_resolver/cbase_query.rb +14 -0
  295. data/lib/yoda/typing/constant_resolver/code_query.rb +25 -0
  296. data/lib/yoda/typing/constant_resolver/member_query.rb +27 -0
  297. data/lib/yoda/typing/constant_resolver/node_tracer.rb +36 -0
  298. data/lib/yoda/typing/constant_resolver/query.rb +70 -0
  299. data/lib/yoda/typing/constant_resolver/relative_base_query.rb +14 -0
  300. data/lib/yoda/typing/constant_resolver.rb +110 -0
  301. data/lib/yoda/typing/contexts/base_context.rb +83 -0
  302. data/lib/yoda/typing/contexts/block_context.rb +14 -0
  303. data/lib/yoda/typing/contexts/context_derivation.rb +59 -0
  304. data/lib/yoda/typing/contexts/method_context.rb +14 -0
  305. data/lib/yoda/typing/contexts/namespace_block_context.rb +29 -0
  306. data/lib/yoda/typing/contexts/namespace_context.rb +14 -0
  307. data/lib/yoda/typing/contexts.rb +25 -0
  308. data/lib/yoda/typing/environment.rb +1 -1
  309. data/lib/yoda/typing/inferencer/arguments.rb +38 -0
  310. data/lib/yoda/typing/inferencer/arguments_binder.rb +24 -0
  311. data/lib/yoda/typing/inferencer/load_resolver.rb +37 -0
  312. data/lib/yoda/typing/inferencer/method_resolver.rb +81 -0
  313. data/lib/yoda/typing/inferencer/object_resolver.rb +55 -0
  314. data/lib/yoda/typing/inferencer/parameter_binder.rb +176 -0
  315. data/lib/yoda/typing/inferencer/tracer.rb +209 -0
  316. data/lib/yoda/typing/inferencer/type_binding.rb +46 -0
  317. data/lib/yoda/typing/inferencer.rb +53 -0
  318. data/lib/yoda/typing/node_info.rb +83 -0
  319. data/lib/yoda/typing/relation.rb +2 -2
  320. data/lib/yoda/typing/traces/base.rb +2 -2
  321. data/lib/yoda/typing/traces/normal.rb +3 -3
  322. data/lib/yoda/typing/traces/send.rb +4 -4
  323. data/lib/yoda/typing/tree/ask_defined.rb +12 -0
  324. data/lib/yoda/typing/tree/base.rb +91 -0
  325. data/lib/yoda/typing/tree/begin.rb +15 -0
  326. data/lib/yoda/typing/tree/block_call.rb +26 -0
  327. data/lib/yoda/typing/tree/case.rb +18 -0
  328. data/lib/yoda/typing/tree/class_tree.rb +23 -0
  329. data/lib/yoda/typing/tree/conditional_loop.rb +15 -0
  330. data/lib/yoda/typing/tree/constant.rb +19 -0
  331. data/lib/yoda/typing/tree/constant_assignment.rb +12 -0
  332. data/lib/yoda/typing/tree/ensure.rb +17 -0
  333. data/lib/yoda/typing/tree/for.rb +15 -0
  334. data/lib/yoda/typing/tree/hash_tree.rb +32 -0
  335. data/lib/yoda/typing/tree/if.rb +22 -0
  336. data/lib/yoda/typing/tree/interpolation_text.rb +21 -0
  337. data/lib/yoda/typing/tree/literal.rb +18 -0
  338. data/lib/yoda/typing/tree/literal_inferable.rb +48 -0
  339. data/lib/yoda/typing/tree/local_exit.rb +15 -0
  340. data/lib/yoda/typing/tree/logical_assignment.rb +16 -0
  341. data/lib/yoda/typing/tree/logical_operator.rb +16 -0
  342. data/lib/yoda/typing/tree/method_def.rb +41 -0
  343. data/lib/yoda/typing/tree/method_inferable.rb +51 -0
  344. data/lib/yoda/typing/tree/module_tree.rb +18 -0
  345. data/lib/yoda/typing/tree/multiple_assignment.rb +16 -0
  346. data/lib/yoda/typing/tree/namespace_inferable.rb +20 -0
  347. data/lib/yoda/typing/tree/rescue.rb +18 -0
  348. data/lib/yoda/typing/tree/rescue_clause.rb +42 -0
  349. data/lib/yoda/typing/tree/self.rb +12 -0
  350. data/lib/yoda/typing/tree/send.rb +19 -0
  351. data/lib/yoda/typing/tree/send_inferable.rb +89 -0
  352. data/lib/yoda/typing/tree/singleton_class_tree.rb +24 -0
  353. data/lib/yoda/typing/tree/singleton_method_def.rb +41 -0
  354. data/lib/yoda/typing/tree/super.rb +19 -0
  355. data/lib/yoda/typing/tree/variable.rb +15 -0
  356. data/lib/yoda/typing/tree/variable_assignment.rb +23 -0
  357. data/lib/yoda/typing/tree/yield.rb +19 -0
  358. data/lib/yoda/typing/tree.rb +129 -0
  359. data/lib/yoda/typing/types/any.rb +15 -0
  360. data/lib/yoda/typing/types/associative_array.rb +28 -0
  361. data/lib/yoda/typing/types/base.rb +25 -0
  362. data/lib/yoda/typing/types/converter.rb +67 -0
  363. data/lib/yoda/typing/types/function.rb +68 -0
  364. data/lib/yoda/typing/types/generator.rb +306 -0
  365. data/lib/yoda/typing/types/generic.rb +29 -0
  366. data/lib/yoda/typing/types/instance.rb +30 -0
  367. data/lib/yoda/typing/types/instance_type.rb +74 -0
  368. data/lib/yoda/typing/types/method.rb +39 -0
  369. data/lib/yoda/typing/types/rbs_type_wrapper_interface.rb +44 -0
  370. data/lib/yoda/typing/types/singleton_type.rb +75 -0
  371. data/lib/yoda/typing/types/tuple.rb +24 -0
  372. data/lib/yoda/typing/types/type.rb +60 -0
  373. data/lib/yoda/typing/types/union.rb +38 -0
  374. data/lib/yoda/typing/types/var.rb +38 -0
  375. data/lib/yoda/typing/types.rb +24 -0
  376. data/lib/yoda/typing.rb +6 -2
  377. data/lib/yoda/version.rb +1 -1
  378. data/lib/yoda.rb +7 -2
  379. data/scripts/benchmark.rb +1 -1
  380. data/yoda-language-server.gemspec +16 -15
  381. metadata +349 -111
  382. data/.travis.yml +0 -8
  383. data/client/vscode/src/test/index.ts +0 -24
  384. data/lib/yoda/commands/setup.rb +0 -51
  385. data/lib/yoda/commands.rb +0 -69
  386. data/lib/yoda/evaluation/code_completion/base_provider.rb +0 -57
  387. data/lib/yoda/evaluation/code_completion/variable_provider.rb +0 -18
  388. data/lib/yoda/evaluation/code_completion.rb +0 -65
  389. data/lib/yoda/evaluation/current_node_explain.rb +0 -71
  390. data/lib/yoda/evaluation/evaluator.rb +0 -105
  391. data/lib/yoda/evaluation/signature_discovery.rb +0 -85
  392. data/lib/yoda/evaluation.rb +0 -9
  393. data/lib/yoda/model/node_signature.rb +0 -43
  394. data/lib/yoda/model/types.rb +0 -84
  395. data/lib/yoda/model/values/module_value.rb +0 -72
  396. data/lib/yoda/parsing/source_analyzer.rb +0 -59
  397. data/lib/yoda/server/file_store.rb +0 -57
  398. data/lib/yoda/store/adapters/leveldb_adapter.rb +0 -80
  399. data/lib/yoda/store/adapters/lmdb_adapter.rb +0 -113
  400. data/lib/yoda/store/objects/project_status.rb +0 -169
  401. data/lib/yoda/store/project/cache.rb +0 -78
  402. data/lib/yoda/store/project/library_doc_loader.rb +0 -114
  403. data/lib/yoda/typing/context.rb +0 -96
  404. data/lib/yoda/typing/evaluator.rb +0 -259
  405. data/scripts/build_core_index.sh +0 -16
@@ -0,0 +1,20 @@
1
+ module Yoda
2
+ module AST
3
+ class IfNode < Node
4
+ # @return [Node]
5
+ def condition
6
+ children[0]
7
+ end
8
+
9
+ # @return [Node]
10
+ def then_clause
11
+ children[1]
12
+ end
13
+
14
+ # @return [Node]
15
+ def else_clause
16
+ children[2]
17
+ end
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,10 @@
1
+ module Yoda
2
+ module AST
3
+ class InterpolationTextNode < Node
4
+ # @return [Array<Vnode>]
5
+ def contents
6
+ children
7
+ end
8
+ end
9
+ end
10
+ end
@@ -0,0 +1,10 @@
1
+ module Yoda
2
+ module AST
3
+ class KwsplatNode < Node
4
+ # @return [Vnode]
5
+ def content
6
+ children.first
7
+ end
8
+ end
9
+ end
10
+ end
@@ -0,0 +1,15 @@
1
+ module Yoda
2
+ module AST
3
+ class LeftOperatorNode < Node
4
+ # @return [Symbol]
5
+ def operator
6
+ type
7
+ end
8
+
9
+ # @return [Node]
10
+ def content
11
+ children[0]
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,18 @@
1
+ module Yoda
2
+ module AST
3
+ class LiteralNode < Node
4
+ def children
5
+ []
6
+ end
7
+
8
+ # @return [Object]
9
+ def value
10
+ node.children[0]
11
+ end
12
+
13
+ def inspect_content
14
+ value
15
+ end
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,22 @@
1
+
2
+ module Yoda
3
+ module AST
4
+ module MethodTraversable
5
+ # @return [true, false]
6
+ def method?
7
+ false
8
+ end
9
+
10
+ # @return [Namespace]
11
+ def including_method
12
+ @including_method ||= method? ? self : parent.including_method
13
+ end
14
+
15
+ # @param location [Location]
16
+ # @return [DefNode, DefSingletonNode, nil]
17
+ def calc_current_location_method(location)
18
+ positionally_nearest_child(location)&.including_method
19
+ end
20
+ end
21
+ end
22
+ end
@@ -0,0 +1,17 @@
1
+ module Yoda
2
+ module AST
3
+ class ModuleNode < Node
4
+ include Namespace
5
+
6
+ # @return [ConstantNode]
7
+ def receiver
8
+ children[0]
9
+ end
10
+
11
+ # @return [Vnode]
12
+ def body
13
+ children[1]
14
+ end
15
+ end
16
+ end
17
+ end
@@ -0,0 +1,31 @@
1
+ module Yoda
2
+ module AST
3
+ class MultipleLeftHandSideNode < Node
4
+ # @return [Array<Vnode>]
5
+ def pre_nodes
6
+ @pre_nodes ||= children.take_while { |arg_node| %i(arg optarg mlhs).include?(arg_node.type) }
7
+ end
8
+
9
+ # @return [Vnode, nil]
10
+ def rest_node
11
+ @rest_node ||= node.children.find { |arg_node| arg_node.type == :restarg }
12
+ end
13
+
14
+ # @return [Array<Vnode>]
15
+ def post_nodes
16
+ @post_nodes ||= children.drop_while { |arg_node| %i(arg optarg mlhs).include?(arg_node.type) }.select { |arg_node| %i(arg optarg mlhs).include?(arg_node.type) }
17
+ end
18
+
19
+ # @return [Model::Parameters::Base]
20
+ def parameter
21
+ rest_parameter = rest_node&.respond_to?(:parameter) && rest_node.parameter
22
+
23
+ Model::Parameters::Multiple.new(
24
+ parameters: pre_nodes.map(&:parameter),
25
+ rest_parameter: rest_parameter,
26
+ post_parameters: post_nodes.map(&:paramter),
27
+ )
28
+ end
29
+ end
30
+ end
31
+ end
@@ -0,0 +1,28 @@
1
+ module Yoda
2
+ module AST
3
+ class NameVnode < Vnode
4
+ # @return [Symbol]
5
+ def type
6
+ :name
7
+ end
8
+
9
+ # @return [Symbol]
10
+ attr_reader :name
11
+
12
+ # @param name [Symbol]
13
+ def initialize(name, **kwargs)
14
+ @name = name
15
+ super(**kwargs)
16
+ end
17
+
18
+ # @return [Array<Node>, nil]
19
+ def children
20
+ []
21
+ end
22
+
23
+ def inspect_content
24
+ name
25
+ end
26
+ end
27
+ end
28
+ end
@@ -0,0 +1,36 @@
1
+
2
+ module Yoda
3
+ module AST
4
+ module Namespace
5
+ # @return [true]
6
+ def root?
7
+ true
8
+ end
9
+
10
+ # @return [Namespace, nil]
11
+ def parent_namespace
12
+ parent&.namespace
13
+ end
14
+
15
+ # @return [Array<Namespace>]
16
+ def namespace_nestings
17
+ @namespace_nestings ||= (parent_namespace&.namespace_nestings || []) + [self]
18
+ end
19
+
20
+ # @return [Namespace]
21
+ def namespace
22
+ self
23
+ end
24
+
25
+ # @return [true, false]
26
+ def namespace?
27
+ true
28
+ end
29
+
30
+ # @return [String]
31
+ def path
32
+ fail NotImplementedError
33
+ end
34
+ end
35
+ end
36
+ end
@@ -0,0 +1,39 @@
1
+
2
+ module Yoda
3
+ module AST
4
+ module NamespaceTraversable
5
+ # @return [true, false]
6
+ def root?
7
+ false
8
+ end
9
+
10
+ # @return [true, false]
11
+ def namespace?
12
+ false
13
+ end
14
+
15
+ # @return [Namespace]
16
+ def namespace
17
+ @namespace ||= namespace? ? self : parent.namespace
18
+ end
19
+
20
+ # @return [String]
21
+ def namespace_path
22
+ namespace.path
23
+ end
24
+
25
+ # @return [String, Symbol]
26
+ def full_name
27
+ return :root if type == :root
28
+ parent_name = parent && !parent.root? ? parent.full_name : ''
29
+ const_node ? ConstNode.new(const_node).to_s(parent_name) : parent_name
30
+ end
31
+
32
+ # @param location [Location]
33
+ # @return [Namespace, nil]
34
+ def calc_current_location_namespace(location)
35
+ positionally_nearest_child(location)&.namespace
36
+ end
37
+ end
38
+ end
39
+ end
@@ -0,0 +1,52 @@
1
+ require 'forwardable'
2
+
3
+ module Yoda
4
+ module AST
5
+ class Node < Vnode
6
+ extend Forwardable
7
+
8
+ # @return [Parser::AST::Node]
9
+ attr_reader :node
10
+
11
+ # @return [Symbol]
12
+ delegate type: :node
13
+
14
+ # @return [String]
15
+ delegate to_s: :node
16
+
17
+ # @param node [Parser::AST::Node]
18
+ # @param parent [Vnode]
19
+ # @param comment_by_node [Hash{Parser::AST::Node => Array<Parser::Source::Comment>}]
20
+ def initialize(node, parent: nil, comments_by_node: {})
21
+ @node = node
22
+ super(parent: parent, comments_by_node: comments_by_node)
23
+ end
24
+
25
+ # @return [Array<Vnode>]
26
+ def children
27
+ @children ||= node.children.map(&method(:wrap_child))
28
+ end
29
+
30
+ # @return [String]
31
+ def identifier
32
+ "#{type}:#{source_map&.expression ? source_map_expression : object_id}"
33
+ end
34
+
35
+ # @return [Parser::Source::Map, nil]
36
+ def source_map
37
+ node.location
38
+ end
39
+
40
+ # @return [Symbol]
41
+ def kind
42
+ node.type
43
+ end
44
+
45
+ private
46
+
47
+ def source_map_expression
48
+ "#{source_map.expression.source_buffer.name}:(#{source_map.line},#{source_map.column})..(#{source_map.last_line},#{source_map.last_column})"
49
+ end
50
+ end
51
+ end
52
+ end
@@ -0,0 +1,20 @@
1
+ module Yoda
2
+ module AST
3
+ class OptionalParameterNode < Node
4
+ # @return [Node]
5
+ def content
6
+ children[0]
7
+ end
8
+
9
+ # @return [Node]
10
+ def optional_value
11
+ children[1]
12
+ end
13
+
14
+ # @return [Model::Parameters::Base]
15
+ def parameter
16
+ content.present? ? Model::Parameters::Named.new(content.name) : Model::Parameters::Unnamed.new
17
+ end
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,15 @@
1
+ module Yoda
2
+ module AST
3
+ class PairNode < Node
4
+ # @return [Vnode]
5
+ def key
6
+ children[0]
7
+ end
8
+
9
+ # @return [Vnode]
10
+ def value
11
+ children[1]
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,25 @@
1
+ module Yoda
2
+ module AST
3
+ class ParameterNode < Node
4
+ # @return [NameVnode, EmptyNode, nil]
5
+ def content
6
+ children[0]
7
+ end
8
+
9
+ # @return [Model::Parameters::Base]
10
+ def parameter
11
+ content&.present? ? Model::Parameters::Named.new(content.name) : Model::Parameters::Unnamed.new
12
+ end
13
+
14
+ # @return [Model::Parameters::Base]
15
+ def parameter_root
16
+ parameter_root_node.parameter
17
+ end
18
+
19
+ # @return [ParametersNode]
20
+ def parameter_root_node
21
+ parent.try(:parameter_root_node)
22
+ end
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,62 @@
1
+ module Yoda
2
+ module AST
3
+ class ParametersNode < Node
4
+ # @return [Array<ParameterNode>]
5
+ def parameter_clauses
6
+ children
7
+ end
8
+
9
+ # @return [Model::Parameters::Multiple]
10
+ def parameter
11
+ Model::Parameters::Multiple.new(
12
+ parameters: parameter_nodes.map(&:parameter),
13
+ rest_parameter: rest_parameter_node&.parameter,
14
+ post_parameters: post_parameter_nodes.map(&:parameter),
15
+ keyword_parameters: keyword_parameter_nodes.map(&:parameter),
16
+ keyword_rest_parameter: keyword_rest_parameter_node&.parameter,
17
+ block_parameter: block_parameter_node&.parameter,
18
+ )
19
+ end
20
+
21
+ # @return [Array<::AST::Node>]
22
+ def parameter_nodes
23
+ @parameter_nodes ||= children.take_while { |arg_node| %i(arg optarg mlhs).include?(arg_node.type) }
24
+ end
25
+
26
+ # @return [::AST::Node, nil]
27
+ def rest_parameter_node
28
+ @rest_parameter_node ||= children.find { |arg_node| arg_node.type == :restarg }
29
+ end
30
+
31
+ # @return [Array<::AST::Node>]
32
+ def post_parameter_nodes
33
+ @post_parameter_nodes ||= children.drop_while { |arg_node| %i(arg optarg mlhs).include?(arg_node.type) }.select { |arg_node| %i(arg optarg mlhs).include?(arg_node.type) }
34
+ end
35
+
36
+ # @return [Array<::AST::Node>]
37
+ def keyword_parameter_nodes
38
+ @keyword_parameter_nodes ||= children.select { |arg_node| %i(kwarg kwoptarg).include?(arg_node.type) }
39
+ end
40
+
41
+ # @return [::AST::Node, nil]
42
+ def keyword_rest_parameter_node
43
+ @keyword_rest_parameter_node ||= children.find { |arg_node| arg_node.type == :kwrestarg }
44
+ end
45
+
46
+ # @return [Node]
47
+ def block_parameter_node
48
+ @block_parameter_node ||= children.find { |arg_node| arg_node.type == :blockarg }
49
+ end
50
+
51
+ # @return [Model::Parameters::Base]
52
+ def parameter_root
53
+ parameter_root_node.parameter
54
+ end
55
+
56
+ # @return [ParametersNode]
57
+ def parameter_root_node
58
+ parent.try(:parameter_root_node) || self
59
+ end
60
+ end
61
+ end
62
+ end
@@ -0,0 +1,20 @@
1
+ module Yoda
2
+ module AST
3
+ class RescueClauseNode < Node
4
+ # @return [Node]
5
+ def match_clause
6
+ children[0]
7
+ end
8
+
9
+ # @return [Node]
10
+ def assignee
11
+ children[1]
12
+ end
13
+
14
+ # @return [Node]
15
+ def body
16
+ children[2]
17
+ end
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,20 @@
1
+ module Yoda
2
+ module AST
3
+ class RescueNode < Node
4
+ # @return [Node]
5
+ def body
6
+ children[0]
7
+ end
8
+
9
+ # @return [Array<RescueClauseNode>]
10
+ def rescue_clauses
11
+ children[1..-2]
12
+ end
13
+
14
+ # @return [Node]
15
+ def else_clause
16
+ children[-1]
17
+ end
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,48 @@
1
+ module Yoda
2
+ module AST
3
+ class RootVnode < Vnode
4
+ include Namespace
5
+
6
+ # @return [Parser::AST::Node]
7
+ attr_reader :node
8
+
9
+ # @param node [Parser::AST::Node]
10
+ # @param comment_by_node [Hash{Parser::AST::Node => Array<Parser::Source::Comment>}]
11
+ def initialize(node, comments_by_node: {})
12
+ @node = node
13
+ @comments_by_node = comments_by_node
14
+ end
15
+
16
+ # @return [nil]
17
+ def parent
18
+ nil
19
+ end
20
+
21
+ # @return [Symbol]
22
+ def type
23
+ :root
24
+ end
25
+
26
+ # @return [Vnode]
27
+ def content
28
+ @content ||= wrap_child(node)
29
+ end
30
+
31
+ # @return [Array<Vnode>]
32
+ def children
33
+ [content]
34
+ end
35
+
36
+ # @return [String]
37
+ def identifier
38
+ "#{type}:#{source_map.expression}"
39
+ end
40
+
41
+ # @return [Parser::Source::Map, nil]
42
+ def source_map
43
+ node.location
44
+ end
45
+ end
46
+ end
47
+ end
48
+
@@ -0,0 +1,100 @@
1
+ module Yoda
2
+ module AST
3
+ class SendNode < Node
4
+ # @return [Vnode]
5
+ def receiver
6
+ children[0]
7
+ end
8
+
9
+ # @return [NameVnode]
10
+ def selector
11
+ children[1]
12
+ end
13
+
14
+ # @return [Symbol]
15
+ def selector_name
16
+ selector.name
17
+ end
18
+
19
+ # @return [Array<Vnode>]
20
+ def arguments
21
+ children.slice(2..-1)
22
+ end
23
+
24
+ # @return [Array<Vnode>]
25
+ def expanded_arguments
26
+ block_pass_arguments, arguments_without_block_pass = arguments.partition { |node| node.type == :block_pass }
27
+ if last_argument = arguments_without_block_pass.last
28
+ arguments_without_block_pass.slice(0..-2) + (last_argument.type == :hash ? last_argument.children : [last_argument]) + block_pass_arguments
29
+ else
30
+ arguments_without_block_pass.slice(0..-2) + block_pass_arguments
31
+ end
32
+ end
33
+
34
+ def keyword_argument
35
+ non_bpass_arguments = arguments.reject { |node| node.type == :block_pass }
36
+ non_bpass_arguments.last&.type == :hash ? non_bpass_arguments.last : nil
37
+ end
38
+
39
+ def block_pass_argument
40
+ arguments.last.type == :block_pass ? arguments.last : nil
41
+ end
42
+
43
+ def implicit_receiver?
44
+ receiver.empty?
45
+ end
46
+
47
+ # @return [true, false]
48
+ def on_selector?(location)
49
+ source_map.selector ? selector_range.include?(location) : false
50
+ end
51
+
52
+ # @param location [Parsing::Location]
53
+ # @return [true, false]
54
+ def on_dot?(location)
55
+ source_map.dot ? dot_range.include?(location) : false
56
+ end
57
+
58
+ # @param location [Parsing::Location]
59
+ # @return [true, false]
60
+ def on_arguments?(location)
61
+ arguments_range.include?(location)
62
+ end
63
+
64
+ # @return [Parsing::Range]
65
+ def arguments_range
66
+ @arguments_range ||=
67
+ Parsing::Range.new(
68
+ Parsing::Location.of_ast_location(source_map.selector.end),
69
+ Parsing::Location.of_ast_location(source_map.expression.end).move(row: 0, column: -1),
70
+ )
71
+ end
72
+
73
+ # @return [Parsing::Range]
74
+ def selector_range
75
+ @selector_range ||= Parsing::Range.of_ast_location(source_map.selector)
76
+ end
77
+
78
+ # @return [Parsing::Range, nil]
79
+ def dot_range
80
+ @dot_range ||= source_map.dot && Parsing::Range.of_ast_location(source_map.dot)
81
+ end
82
+
83
+ # @return [Parsing::Location, nil]
84
+ def next_location_to_dot
85
+ source_map.dot && Parsing::Range.of_ast_location(source_map.dot).end_location
86
+ end
87
+
88
+ # @return [String]
89
+ def selector_name
90
+ selector.name.to_s
91
+ end
92
+
93
+ # @param location [Parsing::Location]
94
+ # @return [Integer]
95
+ def offset_in_selector(location)
96
+ location.offset_from_begin(source_map.selector)[:column]
97
+ end
98
+ end
99
+ end
100
+ end
@@ -0,0 +1,17 @@
1
+ module Yoda
2
+ module AST
3
+ class SingletonClassNode < Node
4
+ include Namespace
5
+
6
+ # @return [ConstantNode]
7
+ def receiver
8
+ children[0]
9
+ end
10
+
11
+ # @return [Vnode]
12
+ def body
13
+ children[1]
14
+ end
15
+ end
16
+ end
17
+ end
@@ -0,0 +1,10 @@
1
+ module Yoda
2
+ module AST
3
+ class SpecialCallNode < Node
4
+ # @return [Array<Node>]
5
+ def arguments
6
+ children
7
+ end
8
+ end
9
+ end
10
+ end
@@ -0,0 +1,34 @@
1
+ module Yoda
2
+ module AST
3
+ # Add query methods to search expected nodes from AST.
4
+ # @see {Yoda::Parsing::Traverser::Matcher} for parameters of query methods.
5
+ # @example
6
+ # ast.query(type: :if) # => returns a if node
7
+ # ast.query(name: :hoge) # => returns a node about an object with the name
8
+ module Traversable
9
+ # @param query [Hash] (See {Yoda::Parsing::Traverser::Matcher.new} for detailed parameters)
10
+ # @return [Vnode, nil]
11
+ def query(**query)
12
+ Parsing::Traverser.new(self).query(**query)&.node
13
+ end
14
+
15
+ # @param query [Hash] (See {Yoda::Parsing::Traverser::Matcher.new} for detailed parameters)
16
+ # @return [Parsing::Traverser::ResultSet]
17
+ def query_all(**query)
18
+ Parsing::Traverser.new(self).query(**query)
19
+ end
20
+
21
+ # @param query [Hash] (See {Yoda::Parsing::Traverser::Matcher.new} for detailed parameters)
22
+ # @return [Vnode, nil]
23
+ def query_ancestor(**query)
24
+ Parsing::Traverser.new(self).query_ancestor(**query)&.node
25
+ end
26
+
27
+ # @param query [Hash] (See {Yoda::Parsing::Traverser::Matcher.new} for detailed parameters)
28
+ # @return [Parsing::Traverser::ResultSet]
29
+ def query_ancestors(**query)
30
+ Parsing::Traverser.new(self).query_ancestors(**query)
31
+ end
32
+ end
33
+ end
34
+ end