steep 0.14.0 → 0.15.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (190) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +5 -0
  3. data/exe/rbs +1 -1
  4. data/lib/steep/annotation_parser.rb +4 -4
  5. data/lib/steep/ast/buffer.rb +11 -7
  6. data/lib/steep/ast/builtin.rb +8 -0
  7. data/lib/steep/ast/types/factory.rb +55 -55
  8. data/lib/steep/drivers/check.rb +20 -4
  9. data/lib/steep/drivers/langserver.rb +6 -1
  10. data/lib/steep/drivers/vendor.rb +2 -2
  11. data/lib/steep/project/completion_provider.rb +5 -11
  12. data/lib/steep/project/dsl.rb +14 -0
  13. data/lib/steep/project/file.rb +42 -46
  14. data/lib/steep/project/hover_content.rb +11 -5
  15. data/lib/steep/project/options.rb +25 -3
  16. data/lib/steep/project/target.rb +10 -4
  17. data/lib/steep/signature/errors.rb +1 -1
  18. data/lib/steep/signature/validator.rb +8 -8
  19. data/lib/steep/source.rb +1 -1
  20. data/lib/steep/type_construction.rb +987 -711
  21. data/lib/steep/type_inference/constant_env.rb +1 -1
  22. data/lib/steep/type_inference/context.rb +7 -3
  23. data/lib/steep/type_inference/context_array.rb +111 -0
  24. data/lib/steep/type_inference/local_variable_type_env.rb +226 -0
  25. data/lib/steep/type_inference/logic.rb +130 -0
  26. data/lib/steep/type_inference/type_env.rb +5 -69
  27. data/lib/steep/typing.rb +79 -22
  28. data/lib/steep/version.rb +1 -1
  29. data/lib/steep.rb +6 -1
  30. data/smoke/alias/Steepfile +1 -0
  31. data/smoke/and/Steepfile +1 -0
  32. data/smoke/array/Steepfile +1 -0
  33. data/smoke/array/b.rb +0 -2
  34. data/smoke/block/Steepfile +1 -0
  35. data/smoke/case/Steepfile +1 -0
  36. data/smoke/class/Steepfile +1 -0
  37. data/smoke/const/Steepfile +1 -0
  38. data/smoke/dstr/Steepfile +1 -0
  39. data/smoke/ensure/Steepfile +1 -0
  40. data/smoke/enumerator/Steepfile +1 -0
  41. data/smoke/extension/Steepfile +1 -0
  42. data/smoke/extension/c.rb +1 -0
  43. data/smoke/hash/Steepfile +1 -0
  44. data/smoke/hello/Steepfile +1 -0
  45. data/smoke/if/Steepfile +1 -0
  46. data/smoke/if/a.rb +1 -1
  47. data/smoke/implements/Steepfile +1 -0
  48. data/smoke/initialize/Steepfile +1 -0
  49. data/smoke/integer/Steepfile +1 -0
  50. data/smoke/interface/Steepfile +1 -0
  51. data/smoke/kwbegin/Steepfile +1 -0
  52. data/smoke/lambda/Steepfile +1 -0
  53. data/smoke/literal/Steepfile +1 -0
  54. data/smoke/map/Steepfile +1 -0
  55. data/smoke/method/Steepfile +1 -0
  56. data/smoke/module/Steepfile +1 -0
  57. data/smoke/regexp/Steepfile +1 -0
  58. data/smoke/regression/Steepfile +1 -0
  59. data/smoke/rescue/Steepfile +1 -0
  60. data/smoke/rescue/a.rb +1 -1
  61. data/smoke/self/Steepfile +1 -0
  62. data/smoke/skip/Steepfile +1 -0
  63. data/smoke/stdout/Steepfile +1 -0
  64. data/smoke/super/Steepfile +1 -0
  65. data/smoke/type_case/Steepfile +1 -0
  66. data/smoke/yield/Steepfile +1 -0
  67. data/steep.gemspec +1 -1
  68. data/vendor/ruby-signature/.gitignore +2 -2
  69. data/vendor/ruby-signature/README.md +2 -2
  70. data/vendor/ruby-signature/Rakefile +2 -2
  71. data/vendor/ruby-signature/bin/annotate-with-rdoc +14 -13
  72. data/vendor/ruby-signature/bin/console +1 -1
  73. data/vendor/ruby-signature/bin/sort +7 -6
  74. data/vendor/ruby-signature/bin/test_runner.rb +0 -1
  75. data/vendor/ruby-signature/docs/CONTRIBUTING.md +1 -1
  76. data/vendor/ruby-signature/docs/sigs.md +3 -3
  77. data/vendor/ruby-signature/docs/stdlib.md +1 -1
  78. data/vendor/ruby-signature/docs/syntax.md +9 -9
  79. data/vendor/ruby-signature/exe/rbs +5 -1
  80. data/vendor/ruby-signature/lib/rbs/ast/annotation.rb +27 -0
  81. data/vendor/ruby-signature/lib/rbs/ast/comment.rb +27 -0
  82. data/vendor/ruby-signature/lib/rbs/ast/declarations.rb +395 -0
  83. data/vendor/ruby-signature/lib/rbs/ast/members.rb +362 -0
  84. data/vendor/ruby-signature/lib/rbs/buffer.rb +50 -0
  85. data/vendor/ruby-signature/lib/rbs/builtin_names.rb +55 -0
  86. data/vendor/ruby-signature/lib/rbs/cli.rb +558 -0
  87. data/vendor/ruby-signature/lib/rbs/constant.rb +26 -0
  88. data/vendor/ruby-signature/lib/rbs/constant_table.rb +150 -0
  89. data/vendor/ruby-signature/lib/rbs/definition.rb +170 -0
  90. data/vendor/ruby-signature/lib/rbs/definition_builder.rb +919 -0
  91. data/vendor/ruby-signature/lib/rbs/environment.rb +281 -0
  92. data/vendor/ruby-signature/lib/rbs/environment_loader.rb +136 -0
  93. data/vendor/ruby-signature/lib/rbs/environment_walker.rb +124 -0
  94. data/vendor/ruby-signature/lib/rbs/errors.rb +187 -0
  95. data/vendor/ruby-signature/lib/rbs/location.rb +102 -0
  96. data/vendor/ruby-signature/lib/rbs/method_type.rb +123 -0
  97. data/vendor/ruby-signature/lib/rbs/namespace.rb +91 -0
  98. data/vendor/ruby-signature/lib/{ruby/signature → rbs}/parser.rb +21 -23
  99. data/vendor/ruby-signature/lib/{ruby/signature → rbs}/parser.y +18 -18
  100. data/vendor/ruby-signature/lib/rbs/prototype/rb.rb +553 -0
  101. data/vendor/ruby-signature/lib/rbs/prototype/rbi.rb +587 -0
  102. data/vendor/ruby-signature/lib/rbs/prototype/runtime.rb +381 -0
  103. data/vendor/ruby-signature/lib/rbs/substitution.rb +46 -0
  104. data/vendor/ruby-signature/lib/rbs/test/errors.rb +61 -0
  105. data/vendor/ruby-signature/lib/rbs/test/hook.rb +294 -0
  106. data/vendor/ruby-signature/lib/{ruby/signature → rbs}/test/setup.rb +7 -7
  107. data/vendor/ruby-signature/lib/rbs/test/spy.rb +325 -0
  108. data/vendor/ruby-signature/lib/rbs/test/test_helper.rb +183 -0
  109. data/vendor/ruby-signature/lib/rbs/test/type_check.rb +254 -0
  110. data/vendor/ruby-signature/lib/rbs/test.rb +26 -0
  111. data/vendor/ruby-signature/lib/rbs/type_name.rb +70 -0
  112. data/vendor/ruby-signature/lib/rbs/types.rb +936 -0
  113. data/vendor/ruby-signature/lib/rbs/variance_calculator.rb +138 -0
  114. data/vendor/ruby-signature/lib/rbs/vendorer.rb +47 -0
  115. data/vendor/ruby-signature/lib/rbs/version.rb +3 -0
  116. data/vendor/ruby-signature/lib/rbs/writer.rb +269 -0
  117. data/vendor/ruby-signature/lib/rbs.rb +64 -0
  118. data/vendor/ruby-signature/lib/ruby/signature.rb +4 -61
  119. data/vendor/ruby-signature/{ruby-signature.gemspec → rbs.gemspec} +4 -4
  120. data/vendor/ruby-signature/stdlib/abbrev/abbrev.rbs +58 -1
  121. data/vendor/ruby-signature/stdlib/base64/base64.rbs +69 -13
  122. data/vendor/ruby-signature/stdlib/benchmark/benchmark.rbs +372 -0
  123. data/vendor/ruby-signature/stdlib/builtin/builtin.rbs +9 -0
  124. data/vendor/ruby-signature/stdlib/builtin/dir.rbs +1 -7
  125. data/vendor/ruby-signature/stdlib/builtin/encoding.rbs +2 -1
  126. data/vendor/ruby-signature/stdlib/builtin/exception.rbs +3 -2
  127. data/vendor/ruby-signature/stdlib/builtin/file.rbs +902 -302
  128. data/vendor/ruby-signature/stdlib/builtin/gc.rbs +190 -68
  129. data/vendor/ruby-signature/stdlib/builtin/integer.rbs +3 -6
  130. data/vendor/ruby-signature/stdlib/builtin/kernel.rbs +6 -4
  131. data/vendor/ruby-signature/stdlib/builtin/marshal.rbs +146 -120
  132. data/vendor/ruby-signature/stdlib/builtin/math.rbs +310 -7
  133. data/vendor/ruby-signature/stdlib/builtin/method.rbs +11 -8
  134. data/vendor/ruby-signature/stdlib/builtin/module.rbs +959 -103
  135. data/vendor/ruby-signature/stdlib/builtin/proc.rbs +3 -0
  136. data/vendor/ruby-signature/stdlib/builtin/process.rbs +981 -108
  137. data/vendor/ruby-signature/stdlib/builtin/random.rbs +215 -41
  138. data/vendor/ruby-signature/stdlib/builtin/rb_config.rbs +47 -0
  139. data/vendor/ruby-signature/stdlib/builtin/string.rbs +9 -2
  140. data/vendor/ruby-signature/stdlib/builtin/string_io.rbs +282 -11
  141. data/vendor/ruby-signature/stdlib/builtin/symbol.rbs +11 -13
  142. data/vendor/ruby-signature/stdlib/builtin/thread.rbs +25 -29
  143. data/vendor/ruby-signature/stdlib/builtin/thread_group.rbs +1 -1
  144. data/vendor/ruby-signature/stdlib/builtin/time.rbs +875 -567
  145. data/vendor/ruby-signature/stdlib/builtin/trace_point.rbs +243 -44
  146. data/vendor/ruby-signature/stdlib/builtin/unbound_method.rbs +103 -109
  147. data/vendor/ruby-signature/stdlib/coverage/coverage.rbs +62 -0
  148. data/vendor/ruby-signature/stdlib/csv/csv.rbs +773 -0
  149. data/vendor/ruby-signature/stdlib/erb/erb.rbs +375 -1
  150. data/vendor/ruby-signature/stdlib/find/find.rbs +0 -4
  151. data/vendor/ruby-signature/stdlib/ipaddr/ipaddr.rbs +247 -0
  152. data/vendor/ruby-signature/stdlib/pathname/pathname.rbs +1088 -16
  153. data/vendor/ruby-signature/stdlib/set/set.rbs +251 -27
  154. metadata +49 -44
  155. data/exe/ruby-signature +0 -3
  156. data/vendor/ruby-signature/exe/ruby-signature +0 -7
  157. data/vendor/ruby-signature/lib/ruby/signature/ast/annotation.rb +0 -29
  158. data/vendor/ruby-signature/lib/ruby/signature/ast/comment.rb +0 -29
  159. data/vendor/ruby-signature/lib/ruby/signature/ast/declarations.rb +0 -391
  160. data/vendor/ruby-signature/lib/ruby/signature/ast/members.rb +0 -364
  161. data/vendor/ruby-signature/lib/ruby/signature/buffer.rb +0 -52
  162. data/vendor/ruby-signature/lib/ruby/signature/builtin_names.rb +0 -54
  163. data/vendor/ruby-signature/lib/ruby/signature/cli.rb +0 -555
  164. data/vendor/ruby-signature/lib/ruby/signature/constant.rb +0 -28
  165. data/vendor/ruby-signature/lib/ruby/signature/constant_table.rb +0 -152
  166. data/vendor/ruby-signature/lib/ruby/signature/definition.rb +0 -172
  167. data/vendor/ruby-signature/lib/ruby/signature/definition_builder.rb +0 -921
  168. data/vendor/ruby-signature/lib/ruby/signature/environment.rb +0 -283
  169. data/vendor/ruby-signature/lib/ruby/signature/environment_loader.rb +0 -138
  170. data/vendor/ruby-signature/lib/ruby/signature/environment_walker.rb +0 -126
  171. data/vendor/ruby-signature/lib/ruby/signature/errors.rb +0 -189
  172. data/vendor/ruby-signature/lib/ruby/signature/location.rb +0 -104
  173. data/vendor/ruby-signature/lib/ruby/signature/method_type.rb +0 -125
  174. data/vendor/ruby-signature/lib/ruby/signature/namespace.rb +0 -93
  175. data/vendor/ruby-signature/lib/ruby/signature/prototype/rb.rb +0 -444
  176. data/vendor/ruby-signature/lib/ruby/signature/prototype/rbi.rb +0 -579
  177. data/vendor/ruby-signature/lib/ruby/signature/prototype/runtime.rb +0 -383
  178. data/vendor/ruby-signature/lib/ruby/signature/substitution.rb +0 -48
  179. data/vendor/ruby-signature/lib/ruby/signature/test/errors.rb +0 -63
  180. data/vendor/ruby-signature/lib/ruby/signature/test/hook.rb +0 -290
  181. data/vendor/ruby-signature/lib/ruby/signature/test/spy.rb +0 -327
  182. data/vendor/ruby-signature/lib/ruby/signature/test/test_helper.rb +0 -185
  183. data/vendor/ruby-signature/lib/ruby/signature/test/type_check.rb +0 -256
  184. data/vendor/ruby-signature/lib/ruby/signature/test.rb +0 -28
  185. data/vendor/ruby-signature/lib/ruby/signature/type_name.rb +0 -72
  186. data/vendor/ruby-signature/lib/ruby/signature/types.rb +0 -932
  187. data/vendor/ruby-signature/lib/ruby/signature/variance_calculator.rb +0 -140
  188. data/vendor/ruby-signature/lib/ruby/signature/vendorer.rb +0 -49
  189. data/vendor/ruby-signature/lib/ruby/signature/version.rb +0 -5
  190. data/vendor/ruby-signature/lib/ruby/signature/writer.rb +0 -271
@@ -1,444 +0,0 @@
1
- module Ruby
2
- module Signature
3
- module Prototype
4
- class RB
5
- attr_reader :source_decls
6
- attr_reader :toplevel_members
7
-
8
- def initialize
9
- @source_decls = []
10
- @toplevel_members = []
11
- end
12
-
13
- def decls
14
- decls = []
15
-
16
- decls.push(*source_decls)
17
-
18
- unless toplevel_members.empty?
19
- top = AST::Declarations::Extension.new(
20
- name: TypeName.new(name: :Object, namespace: Namespace.empty),
21
- extension_name: :Toplevel,
22
- members: toplevel_members,
23
- annotations: [],
24
- comment: nil,
25
- location: nil,
26
- type_params: AST::Declarations::ModuleTypeParams.empty
27
- )
28
- decls << top
29
- end
30
-
31
- decls
32
- end
33
-
34
- def parse(string)
35
- comments = Ripper.lex(string).yield_self do |tokens|
36
- tokens.each.with_object({}) do |token, hash|
37
- if token[1] == :on_comment
38
- line = token[0][0]
39
- body = token[2][2..]
40
-
41
- body = "\n" if body.empty?
42
-
43
- comment = AST::Comment.new(string: body, location: nil)
44
- if (prev_comment = hash[line - 1])
45
- hash[line - 1] = nil
46
- hash[line] = AST::Comment.new(string: prev_comment.string + comment.string,
47
- location: nil)
48
- else
49
- hash[line] = comment
50
- end
51
- end
52
- end
53
- end
54
-
55
- process RubyVM::AbstractSyntaxTree.parse(string), namespace: Namespace.empty, current_module: nil, comments: comments, singleton: false
56
- end
57
-
58
- def nested_name(name)
59
- (current_namespace + const_to_name(name).to_namespace).to_type_name.relative!
60
- end
61
-
62
- def process(node, namespace:, current_module:, comments:, singleton:)
63
- case node.type
64
- when :CLASS
65
- class_name, super_class, *class_body = node.children
66
- kls = AST::Declarations::Class.new(
67
- name: const_to_name(class_name).with_prefix(namespace).relative!,
68
- super_class: super_class && AST::Declarations::Class::Super.new(name: const_to_name(super_class), args: []),
69
- type_params: AST::Declarations::ModuleTypeParams.empty,
70
- members: [],
71
- annotations: [],
72
- location: nil,
73
- comment: comments[node.first_lineno - 1]
74
- )
75
-
76
- source_decls.push kls
77
-
78
- each_node class_body do |child|
79
- process child, namespace: kls.name.to_namespace, current_module: kls, comments: comments, singleton: false
80
- end
81
- when :MODULE
82
- module_name, *module_body = node.children
83
-
84
- mod = AST::Declarations::Module.new(
85
- name: const_to_name(module_name).with_prefix(namespace).relative!,
86
- type_params: AST::Declarations::ModuleTypeParams.empty,
87
- self_type: nil,
88
- members: [],
89
- annotations: [],
90
- location: nil,
91
- comment: comments[node.first_lineno - 1]
92
- )
93
-
94
- source_decls.push mod
95
-
96
- each_node module_body do |child|
97
- process child, namespace: mod.name.to_namespace, current_module: mod, comments: comments, singleton: false
98
- end
99
- when :SCLASS
100
- this = node.children[0]
101
- if this.type != :SELF
102
- Signature.logger.warn "`class <<` syntax with not-self may be compiled to incorrect code: #{this}"
103
- end
104
-
105
- body = node.children[1]
106
- each_child(body) do |child|
107
- process child, namespace: namespace, current_module: current_module, comments: comments, singleton: true
108
- end
109
- when :DEFN, :DEFS
110
- if node.type == :DEFN
111
- def_name, def_body = node.children
112
- kind = singleton ? :singleton : :instance
113
- else
114
- _, def_name, def_body = node.children
115
- kind = :singleton
116
- end
117
-
118
- types = [
119
- MethodType.new(
120
- type_params: [],
121
- type: function_type_from_body(def_body),
122
- block: block_from_body(def_body),
123
- location: nil
124
- )
125
- ]
126
-
127
- member = AST::Members::MethodDefinition.new(
128
- name: def_name,
129
- location: nil,
130
- annotations: [],
131
- types: types,
132
- kind: kind,
133
- comment: comments[node.first_lineno - 1],
134
- attributes: []
135
- )
136
-
137
- if current_module
138
- current_module.members.push member
139
- else
140
- toplevel_members.push member
141
- end
142
- when :FCALL
143
- if current_module
144
- # Inside method definition cannot reach here.
145
- args = node.children[1]&.children || []
146
-
147
- case node.children[0]
148
- when :include
149
- args.each do |arg|
150
- if (name = const_to_name(arg))
151
- current_module.members << AST::Members::Include.new(
152
- name: name,
153
- args: [],
154
- annotations: [],
155
- location: nil,
156
- comment: comments[node.first_lineno - 1]
157
- )
158
- end
159
- end
160
- when :extend
161
- args.each do |arg|
162
- if (name = const_to_name(arg))
163
- current_module.members << AST::Members::Extend.new(
164
- name: name,
165
- args: [],
166
- annotations: [],
167
- location: nil,
168
- comment: comments[node.first_lineno - 1]
169
- )
170
- end
171
- end
172
- when :attr_reader
173
- args.each do |arg|
174
- if arg&.type == :LIT && arg.children[0].is_a?(Symbol)
175
- current_module.members << AST::Members::AttrReader.new(
176
- name: arg.children[0],
177
- ivar_name: nil,
178
- type: Types::Bases::Any.new(location: nil),
179
- location: nil,
180
- comment: comments[node.first_lineno - 1],
181
- annotations: []
182
- )
183
- end
184
- end
185
- when :attr_accessor
186
- args.each do |arg|
187
- if arg&.type == :LIT && arg.children[0].is_a?(Symbol)
188
- current_module.members << AST::Members::AttrAccessor.new(
189
- name: arg.children[0],
190
- ivar_name: nil,
191
- type: Types::Bases::Any.new(location: nil),
192
- location: nil,
193
- comment: comments[node.first_lineno - 1],
194
- annotations: []
195
- )
196
- end
197
- end
198
- when :attr_writer
199
- args.each do |arg|
200
- if arg&.type == :LIT && arg.children[0].is_a?(Symbol)
201
- current_module.members << AST::Members::AttrWriter.new(
202
- name: arg.children[0],
203
- ivar_name: nil,
204
- type: Types::Bases::Any.new(location: nil),
205
- location: nil,
206
- comment: comments[node.first_lineno - 1],
207
- annotations: []
208
- )
209
- end
210
- end
211
- end
212
- end
213
- each_child node do |child|
214
- process child, namespace: namespace, current_module: current_module, comments: comments, singleton: singleton
215
- end
216
-
217
- when :CDECL
218
- type_name = case
219
- when node.children[0].is_a?(Symbol)
220
- ns = if current_module
221
- current_module.name.to_namespace
222
- else
223
- Namespace.empty
224
- end
225
- TypeName.new(name: node.children[0], namespace: ns)
226
- else
227
- name = const_to_name(node.children[0])
228
- if current_module
229
- name.with_prefix current_module.name.to_namespace
230
- else
231
- name
232
- end.relative!
233
- end
234
-
235
- source_decls << AST::Declarations::Constant.new(
236
- name: type_name,
237
- type: node_type(node.children.last),
238
- location: nil,
239
- comment: comments[node.first_lineno - 1]
240
- )
241
- else
242
- each_child node do |child|
243
- process child, namespace: namespace, current_module: current_module, comments: comments, singleton: singleton
244
- end
245
- end
246
- end
247
-
248
- def const_to_name(node)
249
- case node&.type
250
- when :CONST
251
- TypeName.new(name: node.children[0], namespace: Namespace.empty)
252
- when :COLON2
253
- if node.children[0]
254
- namespace = const_to_name(node.children[0]).to_namespace
255
- else
256
- namespace = Namespace.empty
257
- end
258
-
259
- TypeName.new(name: node.children[1], namespace: namespace)
260
- when :COLON3
261
- TypeName.new(name: node.children[0], namespace: Namespace.root)
262
- end
263
- end
264
-
265
- def each_node(nodes)
266
- nodes.each do |child|
267
- if child.is_a?(RubyVM::AbstractSyntaxTree::Node)
268
- yield child
269
- end
270
- end
271
- end
272
-
273
- def each_child(node, &block)
274
- each_node node.children, &block
275
- end
276
-
277
- def function_type_from_body(node)
278
- table_node, args_node, *_ = node.children
279
-
280
- pre_num, _pre_init, opt, _first_post, post_num, _post_init, rest, kw, kwrest, _block = args_node.children
281
-
282
- untyped = Types::Bases::Any.new(location: nil)
283
-
284
- fun = Types::Function.empty(untyped)
285
-
286
- table_node.take(pre_num).each do |name|
287
- fun.required_positionals << Types::Function::Param.new(name: name, type: untyped)
288
- end
289
-
290
- while opt&.type == :OPT_ARG
291
- lvasgn, opt = opt.children
292
- name = lvasgn.children[0]
293
- fun.optional_positionals << Types::Function::Param.new(
294
- name: name,
295
- type: node_type(lvasgn.children[1])
296
- )
297
- end
298
-
299
- if rest
300
- fun = fun.update(rest_positionals: Types::Function::Param.new(name: rest, type: untyped))
301
- end
302
-
303
- table_node.drop(fun.required_positionals.size + fun.optional_positionals.size + (fun.rest_positionals ? 1 : 0)).take(post_num).each do |name|
304
- fun.trailing_positionals << Types::Function::Param.new(name: name, type: untyped)
305
- end
306
-
307
- while kw
308
- lvasgn, kw = kw.children
309
- name, value = lvasgn.children
310
-
311
- case value
312
- when nil, :NODE_SPECIAL_REQUIRED_KEYWORD
313
- fun.required_keywords[name] = Types::Function::Param.new(name: name, type: untyped)
314
- when RubyVM::AbstractSyntaxTree::Node
315
- fun.optional_keywords[name] = Types::Function::Param.new(name: name, type: node_type(value))
316
- else
317
- raise "Unexpected keyword arg value: #{value}"
318
- end
319
- end
320
-
321
- if kwrest && kwrest.children.any?
322
- fun = fun.update(rest_keywords: Types::Function::Param.new(name: kwrest.children[0], type: untyped))
323
- end
324
-
325
- fun
326
- end
327
-
328
- def block_from_body(node)
329
- _, args_node, body_node = node.children
330
-
331
- _pre_num, _pre_init, _opt, _first_post, _post_num, _post_init, _rest, _kw, _kwrest, block = args_node.children
332
-
333
- untyped = Types::Bases::Any.new(location: nil)
334
-
335
- method_block = nil
336
-
337
- if block
338
- method_block = MethodType::Block.new(
339
- required: true,
340
- type: Types::Function.empty(untyped)
341
- )
342
- end
343
-
344
- if body_node
345
- if (yields = any_node?(body_node) {|n| n.type == :YIELD })
346
- method_block = MethodType::Block.new(
347
- required: true,
348
- type: Types::Function.empty(untyped)
349
- )
350
-
351
- yields.each do |yield_node|
352
- array_content = yield_node.children[0]&.children&.compact || []
353
-
354
- positionals, keywords = if keyword_hash?(array_content.last)
355
- [array_content.take(array_content.size - 1), array_content.last]
356
- else
357
- [array_content, nil]
358
- end
359
-
360
- if (diff = positionals.size - method_block.type.required_positionals.size) > 0
361
- diff.times do
362
- method_block.type.required_positionals << Types::Function::Param.new(
363
- type: untyped,
364
- name: nil
365
- )
366
- end
367
- end
368
-
369
- if keywords
370
- keywords.children[0].children.each_slice(2) do |key_node, value_node|
371
- if key_node
372
- key = key_node.children[0]
373
- method_block.type.required_keywords[key] ||=
374
- Types::Function::Param.new(
375
- type: untyped,
376
- name: nil
377
- )
378
- end
379
- end
380
- end
381
- end
382
- end
383
- end
384
-
385
- method_block
386
- end
387
-
388
- def keyword_hash?(node)
389
- if node
390
- if node.type == :HASH
391
- node.children[0].children.compact.each_slice(2).all? {|key, _|
392
- key.type == :LIT && key.children[0].is_a?(Symbol)
393
- }
394
- end
395
- end
396
- end
397
-
398
- def any_node?(node, nodes: [], &block)
399
- if yield(node)
400
- nodes << node
401
- end
402
-
403
- each_child node do |child|
404
- any_node? child, nodes: nodes, &block
405
- end
406
-
407
- nodes.empty? ? nil : nodes
408
- end
409
-
410
- def node_type(node, default: Types::Bases::Any.new(location: nil))
411
- case node.type
412
- when :LIT
413
- case node.children[0]
414
- when Symbol
415
- BuiltinNames::Symbol.instance_type
416
- when Integer
417
- BuiltinNames::Integer.instance_type
418
- when Float
419
- BuiltinNames::Float.instance_type
420
- else
421
- default
422
- end
423
- when :STR, :DSTR
424
- BuiltinNames::String.instance_type
425
- when :NIL
426
- # This type is technical non-sense, but may help practically.
427
- Types::Optional.new(
428
- type: Types::Bases::Any.new(location: nil),
429
- location: nil
430
- )
431
- when :TRUE, :FALSE
432
- Types::Bases::Bool.new(location: nil)
433
- when :ARRAY, :LIST
434
- BuiltinNames::Array.instance_type(default)
435
- when :HASH
436
- BuiltinNames::Hash.instance_type(default, default)
437
- else
438
- default
439
- end
440
- end
441
- end
442
- end
443
- end
444
- end