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,166 +1,166 @@
1
- # frozen_string_literal: true
2
-
3
- module Solargraph
4
- module Parser
5
- module ParserGem
6
- # A factory for generating chains from nodes.
7
- #
8
- class NodeChainer
9
- include NodeMethods
10
-
11
- Chain = Source::Chain
12
-
13
- # @param node [Parser::AST::Node]
14
- # @param filename [String, nil]
15
- # @param parent [Parser::AST::Node, nil]
16
- def initialize node, filename = nil, parent = nil
17
- @node = node
18
- @filename = filename
19
- @parent = parent
20
- end
21
-
22
- # @return [Source::Chain]
23
- def chain
24
- links = generate_links(@node)
25
- Chain.new(links, @node, (Parser.is_ast_node?(@node) && @node.type == :splat))
26
- end
27
-
28
- class << self
29
- # @param node [Parser::AST::Node]
30
- # @param filename [String, nil]
31
- # @param parent [Parser::AST::Node, nil]
32
- # @return [Source::Chain]
33
- def chain node, filename = nil, parent = nil
34
- NodeChainer.new(node, filename, parent).chain
35
- end
36
-
37
- # @param code [String]
38
- # @return [Source::Chain]
39
- def load_string(code)
40
- node = Parser.parse(code.sub(/\.$/, ''))
41
- chain = NodeChainer.new(node).chain
42
- chain.links.push(Chain::Link.new) if code.end_with?('.')
43
- chain
44
- end
45
- end
46
-
47
- private
48
-
49
- # @param n [Parser::AST::Node]
50
- # @return [Array<Chain::Link>]
51
- def generate_links n
52
- return [] unless n.is_a?(::Parser::AST::Node)
53
- return generate_links(n.children[0]) if n.type == :splat
54
- # @type [Array<Chain::Link>]
55
- result = []
56
- if n.type == :block
57
- result.concat NodeChainer.chain(n.children[0], @filename, n).links
58
- elsif n.type == :send
59
- if n.children[0].is_a?(::Parser::AST::Node)
60
- result.concat generate_links(n.children[0])
61
- result.push Chain::Call.new(n.children[1].to_s, Location.from_node(n), node_args(n), passed_block(n))
62
- elsif n.children[0].nil?
63
- args = []
64
- n.children[2..-1].each do |c|
65
- args.push NodeChainer.chain(c, @filename, n)
66
- end
67
- result.push Chain::Call.new(n.children[1].to_s, Location.from_node(n), node_args(n), passed_block(n))
68
- else
69
- raise "No idea what to do with #{n}"
70
- end
71
- elsif n.type == :csend
72
- if n.children[0].is_a?(::Parser::AST::Node)
73
- result.concat generate_links(n.children[0])
74
- result.push Chain::QCall.new(n.children[1].to_s, Location.from_node(n), node_args(n))
75
- elsif n.children[0].nil?
76
- result.push Chain::QCall.new(n.children[1].to_s, Location.from_node(n), node_args(n))
77
- else
78
- raise "No idea what to do with #{n}"
79
- end
80
- elsif n.type == :self
81
- result.push Chain::Head.new('self')
82
- elsif n.type == :zsuper
83
- result.push Chain::ZSuper.new('super')
84
- elsif n.type == :super
85
- args = n.children.map { |c| NodeChainer.chain(c, @filename, n) }
86
- result.push Chain::Call.new('super', Location.from_node(n), args)
87
- elsif n.type == :yield
88
- args = n.children.map { |c| NodeChainer.chain(c, @filename, n) }
89
- result.push Chain::Call.new('yield', Location.from_node(n), args)
90
- elsif n.type == :const
91
- const = unpack_name(n)
92
- result.push Chain::Constant.new(const)
93
- elsif [:lvar, :lvasgn].include?(n.type)
94
- result.push Chain::Call.new(n.children[0].to_s, Location.from_node(n))
95
- elsif [:ivar, :ivasgn].include?(n.type)
96
- result.push Chain::InstanceVariable.new(n.children[0].to_s)
97
- elsif [:cvar, :cvasgn].include?(n.type)
98
- result.push Chain::ClassVariable.new(n.children[0].to_s)
99
- elsif [:gvar, :gvasgn].include?(n.type)
100
- result.push Chain::GlobalVariable.new(n.children[0].to_s)
101
- elsif n.type == :or_asgn
102
- new_node = n.updated(n.children[0].type, n.children[0].children + [n.children[1]])
103
- result.concat generate_links new_node
104
- elsif [:class, :module, :def, :defs].include?(n.type)
105
- # @todo Undefined or what?
106
- result.push Chain::UNDEFINED_CALL
107
- elsif n.type == :and
108
- result.concat generate_links(n.children.last)
109
- elsif n.type == :or
110
- result.push Chain::Or.new([NodeChainer.chain(n.children[0], @filename), NodeChainer.chain(n.children[1], @filename, n)])
111
- elsif n.type == :if
112
- result.push Chain::If.new([NodeChainer.chain(n.children[1], @filename), NodeChainer.chain(n.children[2], @filename, n)])
113
- elsif [:begin, :kwbegin].include?(n.type)
114
- result.concat generate_links(n.children.last)
115
- elsif n.type == :block_pass
116
- block_variable_name_node = n.children[0]
117
- if block_variable_name_node.nil?
118
- # anonymous block forwarding (e.g., "&")
119
- # added in Ruby 3.1 - https://bugs.ruby-lang.org/issues/11256
120
- result.push Chain::BlockVariable.new(nil)
121
- else
122
- if block_variable_name_node.type == :sym
123
- result.push Chain::BlockSymbol.new("#{block_variable_name_node.children[0].to_s}")
124
- else
125
- result.push Chain::BlockVariable.new("&#{block_variable_name_node.children[0].to_s}")
126
- end
127
- end
128
- elsif n.type == :hash
129
- result.push Chain::Hash.new('::Hash', n, hash_is_splatted?(n))
130
- elsif n.type == :array
131
- chained_children = n.children.map { |c| NodeChainer.chain(c) }
132
- result.push Source::Chain::Array.new(chained_children, n)
133
- else
134
- lit = infer_literal_node_type(n)
135
- result.push (lit ? Chain::Literal.new(lit, n) : Chain::Link.new)
136
- end
137
- result
138
- end
139
-
140
- # @param node [Parser::AST::Node]
141
- def hash_is_splatted? node
142
- return false unless Parser.is_ast_node?(node) && node.type == :hash
143
- return false unless Parser.is_ast_node?(node.children.last) && node.children.last.type == :kwsplat
144
- return false if Parser.is_ast_node?(node.children.last.children[0]) && node.children.last.children[0].type == :hash
145
- true
146
- end
147
-
148
- # @param node [Parser::AST::Node]
149
- # @return [Source::Chain, nil]
150
- def passed_block node
151
- return unless node == @node && @parent&.type == :block
152
-
153
- NodeChainer.chain(@parent.children[2], @filename)
154
- end
155
-
156
- # @param node [Parser::AST::Node]
157
- # @return [Array<Source::Chain>]
158
- def node_args node
159
- node.children[2..-1].map do |child|
160
- NodeChainer.chain(child, @filename, node)
161
- end
162
- end
163
- end
164
- end
165
- end
166
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Solargraph
4
+ module Parser
5
+ module ParserGem
6
+ # A factory for generating chains from nodes.
7
+ #
8
+ class NodeChainer
9
+ include NodeMethods
10
+
11
+ Chain = Source::Chain
12
+
13
+ # @param node [Parser::AST::Node]
14
+ # @param filename [String, nil]
15
+ # @param parent [Parser::AST::Node, nil]
16
+ def initialize node, filename = nil, parent = nil
17
+ @node = node
18
+ @filename = filename
19
+ @parent = parent
20
+ end
21
+
22
+ # @return [Source::Chain]
23
+ def chain
24
+ links = generate_links(@node)
25
+ Chain.new(links, @node, (Parser.is_ast_node?(@node) && @node.type == :splat))
26
+ end
27
+
28
+ class << self
29
+ # @param node [Parser::AST::Node]
30
+ # @param filename [String, nil]
31
+ # @param parent [Parser::AST::Node, nil]
32
+ # @return [Source::Chain]
33
+ def chain node, filename = nil, parent = nil
34
+ NodeChainer.new(node, filename, parent).chain
35
+ end
36
+
37
+ # @param code [String]
38
+ # @return [Source::Chain]
39
+ def load_string(code)
40
+ node = Parser.parse(code.sub(/\.$/, ''))
41
+ chain = NodeChainer.new(node).chain
42
+ chain.links.push(Chain::Link.new) if code.end_with?('.')
43
+ chain
44
+ end
45
+ end
46
+
47
+ private
48
+
49
+ # @param n [Parser::AST::Node]
50
+ # @return [Array<Chain::Link>]
51
+ def generate_links n
52
+ return [] unless n.is_a?(::Parser::AST::Node)
53
+ return generate_links(n.children[0]) if n.type == :splat
54
+ # @type [Array<Chain::Link>]
55
+ result = []
56
+ if n.type == :block
57
+ result.concat NodeChainer.chain(n.children[0], @filename, n).links
58
+ elsif n.type == :send
59
+ if n.children[0].is_a?(::Parser::AST::Node)
60
+ result.concat generate_links(n.children[0])
61
+ result.push Chain::Call.new(n.children[1].to_s, Location.from_node(n), node_args(n), passed_block(n))
62
+ elsif n.children[0].nil?
63
+ args = []
64
+ n.children[2..-1].each do |c|
65
+ args.push NodeChainer.chain(c, @filename, n)
66
+ end
67
+ result.push Chain::Call.new(n.children[1].to_s, Location.from_node(n), node_args(n), passed_block(n))
68
+ else
69
+ raise "No idea what to do with #{n}"
70
+ end
71
+ elsif n.type == :csend
72
+ if n.children[0].is_a?(::Parser::AST::Node)
73
+ result.concat generate_links(n.children[0])
74
+ result.push Chain::QCall.new(n.children[1].to_s, Location.from_node(n), node_args(n))
75
+ elsif n.children[0].nil?
76
+ result.push Chain::QCall.new(n.children[1].to_s, Location.from_node(n), node_args(n))
77
+ else
78
+ raise "No idea what to do with #{n}"
79
+ end
80
+ elsif n.type == :self
81
+ result.push Chain::Head.new('self')
82
+ elsif n.type == :zsuper
83
+ result.push Chain::ZSuper.new('super')
84
+ elsif n.type == :super
85
+ args = n.children.map { |c| NodeChainer.chain(c, @filename, n) }
86
+ result.push Chain::Call.new('super', Location.from_node(n), args)
87
+ elsif n.type == :yield
88
+ args = n.children.map { |c| NodeChainer.chain(c, @filename, n) }
89
+ result.push Chain::Call.new('yield', Location.from_node(n), args)
90
+ elsif n.type == :const
91
+ const = unpack_name(n)
92
+ result.push Chain::Constant.new(const)
93
+ elsif [:lvar, :lvasgn].include?(n.type)
94
+ result.push Chain::Call.new(n.children[0].to_s, Location.from_node(n))
95
+ elsif [:ivar, :ivasgn].include?(n.type)
96
+ result.push Chain::InstanceVariable.new(n.children[0].to_s)
97
+ elsif [:cvar, :cvasgn].include?(n.type)
98
+ result.push Chain::ClassVariable.new(n.children[0].to_s)
99
+ elsif [:gvar, :gvasgn].include?(n.type)
100
+ result.push Chain::GlobalVariable.new(n.children[0].to_s)
101
+ elsif n.type == :or_asgn
102
+ new_node = n.updated(n.children[0].type, n.children[0].children + [n.children[1]])
103
+ result.concat generate_links new_node
104
+ elsif [:class, :module, :def, :defs].include?(n.type)
105
+ # @todo Undefined or what?
106
+ result.push Chain::UNDEFINED_CALL
107
+ elsif n.type == :and
108
+ result.concat generate_links(n.children.last)
109
+ elsif n.type == :or
110
+ result.push Chain::Or.new([NodeChainer.chain(n.children[0], @filename), NodeChainer.chain(n.children[1], @filename, n)])
111
+ elsif n.type == :if
112
+ result.push Chain::If.new([NodeChainer.chain(n.children[1], @filename), NodeChainer.chain(n.children[2], @filename, n)])
113
+ elsif [:begin, :kwbegin].include?(n.type)
114
+ result.concat generate_links(n.children.last)
115
+ elsif n.type == :block_pass
116
+ block_variable_name_node = n.children[0]
117
+ if block_variable_name_node.nil?
118
+ # anonymous block forwarding (e.g., "&")
119
+ # added in Ruby 3.1 - https://bugs.ruby-lang.org/issues/11256
120
+ result.push Chain::BlockVariable.new(nil)
121
+ else
122
+ if block_variable_name_node.type == :sym
123
+ result.push Chain::BlockSymbol.new("#{block_variable_name_node.children[0].to_s}")
124
+ else
125
+ result.push Chain::BlockVariable.new("&#{block_variable_name_node.children[0].to_s}")
126
+ end
127
+ end
128
+ elsif n.type == :hash
129
+ result.push Chain::Hash.new('::Hash', n, hash_is_splatted?(n))
130
+ elsif n.type == :array
131
+ chained_children = n.children.map { |c| NodeChainer.chain(c) }
132
+ result.push Source::Chain::Array.new(chained_children, n)
133
+ else
134
+ lit = infer_literal_node_type(n)
135
+ result.push (lit ? Chain::Literal.new(lit, n) : Chain::Link.new)
136
+ end
137
+ result
138
+ end
139
+
140
+ # @param node [Parser::AST::Node]
141
+ def hash_is_splatted? node
142
+ return false unless Parser.is_ast_node?(node) && node.type == :hash
143
+ return false unless Parser.is_ast_node?(node.children.last) && node.children.last.type == :kwsplat
144
+ return false if Parser.is_ast_node?(node.children.last.children[0]) && node.children.last.children[0].type == :hash
145
+ true
146
+ end
147
+
148
+ # @param node [Parser::AST::Node]
149
+ # @return [Source::Chain, nil]
150
+ def passed_block node
151
+ return unless node == @node && @parent&.type == :block
152
+
153
+ NodeChainer.chain(@parent.children[2], @filename)
154
+ end
155
+
156
+ # @param node [Parser::AST::Node]
157
+ # @return [Array<Source::Chain>]
158
+ def node_args node
159
+ node.children[2..-1].map do |child|
160
+ NodeChainer.chain(child, @filename, node)
161
+ end
162
+ end
163
+ end
164
+ end
165
+ end
166
+ end