ruby-lsp 0.1.0 → 0.2.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +35 -0
- data/README.md +2 -1
- data/VERSION +1 -1
- data/exe/ruby-lsp +1 -3
- data/lib/ruby-lsp.rb +2 -2
- data/lib/ruby_lsp/document.rb +10 -3
- data/lib/ruby_lsp/handler.rb +30 -134
- data/lib/ruby_lsp/internal.rb +3 -1
- data/lib/ruby_lsp/requests/code_actions.rb +2 -0
- data/lib/ruby_lsp/requests/diagnostics.rb +14 -9
- data/lib/ruby_lsp/requests/document_highlight.rb +27 -42
- data/lib/ruby_lsp/requests/document_link.rb +59 -0
- data/lib/ruby_lsp/requests/document_symbol.rb +2 -0
- data/lib/ruby_lsp/requests/folding_ranges.rb +26 -21
- data/lib/ruby_lsp/requests/formatting.rb +21 -16
- data/lib/ruby_lsp/requests/selection_ranges.rb +2 -0
- data/lib/ruby_lsp/requests/semantic_highlighting.rb +85 -11
- data/lib/ruby_lsp/requests/support/highlight_target.rb +88 -0
- data/lib/ruby_lsp/requests/support/rubocop_diagnostic.rb +9 -2
- data/lib/ruby_lsp/requests/support/rubocop_diagnostics_runner.rb +61 -0
- data/lib/ruby_lsp/requests/support/rubocop_formatting_runner.rb +50 -0
- data/lib/ruby_lsp/requests.rb +14 -1
- data/lib/ruby_lsp/server.rb +192 -0
- data/lib/ruby_lsp/store.rb +12 -5
- metadata +10 -87
- data/.github/dependabot.yml +0 -11
- data/.github/probots.yml +0 -2
- data/.github/pull_request_template.md +0 -15
- data/.github/workflows/ci.yml +0 -31
- data/.github/workflows/publish_docs.yml +0 -32
- data/.gitignore +0 -9
- data/.rubocop.yml +0 -39
- data/.vscode/extensions.json +0 -5
- data/.vscode/settings.json +0 -5
- data/.vscode/tasks.json +0 -25
- data/CODE_OF_CONDUCT.md +0 -78
- data/Gemfile +0 -17
- data/Gemfile.lock +0 -124
- data/Rakefile +0 -21
- data/bin/rubocop +0 -29
- data/bin/tapioca +0 -29
- data/bin/test +0 -9
- data/dev.yml +0 -20
- data/lib/ruby_lsp/cli.rb +0 -88
- data/lib/ruby_lsp/requests/rubocop_request.rb +0 -60
- data/rakelib/check_docs.rake +0 -57
- data/ruby-lsp.gemspec +0 -26
- data/service.yml +0 -2
- data/sorbet/config +0 -4
- data/sorbet/rbi/.rubocop.yml +0 -8
- data/sorbet/rbi/gems/ansi@1.5.0.rbi +0 -338
- data/sorbet/rbi/gems/ast@2.4.2.rbi +0 -522
- data/sorbet/rbi/gems/builder@3.2.4.rbi +0 -418
- data/sorbet/rbi/gems/coderay@1.1.3.rbi +0 -8
- data/sorbet/rbi/gems/debug@1.5.0.rbi +0 -1273
- data/sorbet/rbi/gems/diff-lcs@1.5.0.rbi +0 -867
- data/sorbet/rbi/gems/io-console@0.5.11.rbi +0 -8
- data/sorbet/rbi/gems/irb@1.4.1.rbi +0 -376
- data/sorbet/rbi/gems/language_server-protocol@3.16.0.3.rbi +0 -7325
- data/sorbet/rbi/gems/method_source@1.0.0.rbi +0 -8
- data/sorbet/rbi/gems/minitest-reporters@1.5.0.rbi +0 -612
- data/sorbet/rbi/gems/minitest@5.15.0.rbi +0 -994
- data/sorbet/rbi/gems/parallel@1.22.1.rbi +0 -163
- data/sorbet/rbi/gems/parser@3.1.2.0.rbi +0 -3968
- data/sorbet/rbi/gems/prettier_print@0.1.0.rbi +0 -734
- data/sorbet/rbi/gems/pry@0.14.1.rbi +0 -8
- data/sorbet/rbi/gems/rainbow@3.1.1.rbi +0 -227
- data/sorbet/rbi/gems/rake@13.0.6.rbi +0 -1853
- data/sorbet/rbi/gems/rbi@0.0.14.rbi +0 -2337
- data/sorbet/rbi/gems/regexp_parser@2.5.0.rbi +0 -1854
- data/sorbet/rbi/gems/reline@0.3.1.rbi +0 -1274
- data/sorbet/rbi/gems/rexml@3.2.5.rbi +0 -3852
- data/sorbet/rbi/gems/rubocop-ast@1.18.0.rbi +0 -4180
- data/sorbet/rbi/gems/rubocop-minitest@0.20.0.rbi +0 -1369
- data/sorbet/rbi/gems/rubocop-rake@0.6.0.rbi +0 -246
- data/sorbet/rbi/gems/rubocop-shopify@2.6.0.rbi +0 -8
- data/sorbet/rbi/gems/rubocop-sorbet@0.6.8.rbi +0 -652
- data/sorbet/rbi/gems/rubocop@1.30.0.rbi +0 -36729
- data/sorbet/rbi/gems/ruby-progressbar@1.11.0.rbi +0 -732
- data/sorbet/rbi/gems/spoom@1.1.11.rbi +0 -1600
- data/sorbet/rbi/gems/syntax_tree@2.7.1.rbi +0 -6777
- data/sorbet/rbi/gems/tapioca@0.8.1.rbi +0 -1972
- data/sorbet/rbi/gems/thor@1.2.1.rbi +0 -2921
- data/sorbet/rbi/gems/unicode-display_width@2.1.0.rbi +0 -27
- data/sorbet/rbi/gems/unparser@0.6.5.rbi +0 -2789
- data/sorbet/rbi/gems/webrick@1.7.0.rbi +0 -1779
- data/sorbet/rbi/gems/yard-sorbet@0.6.1.rbi +0 -289
- data/sorbet/rbi/gems/yard@0.9.27.rbi +0 -13048
- data/sorbet/rbi/shims/fiddle.rbi +0 -4
- data/sorbet/rbi/shims/hash.rbi +0 -6
- data/sorbet/rbi/shims/rdoc.rbi +0 -4
- data/sorbet/tapioca/config.yml +0 -13
- data/sorbet/tapioca/require.rb +0 -7
@@ -1,289 +0,0 @@
|
|
1
|
-
# typed: true
|
2
|
-
|
3
|
-
# DO NOT EDIT MANUALLY
|
4
|
-
# This is an autogenerated file for types exported from the `yard-sorbet` gem.
|
5
|
-
# Please instead update this file by running `bin/tapioca gem yard-sorbet`.
|
6
|
-
|
7
|
-
# Types are documentation
|
8
|
-
module YARDSorbet; end
|
9
|
-
|
10
|
-
# Extract & re-add directives to a docstring
|
11
|
-
module YARDSorbet::Directives
|
12
|
-
class << self
|
13
|
-
sig { params(docstring: ::String, directives: T::Array[::String]).void }
|
14
|
-
def add_directives(docstring, directives); end
|
15
|
-
|
16
|
-
sig { params(docstring: T.nilable(::String)).returns([::YARD::Docstring, T::Array[::String]]) }
|
17
|
-
def extract_directives(docstring); end
|
18
|
-
end
|
19
|
-
end
|
20
|
-
|
21
|
-
# Custom YARD Handlers
|
22
|
-
#
|
23
|
-
# @see https://rubydoc.info/gems/yard/YARD/Handlers/Base YARD Base Handler documentation
|
24
|
-
module YARDSorbet::Handlers; end
|
25
|
-
|
26
|
-
# Apllies an `@abstract` tag to `abstract!`/`interface!` modules (if not alerady present).
|
27
|
-
class YARDSorbet::Handlers::AbstractDSLHandler < ::YARD::Handlers::Ruby::Base
|
28
|
-
sig { void }
|
29
|
-
def process; end
|
30
|
-
end
|
31
|
-
|
32
|
-
# Extra text for class namespaces
|
33
|
-
YARDSorbet::Handlers::AbstractDSLHandler::CLASS_TAG_TEXT = T.let(T.unsafe(nil), String)
|
34
|
-
|
35
|
-
# The text accompanying the `@abstract` tag.
|
36
|
-
#
|
37
|
-
# @see https://github.com/lsegal/yard/blob/main/templates/default/docstring/html/abstract.erb The `@abstract` tag template
|
38
|
-
YARDSorbet::Handlers::AbstractDSLHandler::TAG_TEXT = T.let(T.unsafe(nil), String)
|
39
|
-
|
40
|
-
# Handle `enums` calls, registering enum values as constants
|
41
|
-
class YARDSorbet::Handlers::EnumsHandler < ::YARD::Handlers::Ruby::Base
|
42
|
-
sig { void }
|
43
|
-
def process; end
|
44
|
-
|
45
|
-
private
|
46
|
-
|
47
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(T::Boolean) }
|
48
|
-
def const_assign_node?(node); end
|
49
|
-
end
|
50
|
-
|
51
|
-
# Extends any modules included via `mixes_in_class_methods`
|
52
|
-
#
|
53
|
-
# @see https://sorbet.org/docs/abstract#interfaces-and-the-included-hook Sorbet `mixes_in_class_methods` documentation
|
54
|
-
class YARDSorbet::Handlers::IncludeHandler < ::YARD::Handlers::Ruby::Base
|
55
|
-
sig { void }
|
56
|
-
def process; end
|
57
|
-
|
58
|
-
private
|
59
|
-
|
60
|
-
sig { returns(::YARD::CodeObjects::NamespaceObject) }
|
61
|
-
def included_in; end
|
62
|
-
end
|
63
|
-
|
64
|
-
# Tracks modules that invoke `mixes_in_class_methods` for use in {IncludeHandler}
|
65
|
-
#
|
66
|
-
# @see https://sorbet.org/docs/abstract#interfaces-and-the-included-hook Sorbet `mixes_in_class_methods` documentation
|
67
|
-
class YARDSorbet::Handlers::MixesInClassMethodsHandler < ::YARD::Handlers::Ruby::Base
|
68
|
-
sig { void }
|
69
|
-
def process; end
|
70
|
-
|
71
|
-
class << self
|
72
|
-
sig { params(code_obj: ::String).returns(T.nilable(::String)) }
|
73
|
-
def mixed_in_class_methods(code_obj); end
|
74
|
-
end
|
75
|
-
end
|
76
|
-
|
77
|
-
# A YARD Handler for Sorbet type declarations
|
78
|
-
class YARDSorbet::Handlers::SigHandler < ::YARD::Handlers::Ruby::Base
|
79
|
-
# Swap the method definition docstring and the sig docstring.
|
80
|
-
# Parse relevant parts of the `sig` and include them as well.
|
81
|
-
sig { void }
|
82
|
-
def process; end
|
83
|
-
|
84
|
-
private
|
85
|
-
|
86
|
-
sig do
|
87
|
-
params(
|
88
|
-
method_node: ::YARD::Parser::Ruby::AstNode,
|
89
|
-
node: ::YARD::Parser::Ruby::AstNode,
|
90
|
-
docstring: ::YARD::Docstring
|
91
|
-
).void
|
92
|
-
end
|
93
|
-
def parse_params(method_node, node, docstring); end
|
94
|
-
|
95
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode, docstring: ::YARD::Docstring).void }
|
96
|
-
def parse_return(node, docstring); end
|
97
|
-
|
98
|
-
sig { params(method_node: ::YARD::Parser::Ruby::AstNode, docstring: ::YARD::Docstring).void }
|
99
|
-
def parse_sig(method_node, docstring); end
|
100
|
-
end
|
101
|
-
|
102
|
-
# These node types attached to sigs represent attr_* declarations
|
103
|
-
YARDSorbet::Handlers::SigHandler::ATTR_NODE_TYPES = T.let(T.unsafe(nil), Array)
|
104
|
-
|
105
|
-
# Class-level handler that folds all `const` and `prop` declarations into the constructor documentation
|
106
|
-
# this needs to be injected as a module otherwise the default Class handler will overwrite documentation
|
107
|
-
#
|
108
|
-
# @note this module is included in `YARD::Handlers::Ruby::ClassHandler`
|
109
|
-
module YARDSorbet::Handlers::StructClassHandler
|
110
|
-
sig { void }
|
111
|
-
def process; end
|
112
|
-
|
113
|
-
private
|
114
|
-
|
115
|
-
sig do
|
116
|
-
params(
|
117
|
-
object: ::YARD::CodeObjects::MethodObject,
|
118
|
-
props: T::Array[::YARDSorbet::TStructProp],
|
119
|
-
docstring: ::YARD::Docstring,
|
120
|
-
directives: T::Array[::String]
|
121
|
-
).void
|
122
|
-
end
|
123
|
-
def decorate_t_struct_init(object, props, docstring, directives); end
|
124
|
-
|
125
|
-
# Create a virtual `initialize` method with all the `prop`/`const` arguments
|
126
|
-
sig { params(props: T::Array[::YARDSorbet::TStructProp], class_ns: ::YARD::CodeObjects::ClassObject).void }
|
127
|
-
def process_t_struct_props(props, class_ns); end
|
128
|
-
|
129
|
-
sig { params(props: T::Array[::YARDSorbet::TStructProp]).returns(T::Array[[::String, T.nilable(::String)]]) }
|
130
|
-
def to_object_parameters(props); end
|
131
|
-
end
|
132
|
-
|
133
|
-
# Handles all `const`/`prop` calls, creating accessor methods, and compiles them for later usage at the class level
|
134
|
-
# in creating a constructor
|
135
|
-
class YARDSorbet::Handlers::StructPropHandler < ::YARD::Handlers::Ruby::Base
|
136
|
-
sig { void }
|
137
|
-
def process; end
|
138
|
-
|
139
|
-
private
|
140
|
-
|
141
|
-
# Add the source and docstring to the method object
|
142
|
-
sig { params(object: ::YARD::CodeObjects::MethodObject, prop: ::YARDSorbet::TStructProp).void }
|
143
|
-
def decorate_object(object, prop); end
|
144
|
-
|
145
|
-
# Get the default prop value
|
146
|
-
sig { returns(T.nilable(::String)) }
|
147
|
-
def default_value; end
|
148
|
-
|
149
|
-
sig { params(name: ::String).returns(::YARDSorbet::TStructProp) }
|
150
|
-
def make_prop(name); end
|
151
|
-
|
152
|
-
# Register the field explicitly as an attribute.
|
153
|
-
# While `const` attributes are immutable, `prop` attributes may be reassigned.
|
154
|
-
sig { params(object: ::YARD::CodeObjects::MethodObject, name: ::String).void }
|
155
|
-
def register_attrs(object, name); end
|
156
|
-
|
157
|
-
# Store the prop for use in the constructor definition
|
158
|
-
sig { params(prop: ::YARDSorbet::TStructProp).void }
|
159
|
-
def update_state(prop); end
|
160
|
-
end
|
161
|
-
|
162
|
-
# Helper methods for working with `YARD` AST Nodes
|
163
|
-
module YARDSorbet::NodeUtils
|
164
|
-
class << self
|
165
|
-
# Traverese AST nodes in breadth-first order
|
166
|
-
#
|
167
|
-
# @note This will skip over some node types.
|
168
|
-
# @yield [YARD::Parser::Ruby::AstNode]
|
169
|
-
sig do
|
170
|
-
params(
|
171
|
-
node: ::YARD::Parser::Ruby::AstNode,
|
172
|
-
_blk: T.proc.params(n: ::YARD::Parser::Ruby::AstNode).void
|
173
|
-
).void
|
174
|
-
end
|
175
|
-
def bfs_traverse(node, &_blk); end
|
176
|
-
|
177
|
-
# Gets the node that a sorbet `sig` can be attached do, bypassing visisbility modifiers and the like
|
178
|
-
sig do
|
179
|
-
params(
|
180
|
-
node: ::YARD::Parser::Ruby::AstNode
|
181
|
-
).returns(T.any(::YARD::Parser::Ruby::MethodCallNode, ::YARD::Parser::Ruby::MethodDefinitionNode))
|
182
|
-
end
|
183
|
-
def get_method_node(node); end
|
184
|
-
|
185
|
-
# Find and return the adjacent node (ascending)
|
186
|
-
#
|
187
|
-
# @raise [IndexError] if the node does not have an adjacent sibling (ascending)
|
188
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(::YARD::Parser::Ruby::AstNode) }
|
189
|
-
def sibling_node(node); end
|
190
|
-
end
|
191
|
-
end
|
192
|
-
|
193
|
-
# Command node types that can have type signatures
|
194
|
-
YARDSorbet::NodeUtils::ATTRIBUTE_METHODS = T.let(T.unsafe(nil), Array)
|
195
|
-
|
196
|
-
# Node types that can have type signatures
|
197
|
-
YARDSorbet::NodeUtils::SIGABLE_NODE = T.type_alias { T.any(::YARD::Parser::Ruby::MethodCallNode, ::YARD::Parser::Ruby::MethodDefinitionNode) }
|
198
|
-
|
199
|
-
# Skip these method contents during BFS node traversal, they can have their own nested types via `T.Proc`
|
200
|
-
YARDSorbet::NodeUtils::SKIP_METHOD_CONTENTS = T.let(T.unsafe(nil), Array)
|
201
|
-
|
202
|
-
# Translate `sig` type syntax to `YARD` type syntax.
|
203
|
-
module YARDSorbet::SigToYARD
|
204
|
-
class << self
|
205
|
-
# @see https://yardoc.org/types.html
|
206
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(T::Array[::String]) }
|
207
|
-
def convert(node); end
|
208
|
-
|
209
|
-
private
|
210
|
-
|
211
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(::String) }
|
212
|
-
def build_generic_type(node); end
|
213
|
-
|
214
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(T::Array[::String]) }
|
215
|
-
def convert_aref(node); end
|
216
|
-
|
217
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(T::Array[::String]) }
|
218
|
-
def convert_array(node); end
|
219
|
-
|
220
|
-
sig { params(node: ::YARD::Parser::Ruby::MethodCallNode).returns(T::Array[::String]) }
|
221
|
-
def convert_call(node); end
|
222
|
-
|
223
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(T::Array[::String]) }
|
224
|
-
def convert_collection(node); end
|
225
|
-
|
226
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(T::Array[::String]) }
|
227
|
-
def convert_hash(node); end
|
228
|
-
|
229
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(T::Array[::String]) }
|
230
|
-
def convert_list(node); end
|
231
|
-
|
232
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(T::Array[::String]) }
|
233
|
-
def convert_node(node); end
|
234
|
-
|
235
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(T::Array[::String]) }
|
236
|
-
def convert_node_type(node); end
|
237
|
-
|
238
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(T::Array[::String]) }
|
239
|
-
def convert_ref(node); end
|
240
|
-
|
241
|
-
sig { params(node: ::YARD::Parser::Ruby::MethodCallNode).returns(T::Array[::String]) }
|
242
|
-
def convert_t_method(node); end
|
243
|
-
|
244
|
-
sig { params(node: ::YARD::Parser::Ruby::AstNode).returns(T::Array[::String]) }
|
245
|
-
def convert_unknown(node); end
|
246
|
-
end
|
247
|
-
end
|
248
|
-
|
249
|
-
# Used to store the details of a `T::Struct` `prop` definition
|
250
|
-
class YARDSorbet::TStructProp < ::T::Struct
|
251
|
-
const :default, T.nilable(::String)
|
252
|
-
const :doc, ::String
|
253
|
-
const :prop_name, ::String
|
254
|
-
const :source, ::String
|
255
|
-
const :types, T::Array[::String]
|
256
|
-
|
257
|
-
class << self
|
258
|
-
def inherited(s); end
|
259
|
-
end
|
260
|
-
end
|
261
|
-
|
262
|
-
# Helper methods for working with `YARD` tags
|
263
|
-
module YARDSorbet::TagUtils
|
264
|
-
class << self
|
265
|
-
sig do
|
266
|
-
params(
|
267
|
-
docstring: ::YARD::Docstring,
|
268
|
-
tag_name: ::String,
|
269
|
-
name: T.nilable(::String)
|
270
|
-
).returns(T.nilable(::YARD::Tags::Tag))
|
271
|
-
end
|
272
|
-
def find_tag(docstring, tag_name, name); end
|
273
|
-
|
274
|
-
# Create or update a `YARD` tag with type information
|
275
|
-
sig do
|
276
|
-
params(
|
277
|
-
docstring: ::YARD::Docstring,
|
278
|
-
tag_name: ::String,
|
279
|
-
types: T.nilable(T::Array[::String]),
|
280
|
-
name: T.nilable(::String),
|
281
|
-
text: ::String
|
282
|
-
).void
|
283
|
-
end
|
284
|
-
def upsert_tag(docstring, tag_name, types = T.unsafe(nil), name = T.unsafe(nil), text = T.unsafe(nil)); end
|
285
|
-
end
|
286
|
-
end
|
287
|
-
|
288
|
-
# {https://rubygems.org/gems/yard-sorbet Version history}
|
289
|
-
YARDSorbet::VERSION = T.let(T.unsafe(nil), String)
|