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,43 +1,45 @@
1
- # frozen_string_literal: true
2
-
3
- module Solargraph
4
- module Pin
5
- class Constant < BaseVariable
6
- attr_reader :visibility
7
-
8
- def initialize visibility: :public, **splat
9
- super(**splat)
10
- @visibility = visibility
11
- end
12
-
13
- def return_type
14
- @return_type ||= generate_complex_type
15
- end
16
-
17
- def completion_item_kind
18
- Solargraph::LanguageServer::CompletionItemKinds::CONSTANT
19
- end
20
-
21
- # @return [Integer]
22
- def symbol_kind
23
- LanguageServer::SymbolKinds::CONSTANT
24
- end
25
-
26
- def path
27
- @path ||= context.namespace.to_s.empty? ? name : "#{context.namespace}::#{name}"
28
- end
29
-
30
- private
31
-
32
- # @return [ComplexType]
33
- def generate_complex_type
34
- tags = docstring.tags(:return).map(&:types).flatten.reject(&:nil?)
35
- if tags.empty?
36
- tags = docstring.tags(:type).map(&:types).flatten.reject(&:nil?)
37
- end
38
- return ComplexType::UNDEFINED if tags.empty?
39
- ComplexType.try_parse *tags
40
- end
41
- end
42
- end
43
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Solargraph
4
+ module Pin
5
+ class Constant < BaseVariable
6
+ attr_reader :visibility
7
+
8
+ # @param visibility [::Symbol] The visibility of the constant (:public, :protected, or :private)
9
+ # @param splat [Hash] Additional options supported by superclasses
10
+ def initialize visibility: :public, **splat
11
+ super(**splat)
12
+ @visibility = visibility
13
+ end
14
+
15
+ def return_type
16
+ @return_type ||= generate_complex_type
17
+ end
18
+
19
+ def completion_item_kind
20
+ Solargraph::LanguageServer::CompletionItemKinds::CONSTANT
21
+ end
22
+
23
+ # @return [Integer]
24
+ def symbol_kind
25
+ LanguageServer::SymbolKinds::CONSTANT
26
+ end
27
+
28
+ def path
29
+ @path ||= context.namespace.to_s.empty? ? name : "#{context.namespace}::#{name}"
30
+ end
31
+
32
+ private
33
+
34
+ # @return [ComplexType]
35
+ def generate_complex_type
36
+ tags = docstring.tags(:return).map(&:types).flatten.reject(&:nil?)
37
+ if tags.empty?
38
+ tags = docstring.tags(:type).map(&:types).flatten.reject(&:nil?)
39
+ end
40
+ return ComplexType::UNDEFINED if tags.empty?
41
+ ComplexType.try_parse *tags
42
+ end
43
+ end
44
+ end
45
+ end
@@ -1,123 +1,123 @@
1
- # frozen_string_literal: true
2
-
3
- require 'cgi'
4
-
5
- module Solargraph
6
- module Pin
7
- # @todo Move this stuff. It should be the responsibility of the language server.
8
- # @todo abstract methods below should be verified to be overridden
9
- # by type checker when mixin included by non-abstract class
10
- module Conversions
11
- # @!parse
12
- # include Documenting
13
- # include Common
14
-
15
- # @return [Integer]
16
- # @abstract
17
- def completion_item_kind
18
- raise NotImplementedError
19
- end
20
-
21
- # @abstract
22
- # @return [Boolean]
23
- def deprecated?
24
- raise NotImplementedError
25
- end
26
-
27
- # @abstract
28
- def probed?
29
- raise NotImplementedError
30
- end
31
-
32
- # @abstract
33
- def proxied?
34
- raise NotImplementedError
35
- end
36
-
37
- # @return [Hash]
38
- def completion_item
39
- @completion_item ||= {
40
- label: name,
41
- kind: completion_item_kind,
42
- detail: detail,
43
- data: {
44
- path: path,
45
- return_type: return_type.tag,
46
- location: (location ? location.to_hash : nil),
47
- deprecated: deprecated?
48
- }
49
- }
50
- end
51
-
52
- # @return [Hash]
53
- def resolve_completion_item
54
- @resolve_completion_item ||= begin
55
- extra = {}
56
- alldoc = ''
57
- # alldoc += link_documentation unless link_documentation.nil?
58
- # alldoc += "\n\n" unless alldoc.empty?
59
- alldoc += documentation unless documentation.nil?
60
- extra[:documentation] = alldoc unless alldoc.empty?
61
- completion_item.merge(extra)
62
- end
63
- end
64
-
65
- # @return [::Array<Hash>]
66
- def signature_help
67
- []
68
- end
69
-
70
- # @return [String, nil]
71
- def detail
72
- # This property is not cached in an instance variable because it can
73
- # change when pins get proxied.
74
- detail = String.new
75
- detail += "=#{probed? ? '~' : (proxied? ? '^' : '>')} #{return_type.to_s}" unless return_type.undefined?
76
- detail.strip!
77
- return nil if detail.empty?
78
- detail
79
- end
80
-
81
- # Get a markdown-flavored link to a documentation page.
82
- #
83
- # @return [String]
84
- def link_documentation
85
- @link_documentation ||= generate_link
86
- end
87
-
88
- # @return [String, nil]
89
- def text_documentation
90
- this_path = path || name || return_type.tag
91
- return nil if this_path == 'undefined'
92
- escape_brackets this_path
93
- end
94
-
95
- # @return [void]
96
- def reset_conversions
97
- @completion_item = nil
98
- @resolve_completion_item = nil
99
- @signature_help = nil
100
- @detail = nil
101
- @link_documentation = nil
102
- end
103
-
104
- private
105
-
106
- # @return [String, nil]
107
- def generate_link
108
- this_path = path || name || return_type.tag
109
- return nil if this_path == 'undefined'
110
- return nil if this_path.nil? || this_path == 'undefined'
111
- return this_path if path.nil?
112
- "[#{escape_brackets(this_path).gsub('_', '\\\\_')}](solargraph:/document?query=#{CGI.escape(this_path)})"
113
- end
114
-
115
- # @param text [String]
116
- # @return [String]
117
- def escape_brackets text
118
- # text.gsub(/(\<|\>)/, "\\#{$1}")
119
- text.gsub("<", '\<').gsub(">", '\>')
120
- end
121
- end
122
- end
123
- end
1
+ # frozen_string_literal: true
2
+
3
+ require 'cgi'
4
+
5
+ module Solargraph
6
+ module Pin
7
+ # @todo Move this stuff. It should be the responsibility of the language server.
8
+ # @todo abstract methods below should be verified to be overridden
9
+ # by type checker when mixin included by non-abstract class
10
+ module Conversions
11
+ # @!parse
12
+ # include Documenting
13
+ # include Common
14
+
15
+ # @return [Integer]
16
+ # @abstract
17
+ def completion_item_kind
18
+ raise NotImplementedError
19
+ end
20
+
21
+ # @abstract
22
+ # @return [Boolean]
23
+ def deprecated?
24
+ raise NotImplementedError
25
+ end
26
+
27
+ # @abstract
28
+ def probed?
29
+ raise NotImplementedError
30
+ end
31
+
32
+ # @abstract
33
+ def proxied?
34
+ raise NotImplementedError
35
+ end
36
+
37
+ # @return [Hash]
38
+ def completion_item
39
+ @completion_item ||= {
40
+ label: name,
41
+ kind: completion_item_kind,
42
+ detail: detail,
43
+ data: {
44
+ path: path,
45
+ return_type: return_type.tag,
46
+ location: (location ? location.to_hash : nil),
47
+ deprecated: deprecated?
48
+ }
49
+ }
50
+ end
51
+
52
+ # @return [Hash]
53
+ def resolve_completion_item
54
+ @resolve_completion_item ||= begin
55
+ extra = {}
56
+ alldoc = ''
57
+ # alldoc += link_documentation unless link_documentation.nil?
58
+ # alldoc += "\n\n" unless alldoc.empty?
59
+ alldoc += documentation unless documentation.nil?
60
+ extra[:documentation] = alldoc unless alldoc.empty?
61
+ completion_item.merge(extra)
62
+ end
63
+ end
64
+
65
+ # @return [::Array<Hash>]
66
+ def signature_help
67
+ []
68
+ end
69
+
70
+ # @return [String, nil]
71
+ def detail
72
+ # This property is not cached in an instance variable because it can
73
+ # change when pins get proxied.
74
+ detail = String.new
75
+ detail += "=#{probed? ? '~' : (proxied? ? '^' : '>')} #{return_type.to_s}" unless return_type.undefined?
76
+ detail.strip!
77
+ return nil if detail.empty?
78
+ detail
79
+ end
80
+
81
+ # Get a markdown-flavored link to a documentation page.
82
+ #
83
+ # @return [String]
84
+ def link_documentation
85
+ @link_documentation ||= generate_link
86
+ end
87
+
88
+ # @return [String, nil]
89
+ def text_documentation
90
+ this_path = path || name || return_type.tag
91
+ return nil if this_path == 'undefined'
92
+ escape_brackets this_path
93
+ end
94
+
95
+ # @return [void]
96
+ def reset_conversions
97
+ @completion_item = nil
98
+ @resolve_completion_item = nil
99
+ @signature_help = nil
100
+ @detail = nil
101
+ @link_documentation = nil
102
+ end
103
+
104
+ private
105
+
106
+ # @return [String, nil]
107
+ def generate_link
108
+ this_path = path || name || return_type.tag
109
+ return nil if this_path == 'undefined'
110
+ return nil if this_path.nil? || this_path == 'undefined'
111
+ return this_path if path.nil?
112
+ "[#{escape_brackets(this_path).gsub('_', '\\\\_')}](solargraph:/document?query=#{CGI.escape(this_path)})"
113
+ end
114
+
115
+ # @param text [String]
116
+ # @return [String]
117
+ def escape_brackets text
118
+ # text.gsub(/(\<|\>)/, "\\#{$1}")
119
+ text.gsub("<", '\<').gsub(">", '\>')
120
+ end
121
+ end
122
+ end
123
+ end
@@ -1,101 +1,120 @@
1
- # frozen_string_literal: true
2
-
3
- module Solargraph
4
- module Pin
5
- # A DelegatedMethod is a more complicated version of a MethodAlias that
6
- # allows aliasing a method from a different closure (class/module etc).
7
- class DelegatedMethod < Pin::Method
8
- # A DelegatedMethod can be constructed with either a :resolved_method
9
- # pin, or a :receiver_chain. When a :receiver_chain is supplied, it
10
- # will be used to *dynamically* resolve a receiver type within the
11
- # given closure/scope, and the delegated method will then be resolved
12
- # to a method pin on that type.
13
- #
14
- # @param method [Method, nil] an already resolved method pin.
15
- # @param receiver [Source::Chain, nil] the source code used to resolve the receiver for this delegated method.
16
- # @param name [String]
17
- # @param receiver_method_name [String] the method name that will be called on the receiver (defaults to :name).
18
- def initialize(method: nil, receiver: nil, name: method&.name, receiver_method_name: name, **splat)
19
- raise ArgumentError, 'either :method or :receiver is required' if (method && receiver) || (!method && !receiver)
20
- super(name: name, **splat)
21
-
22
- @receiver_chain = receiver
23
- @resolved_method = method
24
- @receiver_method_name = receiver_method_name
25
- end
26
-
27
- %i[comments parameters return_type location].each do |method|
28
- define_method(method) do
29
- @resolved_method ? @resolved_method.send(method) : super()
30
- end
31
- end
32
-
33
- %i[typify realize infer probe].each do |method|
34
- # @param api_map [ApiMap]
35
- define_method(method) do |api_map|
36
- resolve_method(api_map)
37
- @resolved_method ? @resolved_method.send(method, api_map) : super(api_map)
38
- end
39
- end
40
-
41
- # @param api_map [ApiMap]
42
- def resolvable?(api_map)
43
- resolve_method(api_map)
44
- !!@resolved_method
45
- end
46
-
47
- private
48
-
49
- # Resolves the receiver chain and method name to a method pin, resetting any previously resolution.
50
- #
51
- # @param api_map [ApiMap]
52
- # @return [Pin::Method, nil]
53
- def resolve_method api_map
54
- return if @resolved_method
55
-
56
- resolver = @receiver_chain.define(api_map, self, []).first
57
-
58
- unless resolver
59
- Solargraph.logger.warn \
60
- "Delegated receiver for #{path} was resolved to nil from `#{print_chain(@receiver_chain)}'"
61
- return
62
- end
63
-
64
- receiver_type = resolver.return_type
65
-
66
- return if receiver_type.undefined?
67
-
68
- receiver_path, method_scope =
69
- if @receiver_chain.constant?
70
- # HACK: the `return_type` of a constant is Class<Whatever>, but looking up a method expects
71
- # the arguments `"Whatever"` and `scope: :class`.
72
- [receiver_type.to_s.sub(/^Class<(.+)>$/, '\1'), :class]
73
- else
74
- [receiver_type.to_s, :instance]
75
- end
76
-
77
- method_stack = api_map.get_method_stack(receiver_path, @receiver_method_name, scope: method_scope)
78
- @resolved_method = method_stack.first
79
- end
80
-
81
- # helper to print a source chain as code, probably not 100% correct.
82
- #
83
- # @param chain [Source::Chain]
84
- # @return [String]
85
- def print_chain(chain)
86
- out = +''
87
- chain.links.each_with_index do |link, index|
88
- if index > 0
89
- if Source::Chain::Constant
90
- out << '::' unless link.word.start_with?('::')
91
- else
92
- out << '.'
93
- end
94
- end
95
- out << link.word
96
- end
97
- out
98
- end
99
- end
100
- end
101
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Solargraph
4
+ module Pin
5
+ # A DelegatedMethod is a more complicated version of a MethodAlias that
6
+ # allows aliasing a method from a different closure (class/module etc).
7
+ class DelegatedMethod < Pin::Method
8
+ # A DelegatedMethod can be constructed with either a :resolved_method
9
+ # pin, or a :receiver_chain. When a :receiver_chain is supplied, it
10
+ # will be used to *dynamically* resolve a receiver type within the
11
+ # given closure/scope, and the delegated method will then be resolved
12
+ # to a method pin on that type.
13
+ #
14
+ # @param method [Method, nil] an already resolved method pin.
15
+ # @param receiver [Source::Chain, nil] the source code used to resolve the receiver for this delegated method.
16
+ # @param name [String]
17
+ # @param receiver_method_name [String] the method name that will be called on the receiver (defaults to :name).
18
+ def initialize(method: nil, receiver: nil, name: method&.name, receiver_method_name: name, **splat)
19
+ raise ArgumentError, 'either :method or :receiver is required' if (method && receiver) || (!method && !receiver)
20
+ super(name: name, **splat)
21
+
22
+ @receiver_chain = receiver
23
+ @resolved_method = method
24
+ @receiver_method_name = receiver_method_name
25
+ end
26
+
27
+ def inner_desc
28
+ "#{name} => #{@receiver_chain}##{@receiver_method_name}"
29
+ end
30
+
31
+ def location
32
+ return super if super
33
+
34
+ @resolved_method&.send(:location)
35
+ end
36
+
37
+
38
+ def type_location
39
+ return super if super
40
+
41
+ @resolved_method&.send(:type_location)
42
+ end
43
+
44
+ %i[comments parameters return_type signatures].each do |method|
45
+ define_method(method) do
46
+ # @sg-ignore Need to set context correctly in define_method blocks
47
+ @resolved_method ? @resolved_method.send(method) : super()
48
+ end
49
+ end
50
+
51
+ %i[typify realize infer probe].each do |method|
52
+ # @param api_map [ApiMap]
53
+ define_method(method) do |api_map|
54
+ resolve_method(api_map)
55
+ # @sg-ignore Need to set context correctly in define_method blocks
56
+ @resolved_method ? @resolved_method.send(method, api_map) : super(api_map)
57
+ end
58
+ end
59
+
60
+ # @param api_map [ApiMap]
61
+ def resolvable?(api_map)
62
+ resolve_method(api_map)
63
+ !!@resolved_method
64
+ end
65
+
66
+ private
67
+
68
+ # Resolves the receiver chain and method name to a method pin, resetting any previously resolution.
69
+ #
70
+ # @param api_map [ApiMap]
71
+ # @return [Pin::Method, nil]
72
+ def resolve_method api_map
73
+ return if @resolved_method
74
+
75
+ resolver = @receiver_chain.define(api_map, self, []).first
76
+
77
+ unless resolver
78
+ Solargraph.logger.warn \
79
+ "Delegated receiver for #{path} was resolved to nil from `#{print_chain(@receiver_chain)}'"
80
+ return
81
+ end
82
+
83
+ receiver_type = resolver.return_type
84
+
85
+ return if receiver_type.undefined?
86
+
87
+ receiver_path, method_scope =
88
+ if @receiver_chain.constant?
89
+ # HACK: the `return_type` of a constant is Class<Whatever>, but looking up a method expects
90
+ # the arguments `"Whatever"` and `scope: :class`.
91
+ [receiver_type.to_s.sub(/^Class<(.+)>$/, '\1'), :class]
92
+ else
93
+ [receiver_type.to_s, :instance]
94
+ end
95
+
96
+ method_stack = api_map.get_method_stack(receiver_path, @receiver_method_name, scope: method_scope)
97
+ @resolved_method = method_stack.first
98
+ end
99
+
100
+ # helper to print a source chain as code, probably not 100% correct.
101
+ #
102
+ # @param chain [Source::Chain]
103
+ # @return [String]
104
+ def print_chain(chain)
105
+ out = +''
106
+ chain.links.each_with_index do |link, index|
107
+ if index > 0
108
+ if Source::Chain::Constant
109
+ out << '::' unless link.word.start_with?('::')
110
+ else
111
+ out << '.'
112
+ end
113
+ end
114
+ out << link.word
115
+ end
116
+ out
117
+ end
118
+ end
119
+ end
120
+ end