solargraph 0.58.1 → 0.58.2

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 (147) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +1 -0
  3. data/CHANGELOG.md +7 -1
  4. data/lib/solargraph/api_map/cache.rb +110 -110
  5. data/lib/solargraph/api_map/constants.rb +279 -279
  6. data/lib/solargraph/api_map/index.rb +193 -193
  7. data/lib/solargraph/api_map/source_to_yard.rb +97 -97
  8. data/lib/solargraph/api_map/store.rb +384 -384
  9. data/lib/solargraph/api_map.rb +945 -945
  10. data/lib/solargraph/complex_type/type_methods.rb +228 -228
  11. data/lib/solargraph/complex_type/unique_type.rb +482 -482
  12. data/lib/solargraph/complex_type.rb +444 -444
  13. data/lib/solargraph/convention/data_definition/data_definition_node.rb +91 -91
  14. data/lib/solargraph/convention/data_definition.rb +105 -105
  15. data/lib/solargraph/convention/struct_definition/struct_assignment_node.rb +61 -61
  16. data/lib/solargraph/convention/struct_definition/struct_definition_node.rb +102 -102
  17. data/lib/solargraph/convention/struct_definition.rb +164 -164
  18. data/lib/solargraph/diagnostics/require_not_found.rb +53 -53
  19. data/lib/solargraph/diagnostics/rubocop.rb +118 -118
  20. data/lib/solargraph/diagnostics/rubocop_helpers.rb +68 -68
  21. data/lib/solargraph/diagnostics/type_check.rb +55 -55
  22. data/lib/solargraph/doc_map.rb +439 -439
  23. data/lib/solargraph/equality.rb +34 -34
  24. data/lib/solargraph/gem_pins.rb +98 -98
  25. data/lib/solargraph/language_server/host/diagnoser.rb +89 -89
  26. data/lib/solargraph/language_server/host/dispatch.rb +130 -130
  27. data/lib/solargraph/language_server/host/message_worker.rb +112 -112
  28. data/lib/solargraph/language_server/host/sources.rb +99 -99
  29. data/lib/solargraph/language_server/host.rb +878 -878
  30. data/lib/solargraph/language_server/message/extended/check_gem_version.rb +114 -114
  31. data/lib/solargraph/language_server/message/extended/document.rb +23 -23
  32. data/lib/solargraph/language_server/message/text_document/completion.rb +56 -56
  33. data/lib/solargraph/language_server/message/text_document/definition.rb +40 -40
  34. data/lib/solargraph/language_server/message/text_document/document_symbol.rb +26 -26
  35. data/lib/solargraph/language_server/message/text_document/formatting.rb +148 -148
  36. data/lib/solargraph/language_server/message/text_document/hover.rb +58 -58
  37. data/lib/solargraph/language_server/message/text_document/signature_help.rb +24 -24
  38. data/lib/solargraph/language_server/message/text_document/type_definition.rb +25 -25
  39. data/lib/solargraph/language_server/message/workspace/workspace_symbol.rb +23 -23
  40. data/lib/solargraph/library.rb +683 -683
  41. data/lib/solargraph/location.rb +82 -82
  42. data/lib/solargraph/logging.rb +37 -37
  43. data/lib/solargraph/parser/comment_ripper.rb +69 -69
  44. data/lib/solargraph/parser/flow_sensitive_typing.rb +255 -255
  45. data/lib/solargraph/parser/node_processor/base.rb +92 -92
  46. data/lib/solargraph/parser/node_processor.rb +62 -62
  47. data/lib/solargraph/parser/parser_gem/class_methods.rb +149 -149
  48. data/lib/solargraph/parser/parser_gem/node_chainer.rb +166 -166
  49. data/lib/solargraph/parser/parser_gem/node_methods.rb +486 -486
  50. data/lib/solargraph/parser/parser_gem/node_processors/and_node.rb +22 -22
  51. data/lib/solargraph/parser/parser_gem/node_processors/args_node.rb +59 -59
  52. data/lib/solargraph/parser/parser_gem/node_processors/begin_node.rb +15 -15
  53. data/lib/solargraph/parser/parser_gem/node_processors/block_node.rb +46 -46
  54. data/lib/solargraph/parser/parser_gem/node_processors/def_node.rb +53 -53
  55. data/lib/solargraph/parser/parser_gem/node_processors/if_node.rb +23 -23
  56. data/lib/solargraph/parser/parser_gem/node_processors/ivasgn_node.rb +40 -40
  57. data/lib/solargraph/parser/parser_gem/node_processors/lvasgn_node.rb +29 -29
  58. data/lib/solargraph/parser/parser_gem/node_processors/masgn_node.rb +59 -59
  59. data/lib/solargraph/parser/parser_gem/node_processors/opasgn_node.rb +98 -98
  60. data/lib/solargraph/parser/parser_gem/node_processors/orasgn_node.rb +17 -17
  61. data/lib/solargraph/parser/parser_gem/node_processors/resbody_node.rb +38 -38
  62. data/lib/solargraph/parser/parser_gem/node_processors/sclass_node.rb +52 -52
  63. data/lib/solargraph/parser/parser_gem/node_processors/send_node.rb +291 -291
  64. data/lib/solargraph/parser/parser_gem/node_processors/while_node.rb +29 -29
  65. data/lib/solargraph/parser/parser_gem/node_processors.rb +70 -70
  66. data/lib/solargraph/parser/region.rb +69 -69
  67. data/lib/solargraph/parser/snippet.rb +17 -17
  68. data/lib/solargraph/pin/base.rb +729 -729
  69. data/lib/solargraph/pin/base_variable.rb +126 -126
  70. data/lib/solargraph/pin/block.rb +104 -104
  71. data/lib/solargraph/pin/breakable.rb +9 -9
  72. data/lib/solargraph/pin/callable.rb +231 -231
  73. data/lib/solargraph/pin/closure.rb +72 -72
  74. data/lib/solargraph/pin/common.rb +79 -79
  75. data/lib/solargraph/pin/conversions.rb +123 -123
  76. data/lib/solargraph/pin/delegated_method.rb +120 -120
  77. data/lib/solargraph/pin/documenting.rb +114 -114
  78. data/lib/solargraph/pin/instance_variable.rb +34 -34
  79. data/lib/solargraph/pin/keyword.rb +20 -20
  80. data/lib/solargraph/pin/local_variable.rb +75 -75
  81. data/lib/solargraph/pin/method.rb +672 -672
  82. data/lib/solargraph/pin/method_alias.rb +34 -34
  83. data/lib/solargraph/pin/namespace.rb +115 -115
  84. data/lib/solargraph/pin/parameter.rb +275 -275
  85. data/lib/solargraph/pin/proxy_type.rb +39 -39
  86. data/lib/solargraph/pin/reference/override.rb +47 -47
  87. data/lib/solargraph/pin/reference/superclass.rb +15 -15
  88. data/lib/solargraph/pin/reference.rb +39 -39
  89. data/lib/solargraph/pin/search.rb +61 -61
  90. data/lib/solargraph/pin/signature.rb +61 -61
  91. data/lib/solargraph/pin/symbol.rb +53 -53
  92. data/lib/solargraph/pin/until.rb +18 -18
  93. data/lib/solargraph/pin/while.rb +18 -18
  94. data/lib/solargraph/pin.rb +44 -44
  95. data/lib/solargraph/pin_cache.rb +245 -245
  96. data/lib/solargraph/position.rb +132 -119
  97. data/lib/solargraph/range.rb +112 -112
  98. data/lib/solargraph/rbs_map/conversions.rb +823 -823
  99. data/lib/solargraph/rbs_map/core_map.rb +58 -58
  100. data/lib/solargraph/rbs_map/stdlib_map.rb +43 -43
  101. data/lib/solargraph/rbs_map.rb +163 -163
  102. data/lib/solargraph/shell.rb +352 -352
  103. data/lib/solargraph/source/chain/call.rb +337 -337
  104. data/lib/solargraph/source/chain/constant.rb +26 -26
  105. data/lib/solargraph/source/chain/hash.rb +34 -34
  106. data/lib/solargraph/source/chain/if.rb +28 -28
  107. data/lib/solargraph/source/chain/instance_variable.rb +13 -13
  108. data/lib/solargraph/source/chain/literal.rb +48 -48
  109. data/lib/solargraph/source/chain/or.rb +23 -23
  110. data/lib/solargraph/source/chain.rb +291 -291
  111. data/lib/solargraph/source/change.rb +82 -82
  112. data/lib/solargraph/source/cursor.rb +166 -166
  113. data/lib/solargraph/source/source_chainer.rb +194 -194
  114. data/lib/solargraph/source/updater.rb +55 -55
  115. data/lib/solargraph/source.rb +498 -498
  116. data/lib/solargraph/source_map/clip.rb +226 -226
  117. data/lib/solargraph/source_map/data.rb +34 -34
  118. data/lib/solargraph/source_map/mapper.rb +259 -259
  119. data/lib/solargraph/source_map.rb +212 -212
  120. data/lib/solargraph/type_checker/checks.rb +124 -124
  121. data/lib/solargraph/type_checker/param_def.rb +37 -37
  122. data/lib/solargraph/type_checker/problem.rb +32 -32
  123. data/lib/solargraph/type_checker/rules.rb +84 -84
  124. data/lib/solargraph/type_checker.rb +814 -814
  125. data/lib/solargraph/version.rb +1 -1
  126. data/lib/solargraph/workspace/config.rb +255 -255
  127. data/lib/solargraph/workspace/require_paths.rb +97 -97
  128. data/lib/solargraph/workspace.rb +220 -220
  129. data/lib/solargraph/yard_map/helpers.rb +44 -44
  130. data/lib/solargraph/yard_map/mapper/to_method.rb +130 -130
  131. data/lib/solargraph/yard_map/mapper/to_namespace.rb +31 -31
  132. data/lib/solargraph/yard_map/mapper.rb +79 -79
  133. data/lib/solargraph/yard_map/to_method.rb +89 -89
  134. data/lib/solargraph/yardoc.rb +87 -87
  135. data/lib/solargraph.rb +105 -105
  136. data/rbs_collection.yaml +1 -1
  137. metadata +12 -12
  138. /data/{sig → rbs}/shims/ast/0/node.rbs +0 -0
  139. /data/{sig → rbs}/shims/ast/2.4/.rbs_meta.yaml +0 -0
  140. /data/{sig → rbs}/shims/ast/2.4/ast.rbs +0 -0
  141. /data/{sig → rbs}/shims/parser/3.2.0.1/builders/default.rbs +0 -0
  142. /data/{sig → rbs}/shims/parser/3.2.0.1/manifest.yaml +0 -0
  143. /data/{sig → rbs}/shims/parser/3.2.0.1/parser.rbs +0 -0
  144. /data/{sig → rbs}/shims/parser/3.2.0.1/polyfill.rbs +0 -0
  145. /data/{sig → rbs}/shims/thor/1.2.0.1/.rbs_meta.yaml +0 -0
  146. /data/{sig → rbs}/shims/thor/1.2.0.1/manifest.yaml +0 -0
  147. /data/{sig → rbs}/shims/thor/1.2.0.1/thor.rbs +0 -0
@@ -1,44 +1,44 @@
1
- module Solargraph
2
- class YardMap
3
- module Helpers
4
- module_function
5
-
6
- # @param code_object [YARD::CodeObjects::Base]
7
- # @param spec [Gem::Specification, nil]
8
- # @return [Solargraph::Location, nil]
9
- def object_location code_object, spec
10
- if spec.nil? || code_object.nil? || code_object.file.nil? || code_object.line.nil?
11
- if code_object.namespace.is_a?(YARD::CodeObjects::NamespaceObject)
12
- # If the code object is a namespace, use the namespace's location
13
- return object_location(code_object.namespace, spec)
14
- end
15
- return Solargraph::Location.new(__FILE__, Solargraph::Range.from_to(__LINE__ - 1, 0, __LINE__ - 1, 0))
16
- end
17
- file = File.join(spec.full_gem_path, code_object.file)
18
- Solargraph::Location.new(file, Solargraph::Range.from_to(code_object.line - 1, 0, code_object.line - 1, 0))
19
- end
20
-
21
- # @param code_object [YARD::CodeObjects::Base]
22
- # @param spec [Gem::Specification, nil]
23
- # @return [Solargraph::Pin::Namespace]
24
- def create_closure_namespace_for(code_object, spec)
25
- code_object_for_location = code_object
26
- # code_object.namespace is sometimes a YARD proxy object pointing to a method path ("Object#new")
27
- code_object_for_location = code_object.namespace if code_object.namespace.is_a?(YARD::CodeObjects::NamespaceObject)
28
- namespace_location = object_location(code_object_for_location, spec)
29
- ns_name = code_object.namespace.to_s
30
- if ns_name.empty?
31
- Solargraph::Pin::ROOT_PIN
32
- else
33
- Solargraph::Pin::Namespace.new(
34
- name: ns_name,
35
- closure: Pin::ROOT_PIN,
36
- gates: [code_object.namespace.to_s],
37
- source: :yardoc,
38
- location: namespace_location
39
- )
40
- end
41
- end
42
- end
43
- end
44
- end
1
+ module Solargraph
2
+ class YardMap
3
+ module Helpers
4
+ module_function
5
+
6
+ # @param code_object [YARD::CodeObjects::Base]
7
+ # @param spec [Gem::Specification, nil]
8
+ # @return [Solargraph::Location, nil]
9
+ def object_location code_object, spec
10
+ if spec.nil? || code_object.nil? || code_object.file.nil? || code_object.line.nil?
11
+ if code_object.namespace.is_a?(YARD::CodeObjects::NamespaceObject)
12
+ # If the code object is a namespace, use the namespace's location
13
+ return object_location(code_object.namespace, spec)
14
+ end
15
+ return Solargraph::Location.new(__FILE__, Solargraph::Range.from_to(__LINE__ - 1, 0, __LINE__ - 1, 0))
16
+ end
17
+ file = File.join(spec.full_gem_path, code_object.file)
18
+ Solargraph::Location.new(file, Solargraph::Range.from_to(code_object.line - 1, 0, code_object.line - 1, 0))
19
+ end
20
+
21
+ # @param code_object [YARD::CodeObjects::Base]
22
+ # @param spec [Gem::Specification, nil]
23
+ # @return [Solargraph::Pin::Namespace]
24
+ def create_closure_namespace_for(code_object, spec)
25
+ code_object_for_location = code_object
26
+ # code_object.namespace is sometimes a YARD proxy object pointing to a method path ("Object#new")
27
+ code_object_for_location = code_object.namespace if code_object.namespace.is_a?(YARD::CodeObjects::NamespaceObject)
28
+ namespace_location = object_location(code_object_for_location, spec)
29
+ ns_name = code_object.namespace.to_s
30
+ if ns_name.empty?
31
+ Solargraph::Pin::ROOT_PIN
32
+ else
33
+ Solargraph::Pin::Namespace.new(
34
+ name: ns_name,
35
+ closure: Pin::ROOT_PIN,
36
+ gates: [code_object.namespace.to_s],
37
+ source: :yardoc,
38
+ location: namespace_location
39
+ )
40
+ end
41
+ end
42
+ end
43
+ end
44
+ end
@@ -1,130 +1,130 @@
1
- # frozen_string_literal: true
2
-
3
- module Solargraph
4
- class YardMap
5
- class Mapper
6
- module ToMethod
7
- extend YardMap::Helpers
8
-
9
- VISIBILITY_OVERRIDE = {
10
- # YARD pays attention to 'private' statements prior to class methods but shouldn't
11
- ["Rails::Engine", :class, "find_root_with_flag"] => :public
12
- }
13
-
14
- # @param code_object [YARD::CodeObjects::MethodObject]
15
- # @param name [String, nil]
16
- # @param scope [Symbol, nil]
17
- # @param visibility [Symbol, nil]
18
- # @param closure [Solargraph::Pin::Namespace, nil]
19
- # @param spec [Gem::Specification, nil]
20
- # @return [Solargraph::Pin::Method]
21
- def self.make code_object, name = nil, scope = nil, visibility = nil, closure = nil, spec = nil
22
- closure ||= create_closure_namespace_for(code_object, spec)
23
- location = object_location(code_object, spec)
24
- name ||= code_object.name.to_s
25
- return_type = ComplexType::SELF if name == 'new'
26
- comments = code_object.docstring ? code_object.docstring.all.to_s : ''
27
- final_scope = scope || code_object.scope
28
- override_key = [closure.path, final_scope, name]
29
- final_visibility = VISIBILITY_OVERRIDE[override_key]
30
- final_visibility ||= VISIBILITY_OVERRIDE[[closure.path, final_scope]]
31
- final_visibility ||= :private if closure.path == 'Kernel' && Kernel.private_instance_methods(false).include?(name.to_sym)
32
- final_visibility ||= visibility
33
- final_visibility ||= :private if code_object.module_function? && final_scope == :instance
34
- final_visibility ||= :public if code_object.module_function? && final_scope == :class
35
- final_visibility ||= code_object.visibility
36
- if code_object.is_alias?
37
- origin_code_object = code_object.namespace.aliases[code_object]
38
- pin = Pin::MethodAlias.new(
39
- name: name,
40
- location: location,
41
- original: origin_code_object.name.to_s,
42
- closure: closure,
43
- comments: comments,
44
- scope: final_scope,
45
- visibility: final_visibility,
46
- explicit: code_object.is_explicit?,
47
- return_type: return_type,
48
- parameters: [],
49
- source: :yardoc,
50
- )
51
- else
52
- pin = Pin::Method.new(
53
- location: location,
54
- closure: closure,
55
- name: name,
56
- comments: comments,
57
- scope: final_scope,
58
- visibility: final_visibility,
59
- # @todo Might need to convert overloads to signatures
60
- explicit: code_object.is_explicit?,
61
- return_type: return_type,
62
- attribute: code_object.is_attribute?,
63
- parameters: [],
64
- source: :yardoc,
65
- )
66
- pin.parameters.concat get_parameters(code_object, location, comments, pin)
67
- pin.parameters.freeze
68
- end
69
- logger.debug { "ToMethod.make: Just created method pin: #{pin.inspect}" }
70
- pin
71
- end
72
-
73
- class << self
74
- include Logging
75
-
76
- private
77
-
78
- # @param code_object [YARD::CodeObjects::Base]
79
- # @param location [Location],
80
- # @param comments [String]
81
- # @param pin [Pin::Base]
82
- # @return [Array<Solargraph::Pin::Parameter>]
83
- def get_parameters code_object, location, comments, pin
84
- return [] unless code_object.is_a?(YARD::CodeObjects::MethodObject)
85
- # HACK: Skip `nil` and `self` parameters that are sometimes emitted
86
- # for methods defined in C
87
- # See https://github.com/castwide/solargraph/issues/345
88
- # @sg-ignore https://github.com/castwide/solargraph/pull/1114
89
- code_object.parameters.select { |a| a[0] && a[0] != 'self' }.map do |a|
90
- Solargraph::Pin::Parameter.new(
91
- location: location,
92
- closure: pin,
93
- comments: comments,
94
- name: arg_name(a),
95
- presence: nil,
96
- decl: arg_type(a),
97
- asgn_code: a[1],
98
- source: :yardoc,
99
- )
100
- end
101
- end
102
-
103
- # @param a [Array<String>]
104
- # @return [String]
105
- def arg_name a
106
- a[0].gsub(/[^a-z0-9_]/i, '')
107
- end
108
-
109
- # @param a [Array]
110
- # @return [::Symbol]
111
- def arg_type a
112
- if a[0].start_with?('**')
113
- :kwrestarg
114
- elsif a[0].start_with?('*')
115
- :restarg
116
- elsif a[0].start_with?('&')
117
- :blockarg
118
- elsif a[0].end_with?(':')
119
- a[1] ? :kwoptarg : :kwarg
120
- elsif a[1]
121
- :optarg
122
- else
123
- :arg
124
- end
125
- end
126
- end
127
- end
128
- end
129
- end
130
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Solargraph
4
+ class YardMap
5
+ class Mapper
6
+ module ToMethod
7
+ extend YardMap::Helpers
8
+
9
+ VISIBILITY_OVERRIDE = {
10
+ # YARD pays attention to 'private' statements prior to class methods but shouldn't
11
+ ["Rails::Engine", :class, "find_root_with_flag"] => :public
12
+ }
13
+
14
+ # @param code_object [YARD::CodeObjects::MethodObject]
15
+ # @param name [String, nil]
16
+ # @param scope [Symbol, nil]
17
+ # @param visibility [Symbol, nil]
18
+ # @param closure [Solargraph::Pin::Namespace, nil]
19
+ # @param spec [Gem::Specification, nil]
20
+ # @return [Solargraph::Pin::Method]
21
+ def self.make code_object, name = nil, scope = nil, visibility = nil, closure = nil, spec = nil
22
+ closure ||= create_closure_namespace_for(code_object, spec)
23
+ location = object_location(code_object, spec)
24
+ name ||= code_object.name.to_s
25
+ return_type = ComplexType::SELF if name == 'new'
26
+ comments = code_object.docstring ? code_object.docstring.all.to_s : ''
27
+ final_scope = scope || code_object.scope
28
+ override_key = [closure.path, final_scope, name]
29
+ final_visibility = VISIBILITY_OVERRIDE[override_key]
30
+ final_visibility ||= VISIBILITY_OVERRIDE[[closure.path, final_scope]]
31
+ final_visibility ||= :private if closure.path == 'Kernel' && Kernel.private_instance_methods(false).include?(name.to_sym)
32
+ final_visibility ||= visibility
33
+ final_visibility ||= :private if code_object.module_function? && final_scope == :instance
34
+ final_visibility ||= :public if code_object.module_function? && final_scope == :class
35
+ final_visibility ||= code_object.visibility
36
+ if code_object.is_alias?
37
+ origin_code_object = code_object.namespace.aliases[code_object]
38
+ pin = Pin::MethodAlias.new(
39
+ name: name,
40
+ location: location,
41
+ original: origin_code_object.name.to_s,
42
+ closure: closure,
43
+ comments: comments,
44
+ scope: final_scope,
45
+ visibility: final_visibility,
46
+ explicit: code_object.is_explicit?,
47
+ return_type: return_type,
48
+ parameters: [],
49
+ source: :yardoc,
50
+ )
51
+ else
52
+ pin = Pin::Method.new(
53
+ location: location,
54
+ closure: closure,
55
+ name: name,
56
+ comments: comments,
57
+ scope: final_scope,
58
+ visibility: final_visibility,
59
+ # @todo Might need to convert overloads to signatures
60
+ explicit: code_object.is_explicit?,
61
+ return_type: return_type,
62
+ attribute: code_object.is_attribute?,
63
+ parameters: [],
64
+ source: :yardoc,
65
+ )
66
+ pin.parameters.concat get_parameters(code_object, location, comments, pin)
67
+ pin.parameters.freeze
68
+ end
69
+ logger.debug { "ToMethod.make: Just created method pin: #{pin.inspect}" }
70
+ pin
71
+ end
72
+
73
+ class << self
74
+ include Logging
75
+
76
+ private
77
+
78
+ # @param code_object [YARD::CodeObjects::Base]
79
+ # @param location [Location],
80
+ # @param comments [String]
81
+ # @param pin [Pin::Base]
82
+ # @return [Array<Solargraph::Pin::Parameter>]
83
+ def get_parameters code_object, location, comments, pin
84
+ return [] unless code_object.is_a?(YARD::CodeObjects::MethodObject)
85
+ # HACK: Skip `nil` and `self` parameters that are sometimes emitted
86
+ # for methods defined in C
87
+ # See https://github.com/castwide/solargraph/issues/345
88
+ # @sg-ignore https://github.com/castwide/solargraph/pull/1114
89
+ code_object.parameters.select { |a| a[0] && a[0] != 'self' }.map do |a|
90
+ Solargraph::Pin::Parameter.new(
91
+ location: location,
92
+ closure: pin,
93
+ comments: comments,
94
+ name: arg_name(a),
95
+ presence: nil,
96
+ decl: arg_type(a),
97
+ asgn_code: a[1],
98
+ source: :yardoc,
99
+ )
100
+ end
101
+ end
102
+
103
+ # @param a [Array<String>]
104
+ # @return [String]
105
+ def arg_name a
106
+ a[0].gsub(/[^a-z0-9_]/i, '')
107
+ end
108
+
109
+ # @param a [Array]
110
+ # @return [::Symbol]
111
+ def arg_type a
112
+ if a[0].start_with?('**')
113
+ :kwrestarg
114
+ elsif a[0].start_with?('*')
115
+ :restarg
116
+ elsif a[0].start_with?('&')
117
+ :blockarg
118
+ elsif a[0].end_with?(':')
119
+ a[1] ? :kwoptarg : :kwarg
120
+ elsif a[1]
121
+ :optarg
122
+ else
123
+ :arg
124
+ end
125
+ end
126
+ end
127
+ end
128
+ end
129
+ end
130
+ end
@@ -1,31 +1,31 @@
1
- # frozen_string_literal: true
2
-
3
- module Solargraph
4
- class YardMap
5
- class Mapper
6
- module ToNamespace
7
- extend YardMap::Helpers
8
-
9
- # @param code_object [YARD::CodeObjects::NamespaceObject]
10
- # @param spec [Gem::Specification, nil]
11
- # @param closure [Pin::Closure, nil]
12
- # @return [Pin::Namespace]
13
- def self.make code_object, spec, closure = nil
14
- closure ||= create_closure_namespace_for(code_object, spec)
15
- location = object_location(code_object, spec)
16
-
17
- Pin::Namespace.new(
18
- location: location,
19
- name: code_object.name.to_s,
20
- comments: code_object.docstring ? code_object.docstring.all.to_s : '',
21
- type: code_object.is_a?(YARD::CodeObjects::ClassObject) ? :class : :module,
22
- visibility: code_object.visibility,
23
- closure: closure,
24
- gates: closure.gates,
25
- source: :yardoc,
26
- )
27
- end
28
- end
29
- end
30
- end
31
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Solargraph
4
+ class YardMap
5
+ class Mapper
6
+ module ToNamespace
7
+ extend YardMap::Helpers
8
+
9
+ # @param code_object [YARD::CodeObjects::NamespaceObject]
10
+ # @param spec [Gem::Specification, nil]
11
+ # @param closure [Pin::Closure, nil]
12
+ # @return [Pin::Namespace]
13
+ def self.make code_object, spec, closure = nil
14
+ closure ||= create_closure_namespace_for(code_object, spec)
15
+ location = object_location(code_object, spec)
16
+
17
+ Pin::Namespace.new(
18
+ location: location,
19
+ name: code_object.name.to_s,
20
+ comments: code_object.docstring ? code_object.docstring.all.to_s : '',
21
+ type: code_object.is_a?(YARD::CodeObjects::ClassObject) ? :class : :module,
22
+ visibility: code_object.visibility,
23
+ closure: closure,
24
+ gates: closure.gates,
25
+ source: :yardoc,
26
+ )
27
+ end
28
+ end
29
+ end
30
+ end
31
+ end
@@ -1,79 +1,79 @@
1
- # frozen_string_literal: true
2
-
3
- module Solargraph
4
- class YardMap
5
- class Mapper
6
- autoload :ToMethod, 'solargraph/yard_map/mapper/to_method'
7
- autoload :ToNamespace, 'solargraph/yard_map/mapper/to_namespace'
8
- autoload :ToConstant, 'solargraph/yard_map/mapper/to_constant'
9
-
10
- # @param code_objects [Array<YARD::CodeObjects::Base>]
11
- # @param spec [Gem::Specification, nil]
12
- def initialize code_objects, spec = nil
13
- @code_objects = code_objects
14
- @spec = spec
15
- # @type [Array<Solargraph::Pin::Base>]
16
- @pins = []
17
- @namespace_pins = {}
18
- end
19
-
20
- # @return [Array<Pin::Base>]
21
- def map
22
- @code_objects.each do |co|
23
- @pins.concat generate_pins co
24
- end
25
- # Some yardocs contain documentation for dependencies that can be
26
- # ignored here. The YardMap will load dependencies separately.
27
- @pins.keep_if { |pin| pin.location.nil? || File.file?(pin.location.filename) } if @spec
28
- @pins
29
- end
30
-
31
- private
32
-
33
- # @param code_object [YARD::CodeObjects::Base]
34
- # @return [Array<Pin::Base>]
35
- def generate_pins code_object
36
- result = []
37
- if code_object.is_a?(YARD::CodeObjects::NamespaceObject)
38
- nspin = ToNamespace.make(code_object, @spec, @namespace_pins[code_object.namespace.to_s])
39
- @namespace_pins[code_object.path] = nspin
40
- result.push nspin
41
- if code_object.is_a?(YARD::CodeObjects::ClassObject) and !code_object.superclass.nil?
42
- # This method of superclass detection is a bit of a hack. If
43
- # the superclass is a Proxy, it is assumed to be undefined in its
44
- # yardoc and converted to a fully qualified namespace.
45
- superclass = if code_object.superclass.is_a?(YARD::CodeObjects::Proxy)
46
- "::#{code_object.superclass}"
47
- else
48
- code_object.superclass.to_s
49
- end
50
- result.push Solargraph::Pin::Reference::Superclass.new(name: superclass, closure: nspin, source: :yard_map)
51
- end
52
- code_object.class_mixins.each do |m|
53
- result.push Solargraph::Pin::Reference::Extend.new(closure: nspin, name: m.path, source: :yard_map)
54
- end
55
- code_object.instance_mixins.each do |m|
56
- result.push Solargraph::Pin::Reference::Include.new(
57
- closure: nspin, # @todo Fix this
58
- name: m.path,
59
- source: :yard_map
60
- )
61
- end
62
- elsif code_object.is_a?(YARD::CodeObjects::MethodObject)
63
- closure = @namespace_pins[code_object.namespace.to_s]
64
- if code_object.name == :initialize && code_object.scope == :instance
65
- # @todo Check the visibility of <Class>.new
66
- result.push ToMethod.make(code_object, 'new', :class, :public, closure, @spec)
67
- result.push ToMethod.make(code_object, 'initialize', :instance, :private, closure, @spec)
68
- else
69
- result.push ToMethod.make(code_object, nil, nil, nil, closure, @spec)
70
- end
71
- elsif code_object.is_a?(YARD::CodeObjects::ConstantObject)
72
- closure = @namespace_pins[code_object.namespace]
73
- result.push ToConstant.make(code_object, closure, @spec)
74
- end
75
- result
76
- end
77
- end
78
- end
79
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Solargraph
4
+ class YardMap
5
+ class Mapper
6
+ autoload :ToMethod, 'solargraph/yard_map/mapper/to_method'
7
+ autoload :ToNamespace, 'solargraph/yard_map/mapper/to_namespace'
8
+ autoload :ToConstant, 'solargraph/yard_map/mapper/to_constant'
9
+
10
+ # @param code_objects [Array<YARD::CodeObjects::Base>]
11
+ # @param spec [Gem::Specification, nil]
12
+ def initialize code_objects, spec = nil
13
+ @code_objects = code_objects
14
+ @spec = spec
15
+ # @type [Array<Solargraph::Pin::Base>]
16
+ @pins = []
17
+ @namespace_pins = {}
18
+ end
19
+
20
+ # @return [Array<Pin::Base>]
21
+ def map
22
+ @code_objects.each do |co|
23
+ @pins.concat generate_pins co
24
+ end
25
+ # Some yardocs contain documentation for dependencies that can be
26
+ # ignored here. The YardMap will load dependencies separately.
27
+ @pins.keep_if { |pin| pin.location.nil? || File.file?(pin.location.filename) } if @spec
28
+ @pins
29
+ end
30
+
31
+ private
32
+
33
+ # @param code_object [YARD::CodeObjects::Base]
34
+ # @return [Array<Pin::Base>]
35
+ def generate_pins code_object
36
+ result = []
37
+ if code_object.is_a?(YARD::CodeObjects::NamespaceObject)
38
+ nspin = ToNamespace.make(code_object, @spec, @namespace_pins[code_object.namespace.to_s])
39
+ @namespace_pins[code_object.path] = nspin
40
+ result.push nspin
41
+ if code_object.is_a?(YARD::CodeObjects::ClassObject) and !code_object.superclass.nil?
42
+ # This method of superclass detection is a bit of a hack. If
43
+ # the superclass is a Proxy, it is assumed to be undefined in its
44
+ # yardoc and converted to a fully qualified namespace.
45
+ superclass = if code_object.superclass.is_a?(YARD::CodeObjects::Proxy)
46
+ "::#{code_object.superclass}"
47
+ else
48
+ code_object.superclass.to_s
49
+ end
50
+ result.push Solargraph::Pin::Reference::Superclass.new(name: superclass, closure: nspin, source: :yard_map)
51
+ end
52
+ code_object.class_mixins.each do |m|
53
+ result.push Solargraph::Pin::Reference::Extend.new(closure: nspin, name: m.path, source: :yard_map)
54
+ end
55
+ code_object.instance_mixins.each do |m|
56
+ result.push Solargraph::Pin::Reference::Include.new(
57
+ closure: nspin, # @todo Fix this
58
+ name: m.path,
59
+ source: :yard_map
60
+ )
61
+ end
62
+ elsif code_object.is_a?(YARD::CodeObjects::MethodObject)
63
+ closure = @namespace_pins[code_object.namespace.to_s]
64
+ if code_object.name == :initialize && code_object.scope == :instance
65
+ # @todo Check the visibility of <Class>.new
66
+ result.push ToMethod.make(code_object, 'new', :class, :public, closure, @spec)
67
+ result.push ToMethod.make(code_object, 'initialize', :instance, :private, closure, @spec)
68
+ else
69
+ result.push ToMethod.make(code_object, nil, nil, nil, closure, @spec)
70
+ end
71
+ elsif code_object.is_a?(YARD::CodeObjects::ConstantObject)
72
+ closure = @namespace_pins[code_object.namespace]
73
+ result.push ToConstant.make(code_object, closure, @spec)
74
+ end
75
+ result
76
+ end
77
+ end
78
+ end
79
+ end