solargraph 0.46.0 → 0.54.5
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.
- checksums.yaml +4 -4
- data/.github/FUNDING.yml +1 -0
- data/.github/workflows/plugins.yml +40 -0
- data/.github/workflows/rspec.yml +37 -41
- data/.github/workflows/typecheck.yml +34 -0
- data/.gitignore +9 -9
- data/.rspec +2 -2
- data/.yardopts +2 -2
- data/CHANGELOG.md +1338 -1115
- data/Gemfile +0 -0
- data/LICENSE +1 -1
- data/README.md +131 -128
- data/Rakefile +0 -0
- data/SPONSORS.md +10 -18
- data/bin/solargraph +0 -0
- data/lib/solargraph/api_map/cache.rb +109 -70
- data/lib/solargraph/api_map/index.rb +167 -0
- data/lib/solargraph/api_map/source_to_yard.rb +88 -81
- data/lib/solargraph/api_map/store.rb +260 -256
- data/lib/solargraph/api_map.rb +870 -686
- data/lib/solargraph/bench.rb +44 -27
- data/lib/solargraph/cache.rb +77 -0
- data/lib/solargraph/complex_type/type_methods.rb +217 -130
- data/lib/solargraph/complex_type/unique_type.rb +386 -75
- data/lib/solargraph/complex_type.rb +394 -221
- data/lib/solargraph/convention/base.rb +33 -33
- data/lib/solargraph/convention/gemfile.rb +15 -15
- data/lib/solargraph/convention/gemspec.rb +22 -22
- data/lib/solargraph/convention/rakefile.rb +17 -0
- data/lib/solargraph/convention.rb +47 -47
- data/lib/solargraph/converters/dd.rb +17 -12
- data/lib/solargraph/converters/dl.rb +15 -12
- data/lib/solargraph/converters/dt.rb +15 -12
- data/lib/solargraph/converters/misc.rb +1 -1
- data/lib/solargraph/diagnostics/base.rb +29 -29
- data/lib/solargraph/diagnostics/require_not_found.rb +53 -53
- data/lib/solargraph/diagnostics/rubocop.rb +113 -98
- data/lib/solargraph/diagnostics/rubocop_helpers.rb +66 -63
- data/lib/solargraph/diagnostics/severities.rb +15 -15
- data/lib/solargraph/diagnostics/type_check.rb +55 -54
- data/lib/solargraph/diagnostics/update_errors.rb +41 -41
- data/lib/solargraph/diagnostics.rb +55 -55
- data/lib/solargraph/doc_map.rb +188 -0
- data/lib/solargraph/environ.rb +45 -45
- data/lib/solargraph/equality.rb +33 -0
- data/lib/solargraph/gem_pins.rb +72 -0
- data/lib/solargraph/language_server/completion_item_kinds.rb +35 -35
- data/lib/solargraph/language_server/error_codes.rb +20 -20
- data/lib/solargraph/language_server/host/diagnoser.rb +89 -89
- data/lib/solargraph/language_server/host/dispatch.rb +128 -111
- data/lib/solargraph/language_server/host/message_worker.rb +106 -59
- data/lib/solargraph/language_server/host/sources.rb +99 -156
- data/lib/solargraph/language_server/host.rb +861 -865
- data/lib/solargraph/language_server/message/base.rb +96 -89
- data/lib/solargraph/language_server/message/cancel_request.rb +13 -13
- data/lib/solargraph/language_server/message/client/register_capability.rb +15 -15
- data/lib/solargraph/language_server/message/client.rb +11 -11
- data/lib/solargraph/language_server/message/completion_item/resolve.rb +60 -58
- data/lib/solargraph/language_server/message/completion_item.rb +11 -11
- data/lib/solargraph/language_server/message/exit_notification.rb +13 -13
- data/lib/solargraph/language_server/message/extended/check_gem_version.rb +112 -100
- data/lib/solargraph/language_server/message/extended/document.rb +20 -20
- data/lib/solargraph/language_server/message/extended/document_gems.rb +32 -32
- data/lib/solargraph/language_server/message/extended/download_core.rb +19 -23
- data/lib/solargraph/language_server/message/extended/environment.rb +25 -25
- data/lib/solargraph/language_server/message/extended/search.rb +20 -20
- data/lib/solargraph/language_server/message/extended.rb +21 -21
- data/lib/solargraph/language_server/message/initialize.rb +191 -162
- data/lib/solargraph/language_server/message/initialized.rb +28 -27
- data/lib/solargraph/language_server/message/method_not_found.rb +16 -16
- data/lib/solargraph/language_server/message/method_not_implemented.rb +14 -14
- data/lib/solargraph/language_server/message/shutdown.rb +13 -13
- data/lib/solargraph/language_server/message/text_document/base.rb +19 -19
- data/lib/solargraph/language_server/message/text_document/code_action.rb +17 -17
- data/lib/solargraph/language_server/message/text_document/completion.rb +56 -59
- data/lib/solargraph/language_server/message/text_document/definition.rb +38 -38
- data/lib/solargraph/language_server/message/text_document/did_change.rb +15 -15
- data/lib/solargraph/language_server/message/text_document/did_close.rb +15 -15
- data/lib/solargraph/language_server/message/text_document/did_open.rb +15 -15
- data/lib/solargraph/language_server/message/text_document/did_save.rb +17 -17
- data/lib/solargraph/language_server/message/text_document/document_highlight.rb +16 -16
- data/lib/solargraph/language_server/message/text_document/document_symbol.rb +26 -23
- data/lib/solargraph/language_server/message/text_document/folding_range.rb +26 -26
- data/lib/solargraph/language_server/message/text_document/formatting.rb +131 -126
- data/lib/solargraph/language_server/message/text_document/hover.rb +58 -54
- data/lib/solargraph/language_server/message/text_document/on_type_formatting.rb +34 -34
- data/lib/solargraph/language_server/message/text_document/prepare_rename.rb +11 -11
- data/lib/solargraph/language_server/message/text_document/references.rb +16 -16
- data/lib/solargraph/language_server/message/text_document/rename.rb +19 -19
- data/lib/solargraph/language_server/message/text_document/signature_help.rb +24 -29
- data/lib/solargraph/language_server/message/text_document/type_definition.rb +24 -0
- data/lib/solargraph/language_server/message/text_document.rb +28 -28
- data/lib/solargraph/language_server/message/workspace/did_change_configuration.rb +35 -30
- data/lib/solargraph/language_server/message/workspace/did_change_watched_files.rb +40 -33
- data/lib/solargraph/language_server/message/workspace/did_change_workspace_folders.rb +24 -24
- data/lib/solargraph/language_server/message/workspace/workspace_symbol.rb +23 -23
- data/lib/solargraph/language_server/message/workspace.rb +14 -14
- data/lib/solargraph/language_server/message.rb +94 -93
- data/lib/solargraph/language_server/message_types.rb +14 -14
- data/lib/solargraph/language_server/progress.rb +135 -0
- data/lib/solargraph/language_server/request.rb +24 -24
- data/lib/solargraph/language_server/symbol_kinds.rb +36 -36
- data/lib/solargraph/language_server/transport/adapter.rb +68 -53
- data/lib/solargraph/language_server/transport/data_reader.rb +74 -72
- data/lib/solargraph/language_server/transport.rb +13 -13
- data/lib/solargraph/language_server/uri_helpers.rb +49 -49
- data/lib/solargraph/language_server.rb +20 -19
- data/lib/solargraph/library.rb +663 -546
- data/lib/solargraph/location.rb +58 -37
- data/lib/solargraph/logging.rb +27 -27
- data/lib/solargraph/page.rb +89 -83
- data/lib/solargraph/parser/comment_ripper.rb +56 -52
- data/lib/solargraph/parser/node_methods.rb +83 -43
- data/lib/solargraph/parser/node_processor/base.rb +87 -77
- data/lib/solargraph/parser/node_processor.rb +45 -43
- data/lib/solargraph/parser/{legacy → parser_gem}/class_methods.rb +153 -135
- data/lib/solargraph/parser/{legacy → parser_gem}/flawed_builder.rb +18 -16
- data/lib/solargraph/parser/{legacy → parser_gem}/node_chainer.rb +164 -148
- data/lib/solargraph/parser/parser_gem/node_methods.rb +495 -0
- data/lib/solargraph/parser/{rubyvm → parser_gem}/node_processors/alias_node.rb +23 -23
- data/lib/solargraph/parser/parser_gem/node_processors/args_node.rb +57 -0
- data/lib/solargraph/parser/{rubyvm → parser_gem}/node_processors/begin_node.rb +15 -15
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/block_node.rb +43 -42
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/casgn_node.rb +35 -25
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/cvasgn_node.rb +23 -23
- data/lib/solargraph/parser/{rubyvm → parser_gem}/node_processors/def_node.rb +50 -63
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/defs_node.rb +36 -36
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/gvasgn_node.rb +23 -23
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/ivasgn_node.rb +38 -38
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/lvasgn_node.rb +28 -28
- data/lib/solargraph/parser/parser_gem/node_processors/masgn_node.rb +53 -0
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/namespace_node.rb +39 -39
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/orasgn_node.rb +16 -16
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/resbody_node.rb +36 -36
- data/lib/solargraph/parser/parser_gem/node_processors/sclass_node.rb +42 -0
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/send_node.rb +259 -257
- data/lib/solargraph/parser/{legacy → parser_gem}/node_processors/sym_node.rb +18 -18
- data/lib/solargraph/parser/parser_gem/node_processors.rb +56 -0
- data/lib/solargraph/parser/parser_gem.rb +12 -0
- data/lib/solargraph/parser/region.rb +66 -66
- data/lib/solargraph/parser/snippet.rb +15 -13
- data/lib/solargraph/parser.rb +22 -26
- data/lib/solargraph/pin/base.rb +378 -296
- data/lib/solargraph/pin/base_variable.rb +118 -84
- data/lib/solargraph/pin/block.rb +101 -72
- data/lib/solargraph/pin/callable.rb +147 -0
- data/lib/solargraph/pin/class_variable.rb +8 -8
- data/lib/solargraph/pin/closure.rb +57 -37
- data/lib/solargraph/pin/common.rb +70 -70
- data/lib/solargraph/pin/constant.rb +43 -43
- data/lib/solargraph/pin/conversions.rb +123 -96
- data/lib/solargraph/pin/delegated_method.rb +101 -0
- data/lib/solargraph/pin/documenting.rb +98 -105
- data/lib/solargraph/pin/duck_method.rb +16 -16
- data/lib/solargraph/pin/global_variable.rb +8 -8
- data/lib/solargraph/pin/instance_variable.rb +34 -30
- data/lib/solargraph/pin/keyword.rb +15 -15
- data/lib/solargraph/pin/keyword_param.rb +8 -8
- data/lib/solargraph/pin/local_variable.rb +67 -55
- data/lib/solargraph/pin/method.rb +527 -245
- data/lib/solargraph/pin/method_alias.rb +31 -31
- data/lib/solargraph/pin/namespace.rb +107 -91
- data/lib/solargraph/pin/parameter.rb +212 -201
- data/lib/solargraph/pin/proxy_type.rb +29 -29
- data/lib/solargraph/pin/reference/extend.rb +10 -10
- data/lib/solargraph/pin/reference/include.rb +10 -10
- data/lib/solargraph/pin/reference/override.rb +29 -29
- data/lib/solargraph/pin/reference/prepend.rb +10 -10
- data/lib/solargraph/pin/reference/require.rb +14 -14
- data/lib/solargraph/pin/reference/superclass.rb +10 -10
- data/lib/solargraph/pin/reference.rb +22 -14
- data/lib/solargraph/pin/search.rb +56 -56
- data/lib/solargraph/pin/signature.rb +17 -0
- data/lib/solargraph/pin/singleton.rb +11 -11
- data/lib/solargraph/pin/symbol.rb +47 -47
- data/lib/solargraph/pin.rb +41 -37
- data/lib/solargraph/position.rb +107 -100
- data/lib/solargraph/range.rb +98 -95
- data/lib/solargraph/rbs_map/conversions.rb +646 -0
- data/lib/solargraph/rbs_map/core_fills.rb +50 -0
- data/lib/solargraph/rbs_map/core_map.rb +28 -0
- data/lib/solargraph/rbs_map/stdlib_map.rb +33 -0
- data/lib/solargraph/rbs_map.rb +93 -0
- data/lib/solargraph/server_methods.rb +16 -16
- data/lib/solargraph/shell.rb +269 -226
- data/lib/solargraph/source/chain/array.rb +33 -0
- data/lib/solargraph/source/chain/block_symbol.rb +13 -0
- data/lib/solargraph/source/chain/block_variable.rb +13 -13
- data/lib/solargraph/source/chain/call.rb +303 -204
- data/lib/solargraph/source/chain/class_variable.rb +13 -13
- data/lib/solargraph/source/chain/constant.rb +89 -75
- data/lib/solargraph/source/chain/global_variable.rb +13 -13
- data/lib/solargraph/source/chain/hash.rb +33 -28
- data/lib/solargraph/source/chain/head.rb +19 -19
- data/lib/solargraph/source/chain/if.rb +28 -0
- data/lib/solargraph/source/chain/instance_variable.rb +13 -13
- data/lib/solargraph/source/chain/link.rb +98 -71
- data/lib/solargraph/source/chain/literal.rb +28 -23
- data/lib/solargraph/source/chain/or.rb +23 -23
- data/lib/solargraph/source/chain/q_call.rb +11 -11
- data/lib/solargraph/source/chain/variable.rb +13 -13
- data/lib/solargraph/source/chain/z_super.rb +30 -30
- data/lib/solargraph/source/chain.rb +252 -164
- data/lib/solargraph/source/change.rb +82 -79
- data/lib/solargraph/source/cursor.rb +167 -164
- data/lib/solargraph/source/source_chainer.rb +194 -191
- data/lib/solargraph/source/updater.rb +55 -54
- data/lib/solargraph/source.rb +495 -522
- data/lib/solargraph/source_map/clip.rb +232 -224
- data/lib/solargraph/source_map/completion.rb +23 -23
- data/lib/solargraph/source_map/data.rb +30 -0
- data/lib/solargraph/source_map/mapper.rb +255 -212
- data/lib/solargraph/source_map.rb +217 -180
- data/lib/solargraph/type_checker/checks.rb +120 -99
- data/lib/solargraph/type_checker/param_def.rb +35 -35
- data/lib/solargraph/type_checker/problem.rb +32 -32
- data/lib/solargraph/type_checker/rules.rb +62 -57
- data/lib/solargraph/type_checker.rb +672 -543
- data/lib/solargraph/version.rb +5 -5
- data/lib/solargraph/views/environment.erb +56 -58
- data/lib/solargraph/workspace/config.rb +239 -231
- data/lib/solargraph/workspace.rb +239 -215
- data/lib/solargraph/yard_map/cache.rb +25 -19
- data/lib/solargraph/yard_map/helpers.rb +16 -16
- data/lib/solargraph/yard_map/mapper/to_constant.rb +26 -25
- data/lib/solargraph/yard_map/mapper/to_method.rb +94 -78
- data/lib/solargraph/yard_map/mapper/to_namespace.rb +28 -27
- data/lib/solargraph/yard_map/mapper.rb +78 -77
- data/lib/solargraph/yard_map/to_method.rb +86 -79
- data/lib/solargraph/yard_map.rb +18 -460
- data/lib/solargraph/yard_tags.rb +20 -0
- data/lib/solargraph/yardoc.rb +52 -0
- data/lib/solargraph.rb +72 -69
- data/solargraph.gemspec +21 -10
- metadata +184 -115
- data/.travis.yml +0 -19
- data/lib/solargraph/api_map/bundler_methods.rb +0 -22
- data/lib/solargraph/compat.rb +0 -37
- data/lib/solargraph/convention/rspec.rb +0 -30
- data/lib/solargraph/documentor.rb +0 -76
- data/lib/solargraph/language_server/host/cataloger.rb +0 -56
- data/lib/solargraph/parser/legacy/node_methods.rb +0 -325
- data/lib/solargraph/parser/legacy/node_processors/alias_node.rb +0 -23
- data/lib/solargraph/parser/legacy/node_processors/args_node.rb +0 -35
- data/lib/solargraph/parser/legacy/node_processors/begin_node.rb +0 -15
- data/lib/solargraph/parser/legacy/node_processors/def_node.rb +0 -63
- data/lib/solargraph/parser/legacy/node_processors/sclass_node.rb +0 -21
- data/lib/solargraph/parser/legacy/node_processors.rb +0 -54
- data/lib/solargraph/parser/legacy.rb +0 -12
- data/lib/solargraph/parser/rubyvm/class_methods.rb +0 -144
- data/lib/solargraph/parser/rubyvm/node_chainer.rb +0 -160
- data/lib/solargraph/parser/rubyvm/node_methods.rb +0 -315
- data/lib/solargraph/parser/rubyvm/node_processors/args_node.rb +0 -85
- data/lib/solargraph/parser/rubyvm/node_processors/block_node.rb +0 -42
- data/lib/solargraph/parser/rubyvm/node_processors/casgn_node.rb +0 -22
- data/lib/solargraph/parser/rubyvm/node_processors/cvasgn_node.rb +0 -23
- data/lib/solargraph/parser/rubyvm/node_processors/defs_node.rb +0 -57
- data/lib/solargraph/parser/rubyvm/node_processors/gvasgn_node.rb +0 -23
- data/lib/solargraph/parser/rubyvm/node_processors/ivasgn_node.rb +0 -38
- data/lib/solargraph/parser/rubyvm/node_processors/kw_arg_node.rb +0 -39
- data/lib/solargraph/parser/rubyvm/node_processors/lit_node.rb +0 -20
- data/lib/solargraph/parser/rubyvm/node_processors/lvasgn_node.rb +0 -27
- data/lib/solargraph/parser/rubyvm/node_processors/namespace_node.rb +0 -39
- data/lib/solargraph/parser/rubyvm/node_processors/opt_arg_node.rb +0 -26
- data/lib/solargraph/parser/rubyvm/node_processors/orasgn_node.rb +0 -15
- data/lib/solargraph/parser/rubyvm/node_processors/resbody_node.rb +0 -45
- data/lib/solargraph/parser/rubyvm/node_processors/sclass_node.rb +0 -21
- data/lib/solargraph/parser/rubyvm/node_processors/scope_node.rb +0 -15
- data/lib/solargraph/parser/rubyvm/node_processors/send_node.rb +0 -277
- data/lib/solargraph/parser/rubyvm/node_processors/sym_node.rb +0 -18
- data/lib/solargraph/parser/rubyvm/node_processors.rb +0 -63
- data/lib/solargraph/parser/rubyvm.rb +0 -40
- data/lib/solargraph/yard_map/core_docs.rb +0 -170
- data/lib/solargraph/yard_map/core_fills.rb +0 -208
- data/lib/solargraph/yard_map/core_gen.rb +0 -76
- data/lib/solargraph/yard_map/rdoc_to_yard.rb +0 -140
- data/lib/solargraph/yard_map/stdlib_fills.rb +0 -43
- data/lib/yard-solargraph.rb +0 -33
- data/yardoc/2.2.2.tar.gz +0 -0
data/lib/solargraph/pin/base.rb
CHANGED
@@ -1,296 +1,378 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
module Solargraph
|
4
|
-
module Pin
|
5
|
-
# The base class for map pins.
|
6
|
-
#
|
7
|
-
class Base
|
8
|
-
include Common
|
9
|
-
include Conversions
|
10
|
-
include Documenting
|
11
|
-
|
12
|
-
# @return [YARD::CodeObjects::Base]
|
13
|
-
attr_reader :code_object
|
14
|
-
|
15
|
-
# @return [Solargraph::Location]
|
16
|
-
attr_reader :location
|
17
|
-
|
18
|
-
# @return [
|
19
|
-
attr_reader :
|
20
|
-
|
21
|
-
# @return [String]
|
22
|
-
attr_reader :
|
23
|
-
|
24
|
-
# @
|
25
|
-
|
26
|
-
|
27
|
-
# @
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
@
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
# @return [
|
53
|
-
def
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
# @return [
|
62
|
-
def
|
63
|
-
|
64
|
-
end
|
65
|
-
|
66
|
-
#
|
67
|
-
#
|
68
|
-
#
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
def
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
#
|
119
|
-
#
|
120
|
-
#
|
121
|
-
#
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
#
|
135
|
-
#
|
136
|
-
#
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
#
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
#
|
167
|
-
#
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
@
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
# @param api_map [ApiMap]
|
191
|
-
# @return [
|
192
|
-
def
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
#
|
205
|
-
#
|
206
|
-
#
|
207
|
-
|
208
|
-
|
209
|
-
|
210
|
-
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
|
215
|
-
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
def
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
def
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
|
253
|
-
|
254
|
-
|
255
|
-
#
|
256
|
-
#
|
257
|
-
#
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
# @
|
269
|
-
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
274
|
-
|
275
|
-
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
# @return [
|
280
|
-
def
|
281
|
-
|
282
|
-
|
283
|
-
|
284
|
-
|
285
|
-
|
286
|
-
|
287
|
-
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
292
|
-
|
293
|
-
end
|
294
|
-
|
295
|
-
|
296
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Solargraph
|
4
|
+
module Pin
|
5
|
+
# The base class for map pins.
|
6
|
+
#
|
7
|
+
class Base
|
8
|
+
include Common
|
9
|
+
include Conversions
|
10
|
+
include Documenting
|
11
|
+
|
12
|
+
# @return [YARD::CodeObjects::Base]
|
13
|
+
attr_reader :code_object
|
14
|
+
|
15
|
+
# @return [Solargraph::Location]
|
16
|
+
attr_reader :location
|
17
|
+
|
18
|
+
# @return [Solargraph::Location]
|
19
|
+
attr_reader :type_location
|
20
|
+
|
21
|
+
# @return [String]
|
22
|
+
attr_reader :name
|
23
|
+
|
24
|
+
# @return [String]
|
25
|
+
attr_reader :path
|
26
|
+
|
27
|
+
# @return [::Symbol]
|
28
|
+
attr_accessor :source
|
29
|
+
|
30
|
+
# @param location [Solargraph::Location, nil]
|
31
|
+
# @param type_location [Solargraph::Location, nil]
|
32
|
+
# @param closure [Solargraph::Pin::Closure, nil]
|
33
|
+
# @param name [String]
|
34
|
+
# @param comments [String]
|
35
|
+
def initialize location: nil, type_location: nil, closure: nil, name: '', comments: ''
|
36
|
+
@location = location
|
37
|
+
@type_location = type_location
|
38
|
+
@closure = closure
|
39
|
+
@name = name
|
40
|
+
@comments = comments
|
41
|
+
end
|
42
|
+
|
43
|
+
# @return [String]
|
44
|
+
def comments
|
45
|
+
@comments ||= ''
|
46
|
+
end
|
47
|
+
|
48
|
+
# @param generics_to_resolve [Enumerable<String>]
|
49
|
+
# @param return_type_context [ComplexType, nil]
|
50
|
+
# @param context [ComplexType]
|
51
|
+
# @param resolved_generic_values [Hash{String => ComplexType}]
|
52
|
+
# @return [self]
|
53
|
+
def resolve_generics_from_context(generics_to_resolve, return_type_context = nil, resolved_generic_values: {})
|
54
|
+
proxy return_type.resolve_generics_from_context(generics_to_resolve,
|
55
|
+
return_type_context,
|
56
|
+
resolved_generic_values: resolved_generic_values)
|
57
|
+
end
|
58
|
+
|
59
|
+
# @yieldparam [ComplexType]
|
60
|
+
# @yieldreturn [ComplexType]
|
61
|
+
# @return [self]
|
62
|
+
def transform_types(&transform)
|
63
|
+
proxy return_type.transform(&transform)
|
64
|
+
end
|
65
|
+
|
66
|
+
# Determine the concrete type for each of the generic type
|
67
|
+
# parameters used in this method based on the parameters passed
|
68
|
+
# into the its class and return a new method pin.
|
69
|
+
#
|
70
|
+
# @param definitions [Pin::Namespace] The module/class which uses generic types
|
71
|
+
# @param context_type [ComplexType] The receiver type
|
72
|
+
# @return [self]
|
73
|
+
def resolve_generics definitions, context_type
|
74
|
+
transform_types { |t| t.resolve_generics(definitions, context_type) if t }
|
75
|
+
end
|
76
|
+
|
77
|
+
def all_rooted?
|
78
|
+
!return_type || return_type.all_rooted?
|
79
|
+
end
|
80
|
+
|
81
|
+
# @param generics_to_erase [::Array<String>]
|
82
|
+
# @return [self]
|
83
|
+
def erase_generics(generics_to_erase)
|
84
|
+
return self if generics_to_erase.empty?
|
85
|
+
transform_types { |t| t.erase_generics(generics_to_erase) }
|
86
|
+
end
|
87
|
+
|
88
|
+
# @return [String, nil]
|
89
|
+
def filename
|
90
|
+
return nil if location.nil?
|
91
|
+
location.filename
|
92
|
+
end
|
93
|
+
|
94
|
+
# @return [Integer]
|
95
|
+
def completion_item_kind
|
96
|
+
LanguageServer::CompletionItemKinds::KEYWORD
|
97
|
+
end
|
98
|
+
|
99
|
+
# @return [Integer, nil]
|
100
|
+
def symbol_kind
|
101
|
+
nil
|
102
|
+
end
|
103
|
+
|
104
|
+
def to_s
|
105
|
+
desc
|
106
|
+
end
|
107
|
+
|
108
|
+
# @return [Boolean]
|
109
|
+
def variable?
|
110
|
+
false
|
111
|
+
end
|
112
|
+
|
113
|
+
# @return [Location, nil]
|
114
|
+
def best_location
|
115
|
+
location || type_location
|
116
|
+
end
|
117
|
+
|
118
|
+
# True if the specified pin is a near match to this one. A near match
|
119
|
+
# indicates that the pins contain mostly the same data. Any differences
|
120
|
+
# between them should not have an impact on the API surface.
|
121
|
+
#
|
122
|
+
# @param other [Solargraph::Pin::Base, Object]
|
123
|
+
# @return [Boolean]
|
124
|
+
def nearly? other
|
125
|
+
self.class == other.class &&
|
126
|
+
name == other.name &&
|
127
|
+
(closure == other.closure || (closure && closure.nearly?(other.closure))) &&
|
128
|
+
(comments == other.comments ||
|
129
|
+
(((maybe_directives? == false && other.maybe_directives? == false) || compare_directives(directives, other.directives)) &&
|
130
|
+
compare_docstring_tags(docstring, other.docstring))
|
131
|
+
)
|
132
|
+
end
|
133
|
+
|
134
|
+
# Pin equality is determined using the #nearly? method and also
|
135
|
+
# requiring both pins to have the same location.
|
136
|
+
#
|
137
|
+
def == other
|
138
|
+
return false unless nearly? other
|
139
|
+
comments == other.comments && location == other.location
|
140
|
+
end
|
141
|
+
|
142
|
+
# The pin's return type.
|
143
|
+
#
|
144
|
+
# @return [ComplexType]
|
145
|
+
def return_type
|
146
|
+
@return_type ||= ComplexType::UNDEFINED
|
147
|
+
end
|
148
|
+
|
149
|
+
# @return [YARD::Docstring]
|
150
|
+
def docstring
|
151
|
+
parse_comments unless defined?(@docstring)
|
152
|
+
@docstring ||= Solargraph::Source.parse_docstring('').to_docstring
|
153
|
+
end
|
154
|
+
|
155
|
+
# @return [::Array<YARD::Tags::Directive>]
|
156
|
+
def directives
|
157
|
+
parse_comments unless defined?(@directives)
|
158
|
+
@directives
|
159
|
+
end
|
160
|
+
|
161
|
+
# @return [::Array<YARD::Tags::MacroDirective>]
|
162
|
+
def macros
|
163
|
+
@macros ||= collect_macros
|
164
|
+
end
|
165
|
+
|
166
|
+
# Perform a quick check to see if this pin possibly includes YARD
|
167
|
+
# directives. This method does not require parsing the comments.
|
168
|
+
#
|
169
|
+
# After the comments have been parsed, this method will return false if
|
170
|
+
# no directives were found, regardless of whether it previously appeared
|
171
|
+
# possible.
|
172
|
+
#
|
173
|
+
# @return [Boolean]
|
174
|
+
def maybe_directives?
|
175
|
+
return !@directives.empty? if defined?(@directives)
|
176
|
+
@maybe_directives ||= comments.include?('@!')
|
177
|
+
end
|
178
|
+
|
179
|
+
# @return [Boolean]
|
180
|
+
def deprecated?
|
181
|
+
@deprecated ||= docstring.has_tag?('deprecated')
|
182
|
+
end
|
183
|
+
|
184
|
+
# Get a fully qualified type from the pin's return type.
|
185
|
+
#
|
186
|
+
# The relative type is determined from YARD documentation (@return,
|
187
|
+
# @param, @type, etc.) and its namespaces are fully qualified using the
|
188
|
+
# provided ApiMap.
|
189
|
+
#
|
190
|
+
# @param api_map [ApiMap]
|
191
|
+
# @return [ComplexType]
|
192
|
+
def typify api_map
|
193
|
+
return_type.qualify(api_map, namespace)
|
194
|
+
end
|
195
|
+
|
196
|
+
# Infer the pin's return type via static code analysis.
|
197
|
+
#
|
198
|
+
# @param api_map [ApiMap]
|
199
|
+
# @return [ComplexType]
|
200
|
+
def probe api_map
|
201
|
+
typify api_map
|
202
|
+
end
|
203
|
+
|
204
|
+
# @deprecated Use #typify and/or #probe instead
|
205
|
+
# @param api_map [ApiMap]
|
206
|
+
# @return [ComplexType]
|
207
|
+
def infer api_map
|
208
|
+
Solargraph::Logging.logger.warn "WARNING: Pin #infer methods are deprecated. Use #typify or #probe instead."
|
209
|
+
type = typify(api_map)
|
210
|
+
return type unless type.undefined?
|
211
|
+
probe api_map
|
212
|
+
end
|
213
|
+
|
214
|
+
# Try to merge data from another pin. Merges are only possible if the
|
215
|
+
# pins are near matches (see the #nearly? method). The changes should
|
216
|
+
# not have any side effects on the API surface.
|
217
|
+
#
|
218
|
+
# @param pin [Pin::Base] The pin to merge into this one
|
219
|
+
# @return [Boolean] True if the pins were merged
|
220
|
+
def try_merge! pin
|
221
|
+
return false unless nearly?(pin)
|
222
|
+
@location = pin.location
|
223
|
+
@closure = pin.closure
|
224
|
+
return true if comments == pin.comments
|
225
|
+
@comments = pin.comments
|
226
|
+
@docstring = pin.docstring
|
227
|
+
@return_type = pin.return_type
|
228
|
+
@documentation = nil
|
229
|
+
@deprecated = nil
|
230
|
+
reset_conversions
|
231
|
+
true
|
232
|
+
end
|
233
|
+
|
234
|
+
def proxied?
|
235
|
+
@proxied ||= false
|
236
|
+
end
|
237
|
+
|
238
|
+
def probed?
|
239
|
+
@probed ||= false
|
240
|
+
end
|
241
|
+
|
242
|
+
# @param api_map [ApiMap]
|
243
|
+
# @return [self]
|
244
|
+
def realize api_map
|
245
|
+
return self if return_type.defined?
|
246
|
+
type = typify(api_map)
|
247
|
+
return proxy(type) if type.defined?
|
248
|
+
type = probe(api_map)
|
249
|
+
return self if type.undefined?
|
250
|
+
result = proxy(type)
|
251
|
+
result.probed = true
|
252
|
+
result
|
253
|
+
end
|
254
|
+
|
255
|
+
# Return a proxy for this pin with the specified return type. Other than
|
256
|
+
# the return type and the #proxied? setting, the proxy should be a clone
|
257
|
+
# of the original.
|
258
|
+
#
|
259
|
+
# @param return_type [ComplexType]
|
260
|
+
# @return [self]
|
261
|
+
def proxy return_type
|
262
|
+
result = dup
|
263
|
+
result.return_type = return_type
|
264
|
+
result.proxied = true
|
265
|
+
result
|
266
|
+
end
|
267
|
+
|
268
|
+
# @deprecated
|
269
|
+
# @return [String]
|
270
|
+
def identity
|
271
|
+
@identity ||= "#{closure&.path}|#{name}"
|
272
|
+
end
|
273
|
+
|
274
|
+
# @return [String, nil]
|
275
|
+
def to_rbs
|
276
|
+
return_type.to_rbs
|
277
|
+
end
|
278
|
+
|
279
|
+
# @return [String]
|
280
|
+
def type_desc
|
281
|
+
rbs = to_rbs
|
282
|
+
# RBS doesn't have a way to represent a Class<x> type
|
283
|
+
rbs = return_type.rooted_tags if return_type.name == 'Class'
|
284
|
+
if path
|
285
|
+
if rbs
|
286
|
+
path + ' ' + rbs
|
287
|
+
else
|
288
|
+
path
|
289
|
+
end
|
290
|
+
else
|
291
|
+
rbs
|
292
|
+
end
|
293
|
+
end
|
294
|
+
|
295
|
+
# @return [String]
|
296
|
+
def desc
|
297
|
+
closure_info = closure&.desc
|
298
|
+
binder_info = binder&.desc
|
299
|
+
"[#{type_desc}, closure=#{closure_info}, binder=#{binder}"
|
300
|
+
end
|
301
|
+
|
302
|
+
def inspect
|
303
|
+
"#<#{self.class} `#{self.desc}` at #{self.location.inspect}>"
|
304
|
+
end
|
305
|
+
|
306
|
+
protected
|
307
|
+
|
308
|
+
# @return [Boolean]
|
309
|
+
attr_writer :probed
|
310
|
+
|
311
|
+
# @return [Boolean]
|
312
|
+
attr_writer :proxied
|
313
|
+
|
314
|
+
# @return [ComplexType]
|
315
|
+
attr_writer :return_type
|
316
|
+
|
317
|
+
private
|
318
|
+
|
319
|
+
# @return [void]
|
320
|
+
def parse_comments
|
321
|
+
# HACK: Avoid a NoMethodError on nil with empty overload tags
|
322
|
+
if comments.nil? || comments.empty? || comments.strip.end_with?('@overload')
|
323
|
+
@docstring = nil
|
324
|
+
@directives = []
|
325
|
+
else
|
326
|
+
# HACK: Pass a dummy code object to the parser for plugins that
|
327
|
+
# expect it not to be nil
|
328
|
+
parse = Solargraph::Source.parse_docstring(comments)
|
329
|
+
@docstring = parse.to_docstring
|
330
|
+
@directives = parse.directives
|
331
|
+
end
|
332
|
+
end
|
333
|
+
|
334
|
+
# True if two docstrings have the same tags, regardless of any other
|
335
|
+
# differences.
|
336
|
+
#
|
337
|
+
# @param d1 [YARD::Docstring]
|
338
|
+
# @param d2 [YARD::Docstring]
|
339
|
+
# @return [Boolean]
|
340
|
+
def compare_docstring_tags d1, d2
|
341
|
+
return false if d1.tags.length != d2.tags.length
|
342
|
+
d1.tags.each_index do |i|
|
343
|
+
return false unless compare_tags(d1.tags[i], d2.tags[i])
|
344
|
+
end
|
345
|
+
true
|
346
|
+
end
|
347
|
+
|
348
|
+
# @param dir1 [::Array<YARD::Tags::Directive>]
|
349
|
+
# @param dir2 [::Array<YARD::Tags::Directive>]
|
350
|
+
# @return [Boolean]
|
351
|
+
def compare_directives dir1, dir2
|
352
|
+
return false if dir1.length != dir2.length
|
353
|
+
dir1.each_index do |i|
|
354
|
+
return false unless compare_tags(dir1[i].tag, dir2[i].tag)
|
355
|
+
end
|
356
|
+
true
|
357
|
+
end
|
358
|
+
|
359
|
+
# @param tag1 [YARD::Tags::Tag]
|
360
|
+
# @param tag2 [YARD::Tags::Tag]
|
361
|
+
# @return [Boolean]
|
362
|
+
def compare_tags tag1, tag2
|
363
|
+
tag1.class == tag2.class &&
|
364
|
+
tag1.tag_name == tag2.tag_name &&
|
365
|
+
tag1.text == tag2.text &&
|
366
|
+
tag1.name == tag2.name &&
|
367
|
+
tag1.types == tag2.types
|
368
|
+
end
|
369
|
+
|
370
|
+
# @return [::Array<YARD::Tags::Handlers::Directive>]
|
371
|
+
def collect_macros
|
372
|
+
return [] unless maybe_directives?
|
373
|
+
parse = Solargraph::Source.parse_docstring(comments)
|
374
|
+
parse.directives.select{ |d| d.tag.tag_name == 'macro' }
|
375
|
+
end
|
376
|
+
end
|
377
|
+
end
|
378
|
+
end
|