solargraph 0.58.0 → 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 (150) hide show
  1. checksums.yaml +4 -4
  2. data/.gitattributes +2 -0
  3. data/.gitignore +1 -0
  4. data/CHANGELOG.md +9 -0
  5. data/bin/solargraph +8 -8
  6. data/lib/solargraph/api_map/cache.rb +110 -110
  7. data/lib/solargraph/api_map/constants.rb +279 -279
  8. data/lib/solargraph/api_map/index.rb +193 -193
  9. data/lib/solargraph/api_map/source_to_yard.rb +97 -97
  10. data/lib/solargraph/api_map/store.rb +384 -384
  11. data/lib/solargraph/api_map.rb +945 -945
  12. data/lib/solargraph/complex_type/type_methods.rb +228 -228
  13. data/lib/solargraph/complex_type/unique_type.rb +482 -482
  14. data/lib/solargraph/complex_type.rb +444 -444
  15. data/lib/solargraph/convention/data_definition/data_definition_node.rb +91 -91
  16. data/lib/solargraph/convention/data_definition.rb +105 -105
  17. data/lib/solargraph/convention/struct_definition/struct_assignment_node.rb +61 -61
  18. data/lib/solargraph/convention/struct_definition/struct_definition_node.rb +102 -102
  19. data/lib/solargraph/convention/struct_definition.rb +164 -164
  20. data/lib/solargraph/diagnostics/require_not_found.rb +53 -53
  21. data/lib/solargraph/diagnostics/rubocop.rb +118 -118
  22. data/lib/solargraph/diagnostics/rubocop_helpers.rb +68 -68
  23. data/lib/solargraph/diagnostics/type_check.rb +55 -55
  24. data/lib/solargraph/doc_map.rb +439 -439
  25. data/lib/solargraph/equality.rb +34 -34
  26. data/lib/solargraph/gem_pins.rb +98 -98
  27. data/lib/solargraph/language_server/host/diagnoser.rb +89 -89
  28. data/lib/solargraph/language_server/host/dispatch.rb +130 -130
  29. data/lib/solargraph/language_server/host/message_worker.rb +112 -112
  30. data/lib/solargraph/language_server/host/sources.rb +99 -99
  31. data/lib/solargraph/language_server/host.rb +878 -878
  32. data/lib/solargraph/language_server/message/extended/check_gem_version.rb +114 -114
  33. data/lib/solargraph/language_server/message/extended/document.rb +23 -23
  34. data/lib/solargraph/language_server/message/text_document/completion.rb +56 -56
  35. data/lib/solargraph/language_server/message/text_document/definition.rb +40 -40
  36. data/lib/solargraph/language_server/message/text_document/document_symbol.rb +26 -26
  37. data/lib/solargraph/language_server/message/text_document/formatting.rb +148 -148
  38. data/lib/solargraph/language_server/message/text_document/hover.rb +58 -58
  39. data/lib/solargraph/language_server/message/text_document/signature_help.rb +24 -24
  40. data/lib/solargraph/language_server/message/text_document/type_definition.rb +25 -25
  41. data/lib/solargraph/language_server/message/workspace/workspace_symbol.rb +23 -23
  42. data/lib/solargraph/library.rb +683 -683
  43. data/lib/solargraph/location.rb +82 -82
  44. data/lib/solargraph/logging.rb +37 -37
  45. data/lib/solargraph/parser/comment_ripper.rb +69 -69
  46. data/lib/solargraph/parser/flow_sensitive_typing.rb +255 -255
  47. data/lib/solargraph/parser/node_processor/base.rb +92 -92
  48. data/lib/solargraph/parser/node_processor.rb +62 -62
  49. data/lib/solargraph/parser/parser_gem/class_methods.rb +149 -149
  50. data/lib/solargraph/parser/parser_gem/node_chainer.rb +166 -166
  51. data/lib/solargraph/parser/parser_gem/node_methods.rb +486 -486
  52. data/lib/solargraph/parser/parser_gem/node_processors/and_node.rb +22 -22
  53. data/lib/solargraph/parser/parser_gem/node_processors/args_node.rb +59 -59
  54. data/lib/solargraph/parser/parser_gem/node_processors/begin_node.rb +15 -15
  55. data/lib/solargraph/parser/parser_gem/node_processors/block_node.rb +46 -46
  56. data/lib/solargraph/parser/parser_gem/node_processors/def_node.rb +53 -53
  57. data/lib/solargraph/parser/parser_gem/node_processors/if_node.rb +23 -23
  58. data/lib/solargraph/parser/parser_gem/node_processors/ivasgn_node.rb +40 -40
  59. data/lib/solargraph/parser/parser_gem/node_processors/lvasgn_node.rb +29 -29
  60. data/lib/solargraph/parser/parser_gem/node_processors/masgn_node.rb +59 -59
  61. data/lib/solargraph/parser/parser_gem/node_processors/opasgn_node.rb +98 -98
  62. data/lib/solargraph/parser/parser_gem/node_processors/orasgn_node.rb +17 -17
  63. data/lib/solargraph/parser/parser_gem/node_processors/resbody_node.rb +38 -38
  64. data/lib/solargraph/parser/parser_gem/node_processors/sclass_node.rb +52 -52
  65. data/lib/solargraph/parser/parser_gem/node_processors/send_node.rb +291 -291
  66. data/lib/solargraph/parser/parser_gem/node_processors/while_node.rb +29 -29
  67. data/lib/solargraph/parser/parser_gem/node_processors.rb +70 -70
  68. data/lib/solargraph/parser/region.rb +69 -69
  69. data/lib/solargraph/parser/snippet.rb +17 -17
  70. data/lib/solargraph/pin/base.rb +729 -729
  71. data/lib/solargraph/pin/base_variable.rb +126 -126
  72. data/lib/solargraph/pin/block.rb +104 -104
  73. data/lib/solargraph/pin/breakable.rb +9 -9
  74. data/lib/solargraph/pin/callable.rb +231 -231
  75. data/lib/solargraph/pin/closure.rb +72 -72
  76. data/lib/solargraph/pin/common.rb +79 -79
  77. data/lib/solargraph/pin/conversions.rb +123 -123
  78. data/lib/solargraph/pin/delegated_method.rb +120 -120
  79. data/lib/solargraph/pin/documenting.rb +114 -114
  80. data/lib/solargraph/pin/instance_variable.rb +34 -34
  81. data/lib/solargraph/pin/keyword.rb +20 -20
  82. data/lib/solargraph/pin/local_variable.rb +75 -75
  83. data/lib/solargraph/pin/method.rb +672 -672
  84. data/lib/solargraph/pin/method_alias.rb +34 -34
  85. data/lib/solargraph/pin/namespace.rb +115 -115
  86. data/lib/solargraph/pin/parameter.rb +275 -275
  87. data/lib/solargraph/pin/proxy_type.rb +39 -39
  88. data/lib/solargraph/pin/reference/override.rb +47 -47
  89. data/lib/solargraph/pin/reference/superclass.rb +15 -15
  90. data/lib/solargraph/pin/reference.rb +39 -39
  91. data/lib/solargraph/pin/search.rb +61 -61
  92. data/lib/solargraph/pin/signature.rb +61 -61
  93. data/lib/solargraph/pin/symbol.rb +53 -53
  94. data/lib/solargraph/pin/until.rb +18 -18
  95. data/lib/solargraph/pin/while.rb +18 -18
  96. data/lib/solargraph/pin.rb +44 -44
  97. data/lib/solargraph/pin_cache.rb +245 -245
  98. data/lib/solargraph/position.rb +132 -119
  99. data/lib/solargraph/range.rb +112 -112
  100. data/lib/solargraph/rbs_map/conversions.rb +823 -823
  101. data/lib/solargraph/rbs_map/core_map.rb +58 -58
  102. data/lib/solargraph/rbs_map/stdlib_map.rb +43 -43
  103. data/lib/solargraph/rbs_map.rb +163 -163
  104. data/lib/solargraph/shell.rb +352 -352
  105. data/lib/solargraph/source/chain/call.rb +337 -337
  106. data/lib/solargraph/source/chain/constant.rb +26 -26
  107. data/lib/solargraph/source/chain/hash.rb +34 -34
  108. data/lib/solargraph/source/chain/if.rb +28 -28
  109. data/lib/solargraph/source/chain/instance_variable.rb +13 -13
  110. data/lib/solargraph/source/chain/literal.rb +48 -48
  111. data/lib/solargraph/source/chain/or.rb +23 -23
  112. data/lib/solargraph/source/chain.rb +291 -291
  113. data/lib/solargraph/source/change.rb +82 -82
  114. data/lib/solargraph/source/cursor.rb +166 -166
  115. data/lib/solargraph/source/encoding_fixes.rb +23 -23
  116. data/lib/solargraph/source/source_chainer.rb +194 -194
  117. data/lib/solargraph/source/updater.rb +55 -55
  118. data/lib/solargraph/source.rb +498 -498
  119. data/lib/solargraph/source_map/clip.rb +226 -226
  120. data/lib/solargraph/source_map/data.rb +34 -34
  121. data/lib/solargraph/source_map/mapper.rb +259 -259
  122. data/lib/solargraph/source_map.rb +212 -212
  123. data/lib/solargraph/type_checker/checks.rb +124 -124
  124. data/lib/solargraph/type_checker/param_def.rb +37 -37
  125. data/lib/solargraph/type_checker/problem.rb +32 -32
  126. data/lib/solargraph/type_checker/rules.rb +84 -84
  127. data/lib/solargraph/type_checker.rb +814 -814
  128. data/lib/solargraph/version.rb +5 -5
  129. data/lib/solargraph/workspace/config.rb +255 -255
  130. data/lib/solargraph/workspace/require_paths.rb +97 -97
  131. data/lib/solargraph/workspace.rb +220 -220
  132. data/lib/solargraph/yard_map/helpers.rb +44 -44
  133. data/lib/solargraph/yard_map/mapper/to_method.rb +130 -130
  134. data/lib/solargraph/yard_map/mapper/to_namespace.rb +31 -31
  135. data/lib/solargraph/yard_map/mapper.rb +79 -79
  136. data/lib/solargraph/yard_map/to_method.rb +89 -89
  137. data/lib/solargraph/yardoc.rb +87 -87
  138. data/lib/solargraph.rb +105 -105
  139. data/rbs_collection.yaml +1 -1
  140. metadata +13 -12
  141. /data/{sig → rbs}/shims/ast/0/node.rbs +0 -0
  142. /data/{sig → rbs}/shims/ast/2.4/.rbs_meta.yaml +0 -0
  143. /data/{sig → rbs}/shims/ast/2.4/ast.rbs +0 -0
  144. /data/{sig → rbs}/shims/parser/3.2.0.1/builders/default.rbs +0 -0
  145. /data/{sig → rbs}/shims/parser/3.2.0.1/manifest.yaml +0 -0
  146. /data/{sig → rbs}/shims/parser/3.2.0.1/parser.rbs +0 -0
  147. /data/{sig → rbs}/shims/parser/3.2.0.1/polyfill.rbs +0 -0
  148. /data/{sig → rbs}/shims/thor/1.2.0.1/.rbs_meta.yaml +0 -0
  149. /data/{sig → rbs}/shims/thor/1.2.0.1/manifest.yaml +0 -0
  150. /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