solargraph 0.54.4 → 0.58.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (238) hide show
  1. checksums.yaml +4 -4
  2. data/.gitattributes +2 -0
  3. data/.github/workflows/linting.yml +127 -0
  4. data/.github/workflows/plugins.yml +185 -6
  5. data/.github/workflows/rspec.yml +55 -5
  6. data/.github/workflows/typecheck.yml +8 -3
  7. data/.gitignore +8 -0
  8. data/.overcommit.yml +72 -0
  9. data/.rspec +1 -0
  10. data/.rubocop.yml +66 -0
  11. data/.rubocop_todo.yml +1279 -0
  12. data/.yardopts +1 -0
  13. data/CHANGELOG.md +143 -0
  14. data/README.md +20 -6
  15. data/Rakefile +125 -13
  16. data/bin/solargraph +3 -0
  17. data/lib/solargraph/api_map/cache.rb +110 -109
  18. data/lib/solargraph/api_map/constants.rb +279 -0
  19. data/lib/solargraph/api_map/index.rb +193 -167
  20. data/lib/solargraph/api_map/source_to_yard.rb +97 -88
  21. data/lib/solargraph/api_map/store.rb +384 -241
  22. data/lib/solargraph/api_map.rb +945 -875
  23. data/lib/solargraph/bench.rb +45 -28
  24. data/lib/solargraph/complex_type/type_methods.rb +228 -217
  25. data/lib/solargraph/complex_type/unique_type.rb +482 -386
  26. data/lib/solargraph/complex_type.rb +444 -394
  27. data/lib/solargraph/convention/active_support_concern.rb +111 -0
  28. data/lib/solargraph/convention/base.rb +20 -3
  29. data/lib/solargraph/convention/data_definition/data_assignment_node.rb +61 -0
  30. data/lib/solargraph/convention/data_definition/data_definition_node.rb +91 -0
  31. data/lib/solargraph/convention/data_definition.rb +105 -0
  32. data/lib/solargraph/convention/gemfile.rb +15 -15
  33. data/lib/solargraph/convention/gemspec.rb +23 -22
  34. data/lib/solargraph/convention/rakefile.rb +17 -17
  35. data/lib/solargraph/convention/struct_definition/struct_assignment_node.rb +61 -0
  36. data/lib/solargraph/convention/struct_definition/struct_definition_node.rb +102 -0
  37. data/lib/solargraph/convention/struct_definition.rb +164 -0
  38. data/lib/solargraph/convention.rb +78 -47
  39. data/lib/solargraph/converters/dd.rb +17 -17
  40. data/lib/solargraph/converters/dl.rb +15 -15
  41. data/lib/solargraph/converters/dt.rb +15 -15
  42. data/lib/solargraph/converters/misc.rb +1 -1
  43. data/lib/solargraph/diagnostics/require_not_found.rb +53 -53
  44. data/lib/solargraph/diagnostics/rubocop.rb +118 -113
  45. data/lib/solargraph/diagnostics/rubocop_helpers.rb +68 -66
  46. data/lib/solargraph/diagnostics/type_check.rb +55 -55
  47. data/lib/solargraph/diagnostics/update_errors.rb +41 -41
  48. data/lib/solargraph/doc_map.rb +439 -188
  49. data/lib/solargraph/environ.rb +9 -2
  50. data/lib/solargraph/equality.rb +34 -33
  51. data/lib/solargraph/gem_pins.rb +98 -72
  52. data/lib/solargraph/language_server/error_codes.rb +20 -20
  53. data/lib/solargraph/language_server/host/diagnoser.rb +89 -89
  54. data/lib/solargraph/language_server/host/dispatch.rb +130 -128
  55. data/lib/solargraph/language_server/host/message_worker.rb +112 -106
  56. data/lib/solargraph/language_server/host/sources.rb +99 -99
  57. data/lib/solargraph/language_server/host.rb +878 -861
  58. data/lib/solargraph/language_server/message/base.rb +97 -96
  59. data/lib/solargraph/language_server/message/client/register_capability.rb +15 -15
  60. data/lib/solargraph/language_server/message/completion_item/resolve.rb +60 -60
  61. data/lib/solargraph/language_server/message/extended/check_gem_version.rb +114 -112
  62. data/lib/solargraph/language_server/message/extended/document.rb +23 -20
  63. data/lib/solargraph/language_server/message/extended/document_gems.rb +32 -32
  64. data/lib/solargraph/language_server/message/extended/download_core.rb +19 -19
  65. data/lib/solargraph/language_server/message/extended/search.rb +20 -20
  66. data/lib/solargraph/language_server/message/initialize.rb +191 -191
  67. data/lib/solargraph/language_server/message/text_document/completion.rb +56 -56
  68. data/lib/solargraph/language_server/message/text_document/definition.rb +40 -38
  69. data/lib/solargraph/language_server/message/text_document/document_highlight.rb +16 -16
  70. data/lib/solargraph/language_server/message/text_document/document_symbol.rb +26 -26
  71. data/lib/solargraph/language_server/message/text_document/formatting.rb +148 -131
  72. data/lib/solargraph/language_server/message/text_document/hover.rb +58 -58
  73. data/lib/solargraph/language_server/message/text_document/prepare_rename.rb +11 -11
  74. data/lib/solargraph/language_server/message/text_document/references.rb +16 -16
  75. data/lib/solargraph/language_server/message/text_document/rename.rb +19 -19
  76. data/lib/solargraph/language_server/message/text_document/signature_help.rb +24 -24
  77. data/lib/solargraph/language_server/message/text_document/type_definition.rb +25 -24
  78. data/lib/solargraph/language_server/message/workspace/did_change_configuration.rb +35 -35
  79. data/lib/solargraph/language_server/message/workspace/did_change_watched_files.rb +40 -40
  80. data/lib/solargraph/language_server/message/workspace/did_change_workspace_folders.rb +26 -24
  81. data/lib/solargraph/language_server/message/workspace/workspace_symbol.rb +23 -23
  82. data/lib/solargraph/language_server/message.rb +94 -94
  83. data/lib/solargraph/language_server/progress.rb +8 -0
  84. data/lib/solargraph/language_server/request.rb +27 -24
  85. data/lib/solargraph/language_server/transport/data_reader.rb +74 -74
  86. data/lib/solargraph/language_server/uri_helpers.rb +49 -49
  87. data/lib/solargraph/library.rb +683 -662
  88. data/lib/solargraph/location.rb +82 -58
  89. data/lib/solargraph/logging.rb +37 -27
  90. data/lib/solargraph/page.rb +92 -89
  91. data/lib/solargraph/parser/comment_ripper.rb +69 -56
  92. data/lib/solargraph/parser/flow_sensitive_typing.rb +255 -0
  93. data/lib/solargraph/parser/node_processor/base.rb +92 -87
  94. data/lib/solargraph/parser/node_processor.rb +62 -45
  95. data/lib/solargraph/parser/parser_gem/class_methods.rb +149 -157
  96. data/lib/solargraph/parser/parser_gem/flawed_builder.rb +19 -18
  97. data/lib/solargraph/parser/parser_gem/node_chainer.rb +166 -164
  98. data/lib/solargraph/parser/parser_gem/node_methods.rb +486 -495
  99. data/lib/solargraph/parser/parser_gem/node_processors/alias_node.rb +2 -1
  100. data/lib/solargraph/parser/parser_gem/node_processors/and_node.rb +22 -0
  101. data/lib/solargraph/parser/parser_gem/node_processors/args_node.rb +59 -57
  102. data/lib/solargraph/parser/parser_gem/node_processors/begin_node.rb +15 -15
  103. data/lib/solargraph/parser/parser_gem/node_processors/block_node.rb +46 -43
  104. data/lib/solargraph/parser/parser_gem/node_processors/casgn_node.rb +2 -1
  105. data/lib/solargraph/parser/parser_gem/node_processors/cvasgn_node.rb +2 -1
  106. data/lib/solargraph/parser/parser_gem/node_processors/def_node.rb +53 -50
  107. data/lib/solargraph/parser/parser_gem/node_processors/defs_node.rb +37 -36
  108. data/lib/solargraph/parser/parser_gem/node_processors/gvasgn_node.rb +2 -1
  109. data/lib/solargraph/parser/parser_gem/node_processors/if_node.rb +23 -0
  110. data/lib/solargraph/parser/parser_gem/node_processors/ivasgn_node.rb +40 -38
  111. data/lib/solargraph/parser/parser_gem/node_processors/lvasgn_node.rb +29 -28
  112. data/lib/solargraph/parser/parser_gem/node_processors/masgn_node.rb +59 -53
  113. data/lib/solargraph/parser/parser_gem/node_processors/namespace_node.rb +8 -7
  114. data/lib/solargraph/parser/parser_gem/node_processors/opasgn_node.rb +98 -0
  115. data/lib/solargraph/parser/parser_gem/node_processors/orasgn_node.rb +17 -16
  116. data/lib/solargraph/parser/parser_gem/node_processors/resbody_node.rb +38 -36
  117. data/lib/solargraph/parser/parser_gem/node_processors/sclass_node.rb +52 -42
  118. data/lib/solargraph/parser/parser_gem/node_processors/send_node.rb +291 -259
  119. data/lib/solargraph/parser/parser_gem/node_processors/sym_node.rb +3 -1
  120. data/lib/solargraph/parser/parser_gem/node_processors/until_node.rb +29 -0
  121. data/lib/solargraph/parser/parser_gem/node_processors/while_node.rb +29 -0
  122. data/lib/solargraph/parser/parser_gem/node_processors.rb +70 -56
  123. data/lib/solargraph/parser/parser_gem.rb +12 -12
  124. data/lib/solargraph/parser/region.rb +69 -66
  125. data/lib/solargraph/parser/snippet.rb +17 -15
  126. data/lib/solargraph/parser.rb +23 -22
  127. data/lib/solargraph/pin/base.rb +729 -378
  128. data/lib/solargraph/pin/base_variable.rb +126 -118
  129. data/lib/solargraph/pin/block.rb +104 -101
  130. data/lib/solargraph/pin/breakable.rb +9 -0
  131. data/lib/solargraph/pin/callable.rb +231 -147
  132. data/lib/solargraph/pin/closure.rb +72 -57
  133. data/lib/solargraph/pin/common.rb +79 -70
  134. data/lib/solargraph/pin/constant.rb +45 -43
  135. data/lib/solargraph/pin/conversions.rb +123 -123
  136. data/lib/solargraph/pin/delegated_method.rb +120 -101
  137. data/lib/solargraph/pin/documenting.rb +114 -98
  138. data/lib/solargraph/pin/instance_variable.rb +34 -34
  139. data/lib/solargraph/pin/keyword.rb +20 -15
  140. data/lib/solargraph/pin/local_variable.rb +75 -67
  141. data/lib/solargraph/pin/method.rb +672 -527
  142. data/lib/solargraph/pin/method_alias.rb +34 -31
  143. data/lib/solargraph/pin/namespace.rb +115 -107
  144. data/lib/solargraph/pin/parameter.rb +275 -212
  145. data/lib/solargraph/pin/proxy_type.rb +39 -29
  146. data/lib/solargraph/pin/reference/override.rb +47 -29
  147. data/lib/solargraph/pin/reference/require.rb +2 -2
  148. data/lib/solargraph/pin/reference/superclass.rb +15 -10
  149. data/lib/solargraph/pin/reference.rb +39 -22
  150. data/lib/solargraph/pin/search.rb +61 -56
  151. data/lib/solargraph/pin/signature.rb +61 -17
  152. data/lib/solargraph/pin/singleton.rb +1 -1
  153. data/lib/solargraph/pin/symbol.rb +53 -47
  154. data/lib/solargraph/pin/until.rb +18 -0
  155. data/lib/solargraph/pin/while.rb +18 -0
  156. data/lib/solargraph/pin.rb +44 -41
  157. data/lib/solargraph/pin_cache.rb +245 -0
  158. data/lib/solargraph/position.rb +132 -107
  159. data/lib/solargraph/range.rb +112 -98
  160. data/lib/solargraph/rbs_map/conversions.rb +823 -646
  161. data/lib/solargraph/rbs_map/core_fills.rb +84 -50
  162. data/lib/solargraph/rbs_map/core_map.rb +58 -28
  163. data/lib/solargraph/rbs_map/stdlib_map.rb +43 -33
  164. data/lib/solargraph/rbs_map.rb +163 -93
  165. data/lib/solargraph/server_methods.rb +16 -16
  166. data/lib/solargraph/shell.rb +363 -269
  167. data/lib/solargraph/source/chain/array.rb +37 -33
  168. data/lib/solargraph/source/chain/block_symbol.rb +1 -1
  169. data/lib/solargraph/source/chain/block_variable.rb +1 -1
  170. data/lib/solargraph/source/chain/call.rb +337 -303
  171. data/lib/solargraph/source/chain/class_variable.rb +13 -13
  172. data/lib/solargraph/source/chain/constant.rb +26 -89
  173. data/lib/solargraph/source/chain/global_variable.rb +13 -13
  174. data/lib/solargraph/source/chain/hash.rb +34 -33
  175. data/lib/solargraph/source/chain/head.rb +1 -1
  176. data/lib/solargraph/source/chain/if.rb +28 -28
  177. data/lib/solargraph/source/chain/instance_variable.rb +13 -13
  178. data/lib/solargraph/source/chain/link.rb +109 -98
  179. data/lib/solargraph/source/chain/literal.rb +48 -28
  180. data/lib/solargraph/source/chain/or.rb +23 -23
  181. data/lib/solargraph/source/chain/q_call.rb +11 -11
  182. data/lib/solargraph/source/chain/variable.rb +13 -13
  183. data/lib/solargraph/source/chain/z_super.rb +30 -30
  184. data/lib/solargraph/source/chain.rb +291 -252
  185. data/lib/solargraph/source/change.rb +82 -82
  186. data/lib/solargraph/source/cursor.rb +166 -167
  187. data/lib/solargraph/source/encoding_fixes.rb +23 -23
  188. data/lib/solargraph/source/source_chainer.rb +194 -194
  189. data/lib/solargraph/source/updater.rb +55 -55
  190. data/lib/solargraph/source.rb +498 -495
  191. data/lib/solargraph/source_map/clip.rb +226 -232
  192. data/lib/solargraph/source_map/data.rb +34 -30
  193. data/lib/solargraph/source_map/mapper.rb +259 -255
  194. data/lib/solargraph/source_map.rb +212 -217
  195. data/lib/solargraph/type_checker/checks.rb +124 -120
  196. data/lib/solargraph/type_checker/param_def.rb +37 -35
  197. data/lib/solargraph/type_checker/problem.rb +32 -32
  198. data/lib/solargraph/type_checker/rules.rb +84 -62
  199. data/lib/solargraph/type_checker.rb +814 -672
  200. data/lib/solargraph/version.rb +5 -5
  201. data/lib/solargraph/views/_method.erb +10 -10
  202. data/lib/solargraph/views/_namespace.erb +3 -3
  203. data/lib/solargraph/views/document.erb +10 -10
  204. data/lib/solargraph/workspace/config.rb +255 -239
  205. data/lib/solargraph/workspace/require_paths.rb +97 -0
  206. data/lib/solargraph/workspace.rb +220 -239
  207. data/lib/solargraph/yard_map/helpers.rb +44 -16
  208. data/lib/solargraph/yard_map/mapper/to_constant.rb +7 -5
  209. data/lib/solargraph/yard_map/mapper/to_method.rb +130 -94
  210. data/lib/solargraph/yard_map/mapper/to_namespace.rb +31 -28
  211. data/lib/solargraph/yard_map/mapper.rb +79 -78
  212. data/lib/solargraph/yard_map/to_method.rb +89 -86
  213. data/lib/solargraph/yard_tags.rb +20 -20
  214. data/lib/solargraph/yardoc.rb +87 -52
  215. data/lib/solargraph.rb +105 -72
  216. data/rbs/fills/bundler/0/bundler.rbs +4271 -0
  217. data/rbs/fills/open3/0/open3.rbs +172 -0
  218. data/rbs/fills/rubygems/0/basic_specification.rbs +326 -0
  219. data/rbs/fills/rubygems/0/errors.rbs +364 -0
  220. data/rbs/fills/rubygems/0/spec_fetcher.rbs +107 -0
  221. data/rbs/fills/rubygems/0/specification.rbs +1753 -0
  222. data/rbs/fills/tuple/tuple.rbs +149 -0
  223. data/rbs/shims/ast/0/node.rbs +5 -0
  224. data/rbs/shims/ast/2.4/.rbs_meta.yaml +9 -0
  225. data/rbs/shims/ast/2.4/ast.rbs +73 -0
  226. data/rbs/shims/parser/3.2.0.1/builders/default.rbs +195 -0
  227. data/rbs/shims/parser/3.2.0.1/manifest.yaml +7 -0
  228. data/rbs/shims/parser/3.2.0.1/parser.rbs +201 -0
  229. data/rbs/shims/parser/3.2.0.1/polyfill.rbs +4 -0
  230. data/rbs/shims/thor/1.2.0.1/.rbs_meta.yaml +9 -0
  231. data/rbs/shims/thor/1.2.0.1/manifest.yaml +7 -0
  232. data/rbs/shims/thor/1.2.0.1/thor.rbs +17 -0
  233. data/rbs_collection.yaml +19 -0
  234. data/solargraph.gemspec +27 -5
  235. metadata +215 -18
  236. data/lib/.rubocop.yml +0 -22
  237. data/lib/solargraph/cache.rb +0 -77
  238. data/lib/solargraph/parser/node_methods.rb +0 -83
@@ -1,241 +1,384 @@
1
- # frozen_string_literal: true
2
-
3
-
4
- module Solargraph
5
- class ApiMap
6
- # Queryable collection of Pins representing a Workspace, gems and the Ruby
7
- # core.
8
- #
9
- class Store
10
- # @param static [Enumerable<Pin::Base>]
11
- # @param dynamic [Enumerable<Pin::Base>]
12
- def initialize static = [], dynamic = []
13
- @static_index = Index.new(static)
14
- @dynamic = dynamic
15
- @index = @static_index.merge(dynamic)
16
- end
17
-
18
- # @return [Array<Solargraph::Pin::Base>]
19
- def pins
20
- index.pins
21
- end
22
-
23
- # @param static [Enumerable<Pin::Base>]
24
- # @param dynamic [Enumerable<Pin::Base>]
25
- def update! static = [], dynamic = []
26
- # @todo Fix this map
27
- @fqns_pins_map = nil
28
- if @static_index.pins == static
29
- return self if @dynamic == dynamic
30
- else
31
- @static_index = Index.new(static)
32
- end
33
- @dynamic = dynamic
34
- @index = @static_index.merge(dynamic)
35
- self
36
- end
37
-
38
- def to_s
39
- self.class.to_s
40
- end
41
-
42
- def inspect
43
- to_s
44
- end
45
-
46
- # @param fqns [String]
47
- # @param visibility [Array<Symbol>]
48
- # @return [Enumerable<Solargraph::Pin::Base>]
49
- def get_constants fqns, visibility = [:public]
50
- namespace_children(fqns).select { |pin|
51
- !pin.name.empty? && (pin.is_a?(Pin::Namespace) || pin.is_a?(Pin::Constant)) && visibility.include?(pin.visibility)
52
- }
53
- end
54
-
55
- # @param fqns [String]
56
- # @param scope [Symbol]
57
- # @param visibility [Array<Symbol>]
58
- # @return [Enumerable<Solargraph::Pin::Method>]
59
- def get_methods fqns, scope: :instance, visibility: [:public]
60
- namespace_children(fqns).select do |pin|
61
- pin.is_a?(Pin::Method) && pin.scope == scope && visibility.include?(pin.visibility)
62
- end
63
- end
64
-
65
- # @param fqns [String]
66
- # @return [String, nil]
67
- def get_superclass fqns
68
- raise "Do not prefix fully qualified namespaces with '::' - #{fqns.inspect}" if fqns.start_with?('::')
69
- return superclass_references[fqns].first if superclass_references.key?(fqns)
70
- return 'Object' if fqns != 'BasicObject' && namespace_exists?(fqns)
71
- return 'Object' if fqns == 'Boolean'
72
- nil
73
- end
74
-
75
- # @param fqns [String]
76
- # @return [Array<String>]
77
- def get_includes fqns
78
- include_references[fqns] || []
79
- end
80
-
81
- # @param fqns [String]
82
- # @return [Array<String>]
83
- def get_prepends fqns
84
- prepend_references[fqns] || []
85
- end
86
-
87
- # @param fqns [String]
88
- # @return [Array<String>]
89
- def get_extends fqns
90
- extend_references[fqns] || []
91
- end
92
-
93
- # @param path [String]
94
- # @return [Array<Solargraph::Pin::Base>]
95
- def get_path_pins path
96
- index.path_pin_hash[path]
97
- end
98
-
99
- # @param fqns [String]
100
- # @param scope [Symbol] :class or :instance
101
- # @return [Enumerable<Solargraph::Pin::Base>]
102
- def get_instance_variables(fqns, scope = :instance)
103
- all_instance_variables.select { |pin|
104
- pin.binder.namespace == fqns && pin.binder.scope == scope
105
- }
106
- end
107
-
108
- # @param fqns [String]
109
- # @return [Enumerable<Solargraph::Pin::Base>]
110
- def get_class_variables(fqns)
111
- namespace_children(fqns).select{|pin| pin.is_a?(Pin::ClassVariable)}
112
- end
113
-
114
- # @return [Enumerable<Solargraph::Pin::Base>]
115
- def get_symbols
116
- symbols.uniq(&:name)
117
- end
118
-
119
- # @param fqns [String]
120
- # @return [Boolean]
121
- def namespace_exists?(fqns)
122
- fqns_pins(fqns).any?
123
- end
124
-
125
- # @return [Set<String>]
126
- def namespaces
127
- index.namespaces
128
- end
129
-
130
- # @return [Enumerable<Solargraph::Pin::Namespace>]
131
- def namespace_pins
132
- pins_by_class(Solargraph::Pin::Namespace)
133
- end
134
-
135
- # @return [Enumerable<Solargraph::Pin::Method>]
136
- def method_pins
137
- pins_by_class(Solargraph::Pin::Method)
138
- end
139
-
140
- # @param fqns [String]
141
- # @return [Array<String>]
142
- def domains(fqns)
143
- result = []
144
- fqns_pins(fqns).each do |nspin|
145
- result.concat nspin.domains
146
- end
147
- result
148
- end
149
-
150
- # @return [Hash{String => YARD::Tags::MacroDirective}]
151
- def named_macros
152
- @named_macros ||= begin
153
- result = {}
154
- pins.each do |pin|
155
- pin.macros.select{|m| m.tag.tag_name == 'macro' && !m.tag.text.empty? }.each do |macro|
156
- next if macro.tag.name.nil? || macro.tag.name.empty?
157
- result[macro.tag.name] = macro
158
- end
159
- end
160
- result
161
- end
162
- end
163
-
164
- # @return [Enumerable<Pin::Block>]
165
- def block_pins
166
- pins_by_class(Pin::Block)
167
- end
168
-
169
- # @generic T
170
- # @param klass [Class<generic<T>>]
171
- # @return [Set<generic<T>>]
172
- def pins_by_class klass
173
- index.pins_by_class klass
174
- end
175
-
176
- # @param fqns [String]
177
- # @return [Array<Solargraph::Pin::Namespace>]
178
- def fqns_pins fqns
179
- return [] if fqns.nil?
180
- if fqns.include?('::')
181
- parts = fqns.split('::')
182
- name = parts.pop
183
- base = parts.join('::')
184
- else
185
- base = ''
186
- name = fqns
187
- end
188
- fqns_pins_map[[base, name]]
189
- end
190
-
191
- private
192
-
193
- attr_reader :index
194
-
195
- # @return [Hash{::Array(String, String) => ::Array<Pin::Namespace>}]
196
- def fqns_pins_map
197
- @fqns_pins_map ||= Hash.new do |h, (base, name)|
198
- value = namespace_children(base).select { |pin| pin.name == name && pin.is_a?(Pin::Namespace) }
199
- h[[base, name]] = value
200
- end
201
- end
202
-
203
- # @return [Enumerable<Solargraph::Pin::Symbol>]
204
- def symbols
205
- index.pins_by_class(Pin::Symbol)
206
- end
207
-
208
- # @return [Hash{String => Array<String>}]
209
- def superclass_references
210
- index.superclass_references
211
- end
212
-
213
- # @return [Hash{String => Array<String>}]
214
- def include_references
215
- index.include_references
216
- end
217
-
218
- # @return [Hash{String => Array<String>}]
219
- def prepend_references
220
- index.prepend_references
221
- end
222
-
223
- # @return [Hash{String => Array<String>}]
224
- def extend_references
225
- index.extend_references
226
- end
227
-
228
- # @param name [String]
229
- # @return [Enumerable<Solargraph::Pin::Base>]
230
- def namespace_children name
231
- return [] unless index.namespace_hash.key?(name)
232
- index.namespace_hash[name]
233
- end
234
-
235
- # @return [Enumerable<Pin::InstanceVariable>]
236
- def all_instance_variables
237
- index.pins_by_class(Pin::InstanceVariable)
238
- end
239
- end
240
- end
241
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Solargraph
4
+ class ApiMap
5
+ # Queryable collection of Pins representing a Workspace, gems and the Ruby
6
+ # core.
7
+ #
8
+ class Store
9
+ # @param pinsets [Array<Enumerable<Pin::Base>>]
10
+ def initialize *pinsets
11
+ @pinsets = pinsets
12
+ catalog pinsets
13
+ end
14
+
15
+ # @return [Array<Solargraph::Pin::Base>]
16
+ def pins
17
+ index.pins
18
+ end
19
+
20
+ # @param pinsets [Array<Array<Pin::Base>>]
21
+ # - pinsets[0] = core Ruby pins
22
+ # - pinsets[1] = documentation/gem pins
23
+ # - pinsets[2] = convention pins
24
+ # - pinsets[3] = workspace source pins
25
+ # - pinsets[4] = currently open file pins
26
+ # @return [Boolean] True if the index was updated
27
+ def update *pinsets
28
+ return catalog(pinsets) if pinsets.length != @pinsets.length
29
+
30
+ changed = pinsets.find_index.with_index { |pinset, idx| @pinsets[idx] != pinset }
31
+ return false unless changed
32
+
33
+ # @todo Fix this map
34
+ @fqns_pins_map = nil
35
+ return catalog(pinsets) if changed == 0
36
+
37
+ pinsets[changed..].each_with_index do |pins, idx|
38
+ @pinsets[changed + idx] = pins
39
+ @indexes[changed + idx] = if pins.empty?
40
+ @indexes[changed + idx - 1]
41
+ else
42
+ @indexes[changed + idx - 1].merge(pins)
43
+ end
44
+ end
45
+ constants.clear
46
+ cached_qualify_superclass.clear
47
+ true
48
+ end
49
+
50
+ def to_s
51
+ self.class.to_s
52
+ end
53
+
54
+ def inspect
55
+ to_s
56
+ end
57
+
58
+ # @param fqns [String]
59
+ # @param visibility [Array<Symbol>]
60
+ # @return [Enumerable<Solargraph::Pin::Namespace, Solargraph::Pin::Constant>]
61
+ def get_constants fqns, visibility = [:public]
62
+ namespace_children(fqns).select { |pin|
63
+ # @sg-ignore flow-sensitive typing not smart enough to handle this case
64
+ !pin.name.empty? && (pin.is_a?(Pin::Namespace) || pin.is_a?(Pin::Constant)) && visibility.include?(pin.visibility)
65
+ }
66
+ end
67
+
68
+ # @param fqns [String]
69
+ # @param scope [Symbol]
70
+ # @param visibility [Array<Symbol>]
71
+ # @return [Enumerable<Solargraph::Pin::Method>]
72
+ def get_methods fqns, scope: :instance, visibility: [:public]
73
+ all_pins = namespace_children(fqns).select do |pin|
74
+ # @sg-ignore https://github.com/castwide/solargraph/pull/1114
75
+ pin.is_a?(Pin::Method) && pin.scope == scope && visibility.include?(pin.visibility)
76
+ end
77
+ GemPins.combine_method_pins_by_path(all_pins)
78
+ end
79
+
80
+ BOOLEAN_SUPERCLASS_PIN = Pin::Reference::Superclass.new(name: 'Boolean', closure: Pin::ROOT_PIN, source: :solargraph)
81
+ OBJECT_SUPERCLASS_PIN = Pin::Reference::Superclass.new(name: 'Object', closure: Pin::ROOT_PIN, source: :solargraph)
82
+
83
+ # @param fqns [String]
84
+ # @return [Pin::Reference::Superclass]
85
+ def get_superclass fqns
86
+ return nil if fqns.nil? || fqns.empty?
87
+ return BOOLEAN_SUPERCLASS_PIN if %w[TrueClass FalseClass].include?(fqns)
88
+
89
+ superclass_references[fqns].first || try_special_superclasses(fqns)
90
+ end
91
+
92
+ # @param fq_sub_tag [String]
93
+ # @return [String, nil]
94
+ def qualify_superclass fq_sub_tag
95
+ cached_qualify_superclass[fq_sub_tag] || qualify_and_cache_superclass(fq_sub_tag)
96
+ type = ComplexType.try_parse(fq_sub_tag)
97
+ return type.simplify_literals.to_s if type.literal?
98
+ ref = get_superclass(fq_sub_tag)
99
+ return unless ref
100
+ res = constants.dereference(ref)
101
+ return unless res
102
+ res
103
+ end
104
+
105
+ # @param fqns [String]
106
+ # @return [Array<Pin::Reference::Include>]
107
+ def get_includes fqns
108
+ include_references[fqns] || []
109
+ end
110
+
111
+ # @param fqns [String]
112
+ # @return [Array<Pin::Reference::Prepend>]
113
+ def get_prepends fqns
114
+ prepend_references[fqns] || []
115
+ end
116
+
117
+ # @param fqns [String]
118
+ # @return [Array<Pin::Reference::Extend>]
119
+ def get_extends fqns
120
+ extend_references[fqns] || []
121
+ end
122
+
123
+ # @param path [String]
124
+ # @return [Array<Solargraph::Pin::Base>]
125
+ def get_path_pins path
126
+ index.path_pin_hash[path]
127
+ end
128
+
129
+ # @param fqns [String]
130
+ # @param scope [Symbol] :class or :instance
131
+ # @return [Enumerable<Solargraph::Pin::Base>]
132
+ def get_instance_variables(fqns, scope = :instance)
133
+ all_instance_variables.select { |pin|
134
+ pin.binder.namespace == fqns && pin.binder.scope == scope
135
+ }
136
+ end
137
+
138
+ # @param fqns [String]
139
+ #
140
+ # @return [Enumerable<Solargraph::Pin::ClassVariable>]
141
+ def get_class_variables(fqns)
142
+ namespace_children(fqns).select { |pin| pin.is_a?(Pin::ClassVariable)}
143
+ end
144
+
145
+ # @return [Enumerable<Solargraph::Pin::Base>]
146
+ def get_symbols
147
+ symbols.uniq(&:name)
148
+ end
149
+
150
+ # @param fqns [String]
151
+ # @return [Boolean]
152
+ def namespace_exists?(fqns)
153
+ fqns_pins(fqns).any?
154
+ end
155
+
156
+ # @return [Enumerable<Solargraph::Pin::Namespace>]
157
+ def namespace_pins
158
+ pins_by_class(Solargraph::Pin::Namespace)
159
+ end
160
+
161
+ # @return [Enumerable<Solargraph::Pin::Method>]
162
+ def method_pins
163
+ pins_by_class(Solargraph::Pin::Method)
164
+ end
165
+
166
+ # @param fqns [String]
167
+ # @return [Array<String>]
168
+ def domains(fqns)
169
+ result = []
170
+ fqns_pins(fqns).each do |nspin|
171
+ result.concat nspin.domains
172
+ end
173
+ result
174
+ end
175
+
176
+ # @return [Hash{String => YARD::Tags::MacroDirective}]
177
+ def named_macros
178
+ @named_macros ||= begin
179
+ result = {}
180
+ pins.each do |pin|
181
+ pin.macros.select{|m| m.tag.tag_name == 'macro' && !m.tag.text.empty? }.each do |macro|
182
+ next if macro.tag.name.nil? || macro.tag.name.empty?
183
+ result[macro.tag.name] = macro
184
+ end
185
+ end
186
+ result
187
+ end
188
+ end
189
+
190
+ # @return [Enumerable<Pin::Block>]
191
+ def block_pins
192
+ pins_by_class(Pin::Block)
193
+ end
194
+
195
+ # @generic T
196
+ # @param klass [Class<generic<T>>]
197
+ # @return [Set<generic<T>>]
198
+ def pins_by_class klass
199
+ index.pins_by_class klass
200
+ end
201
+
202
+ # @param fqns [String]
203
+ # @return [Array<Solargraph::Pin::Namespace>]
204
+ def fqns_pins fqns
205
+ return [] if fqns.nil?
206
+ if fqns.include?('::')
207
+ parts = fqns.split('::')
208
+ name = parts.pop
209
+ base = parts.join('::')
210
+ else
211
+ base = ''
212
+ name = fqns
213
+ end
214
+ fqns_pins_map[[base, name]]
215
+ end
216
+
217
+ # Get all ancestors (superclasses, includes, prepends, extends) for a namespace
218
+ # @param fqns [String] The fully qualified namespace
219
+ # @return [Array<String>] Array of ancestor namespaces including the original
220
+ def get_ancestors(fqns)
221
+ return [] if fqns.nil? || fqns.empty?
222
+
223
+ ancestors = [fqns]
224
+ visited = Set.new
225
+ queue = [fqns]
226
+
227
+ until queue.empty?
228
+ current = queue.shift
229
+ next if current.nil? || current.empty? || visited.include?(current)
230
+ visited.add(current)
231
+
232
+ current = current.gsub(/^::/, '')
233
+
234
+ # Add superclass
235
+ ref = get_superclass(current)
236
+ superclass = ref && constants.dereference(ref)
237
+ if superclass && !superclass.empty? && !visited.include?(superclass)
238
+ ancestors << superclass
239
+ queue << superclass
240
+ end
241
+
242
+ # Add includes, prepends, and extends
243
+ [get_includes(current), get_prepends(current), get_extends(current)].each do |refs|
244
+ next if refs.nil?
245
+ # @param ref [String]
246
+ refs.map(&:type).map(&:to_s).each do |ref|
247
+ next if ref.nil? || ref.empty? || visited.include?(ref)
248
+ ancestors << ref
249
+ queue << ref
250
+ end
251
+ end
252
+ end
253
+
254
+ ancestors.compact.uniq
255
+ end
256
+
257
+ # @param fqns [String]
258
+ #
259
+ # @return [Array<Solargraph::Pin::Reference>]
260
+ def get_ancestor_references(fqns)
261
+ (get_prepends(fqns) + get_includes(fqns) + [get_superclass(fqns)]).compact
262
+ end
263
+
264
+ # @return [Constants]
265
+ def constants
266
+ @constants ||= Constants.new(self)
267
+ end
268
+
269
+ private
270
+
271
+ # @return [Index]
272
+ def index
273
+ @indexes.last
274
+ end
275
+
276
+ # @param pinsets [Array<Array<Pin::Base>>]
277
+ #
278
+ # @return [void]
279
+ def catalog pinsets
280
+ @pinsets = pinsets
281
+ # @type [Array<Index>]
282
+ @indexes = []
283
+ pinsets.each do |pins|
284
+ if @indexes.last && pins.empty?
285
+ @indexes.push @indexes.last
286
+ else
287
+ @indexes.push(@indexes.last&.merge(pins) || Solargraph::ApiMap::Index.new(pins))
288
+ end
289
+ end
290
+ constants.clear
291
+ cached_qualify_superclass.clear
292
+ true
293
+ end
294
+
295
+ # @return [Hash{::Array(String, String) => ::Array<Pin::Namespace>}]
296
+ def fqns_pins_map
297
+ # @param h [Hash{::Array(String, String) => ::Array<Pin::Namespace>}]
298
+ # @param base [String]
299
+ # @param name [String]
300
+ @fqns_pins_map ||= Hash.new do |h, (base, name)|
301
+ value = namespace_children(base).select { |pin| pin.name == name && pin.is_a?(Pin::Namespace) }
302
+ h[[base, name]] = value
303
+ end
304
+ end
305
+
306
+ # @return [Enumerable<Solargraph::Pin::Symbol>]
307
+ def symbols
308
+ index.pins_by_class(Pin::Symbol)
309
+ end
310
+
311
+ # @return [Hash{String => Array<String>}]
312
+ def superclass_references
313
+ index.superclass_references
314
+ end
315
+
316
+ # @return [Hash{String => Array<Pin::Reference::Include>}]
317
+ def include_references
318
+ index.include_references
319
+ end
320
+
321
+ # @return [Hash{String => Array<Solargraph::Pin::Reference::Include>}]
322
+ def include_reference_pins
323
+ index.include_reference_pins
324
+ end
325
+
326
+ # @return [Hash{String => Array<Pin::Reference::Prepend>}]
327
+ def prepend_references
328
+ index.prepend_references
329
+ end
330
+
331
+ # @return [Hash{String => Array<Pin::Reference::Extend>}]
332
+ def extend_references
333
+ index.extend_references
334
+ end
335
+
336
+ # @param name [String]
337
+ # @return [Enumerable<Solargraph::Pin::Base>]
338
+ def namespace_children name
339
+ return [] unless index.namespace_hash.key?(name)
340
+ index.namespace_hash[name]
341
+ end
342
+
343
+ # @return [Enumerable<Pin::InstanceVariable>]
344
+ def all_instance_variables
345
+ index.pins_by_class(Pin::InstanceVariable)
346
+ end
347
+
348
+ # @param fqns [String]
349
+ # @return [Pin::Reference::Superclass, nil]
350
+ def try_special_superclasses(fqns)
351
+ return OBJECT_SUPERCLASS_PIN if fqns == 'Boolean'
352
+ return OBJECT_SUPERCLASS_PIN if !%w[BasicObject Object].include?(fqns) && namespace_exists?(fqns)
353
+
354
+ sub = ComplexType.try_parse(fqns)
355
+ return get_superclass(sub.simplify_literals.name) if sub.literal?
356
+
357
+ get_superclass(sub.namespace) if sub.namespace != fqns
358
+ end
359
+
360
+ # @param fq_sub_tag [String]
361
+ # @return [String, nil]
362
+ def qualify_and_cache_superclass fq_sub_tag
363
+ cached_qualify_superclass[fq_sub_tag] = uncached_qualify_superclass(fq_sub_tag)
364
+ end
365
+
366
+ # @return [Hash{String => String, nil}]
367
+ def cached_qualify_superclass
368
+ @cached_qualify_superclass ||= {}
369
+ end
370
+
371
+ # @param fq_sub_tag [String]
372
+ # @return [String, nil]
373
+ def uncached_qualify_superclass fq_sub_tag
374
+ type = ComplexType.try_parse(fq_sub_tag)
375
+ return type.simplify_literals.to_s if type.literal?
376
+ ref = get_superclass(fq_sub_tag)
377
+ return unless ref
378
+ res = constants.dereference(ref)
379
+ return unless res
380
+ res + type.substring
381
+ end
382
+ end
383
+ end
384
+ end