steep 1.6.0 → 1.7.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (453) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +0 -1
  3. data/CHANGELOG.md +49 -0
  4. data/README.md +18 -0
  5. data/Rakefile +5 -0
  6. data/bin/output_test.rb +1 -0
  7. data/doc/narrowing.md +195 -0
  8. data/doc/shape.md +194 -0
  9. data/guides/src/gem-rbs-collection/gem-rbs-collection.md +7 -24
  10. data/guides/src/getting-started/getting-started.md +10 -11
  11. data/lib/steep/ast/ignore.rb +148 -0
  12. data/lib/steep/ast/types/factory.rb +27 -18
  13. data/lib/steep/ast/types/helper.rb +4 -0
  14. data/lib/steep/ast/types/intersection.rb +7 -0
  15. data/lib/steep/ast/types/proc.rb +14 -9
  16. data/lib/steep/ast/types/record.rb +7 -0
  17. data/lib/steep/ast/types/tuple.rb +7 -0
  18. data/lib/steep/ast/types/union.rb +7 -0
  19. data/lib/steep/cli.rb +6 -1
  20. data/lib/steep/diagnostic/ruby.rb +16 -0
  21. data/lib/steep/drivers/stats.rb +2 -2
  22. data/lib/steep/drivers/utils/driver_helper.rb +22 -11
  23. data/lib/steep/drivers/validate.rb +4 -2
  24. data/lib/steep/expectations.rb +2 -2
  25. data/lib/steep/interface/block.rb +1 -1
  26. data/lib/steep/interface/builder.rb +342 -358
  27. data/lib/steep/interface/function.rb +82 -11
  28. data/lib/steep/interface/method_type.rb +18 -10
  29. data/lib/steep/interface/shape.rb +69 -18
  30. data/lib/steep/interface/substitution.rb +4 -0
  31. data/lib/steep/node_helper.rb +30 -1
  32. data/lib/steep/project/dsl.rb +18 -21
  33. data/lib/steep/project/options.rb +39 -2
  34. data/lib/steep/project/pattern.rb +1 -2
  35. data/lib/steep/project.rb +11 -7
  36. data/lib/steep/rake_task.rb +132 -0
  37. data/lib/steep/server/change_buffer.rb +2 -2
  38. data/lib/steep/server/interaction_worker.rb +67 -11
  39. data/lib/steep/server/lsp_formatter.rb +2 -0
  40. data/lib/steep/server/worker_process.rb +3 -1
  41. data/lib/steep/services/completion_provider.rb +59 -26
  42. data/lib/steep/services/file_loader.rb +15 -19
  43. data/lib/steep/services/signature_help_provider.rb +37 -35
  44. data/lib/steep/services/type_check_service.rb +36 -8
  45. data/lib/steep/signature/validator.rb +185 -133
  46. data/lib/steep/source/ignore_ranges.rb +69 -0
  47. data/lib/steep/source.rb +10 -4
  48. data/lib/steep/subtyping/check.rb +50 -43
  49. data/lib/steep/subtyping/result.rb +6 -0
  50. data/lib/steep/subtyping/variable_variance.rb +3 -3
  51. data/lib/steep/test.rb +9 -0
  52. data/lib/steep/type_construction.rb +205 -309
  53. data/lib/steep/type_inference/block_params.rb +12 -4
  54. data/lib/steep/type_inference/case_when.rb +301 -0
  55. data/lib/steep/type_inference/context.rb +1 -1
  56. data/lib/steep/type_inference/logic_type_interpreter.rb +3 -2
  57. data/lib/steep/type_inference/method_params.rb +16 -0
  58. data/lib/steep/type_inference/send_args.rb +5 -2
  59. data/lib/steep/version.rb +1 -1
  60. data/lib/steep.rb +25 -8
  61. data/steep.gemspec +5 -2
  62. metadata +12 -396
  63. data/.github/dependabot.yml +0 -22
  64. data/.github/workflows/ruby-windows.yml +0 -34
  65. data/.github/workflows/ruby.yml +0 -33
  66. data/.vscode/steep-shared.code-snippets +0 -41
  67. data/Gemfile +0 -14
  68. data/Gemfile.lock +0 -104
  69. data/Gemfile.steep +0 -0
  70. data/gemfile_steep/Gemfile +0 -3
  71. data/gemfile_steep/Gemfile.lock +0 -64
  72. data/rbs_collection.steep.lock.yaml +0 -106
  73. data/rbs_collection.steep.yaml +0 -23
  74. data/sig/shims/bundler.rbs +0 -3
  75. data/sig/shims/concurrent-ruby.rbs +0 -39
  76. data/sig/shims/exception.rbs +0 -4
  77. data/sig/shims/language-server_protocol.rbs +0 -450
  78. data/sig/shims/parser/comment.rbs +0 -33
  79. data/sig/shims/parser/nodes.rbs +0 -252
  80. data/sig/shims/parser/source/map.rbs +0 -146
  81. data/sig/shims/parser/source/range.rbs +0 -237
  82. data/sig/shims/parser.rbs +0 -59
  83. data/sig/shims/string.rbs +0 -4
  84. data/sig/shims/tagged_logging.rbs +0 -6
  85. data/sig/steep/annotation_parser.rbs +0 -60
  86. data/sig/steep/ast/annotation/collection.rbs +0 -78
  87. data/sig/steep/ast/annotation.rbs +0 -121
  88. data/sig/steep/ast/builtin.rbs +0 -69
  89. data/sig/steep/ast/node/type_application.rbs +0 -31
  90. data/sig/steep/ast/node/type_assertion.rbs +0 -32
  91. data/sig/steep/ast/types/any.rbs +0 -29
  92. data/sig/steep/ast/types/boolean.rbs +0 -31
  93. data/sig/steep/ast/types/bot.rbs +0 -29
  94. data/sig/steep/ast/types/class.rbs +0 -33
  95. data/sig/steep/ast/types/factory.rbs +0 -110
  96. data/sig/steep/ast/types/helper.rbs +0 -22
  97. data/sig/steep/ast/types/instance.rbs +0 -33
  98. data/sig/steep/ast/types/intersection.rbs +0 -38
  99. data/sig/steep/ast/types/literal.rbs +0 -35
  100. data/sig/steep/ast/types/logic.rbs +0 -83
  101. data/sig/steep/ast/types/name.rbs +0 -80
  102. data/sig/steep/ast/types/nil.rbs +0 -31
  103. data/sig/steep/ast/types/proc.rbs +0 -53
  104. data/sig/steep/ast/types/record.rbs +0 -37
  105. data/sig/steep/ast/types/self.rbs +0 -33
  106. data/sig/steep/ast/types/top.rbs +0 -29
  107. data/sig/steep/ast/types/tuple.rbs +0 -35
  108. data/sig/steep/ast/types/union.rbs +0 -38
  109. data/sig/steep/ast/types/var.rbs +0 -42
  110. data/sig/steep/ast/types/void.rbs +0 -29
  111. data/sig/steep/ast/types.rbs +0 -16
  112. data/sig/steep/cli.rbs +0 -55
  113. data/sig/steep/diagnostic/deprecated/else_on_exhaustive_case.rbs +0 -13
  114. data/sig/steep/diagnostic/deprecated/unknown_constant_assigned.rbs +0 -15
  115. data/sig/steep/diagnostic/helper.rbs +0 -15
  116. data/sig/steep/diagnostic/lsp_formatter.rbs +0 -36
  117. data/sig/steep/diagnostic/ruby.rbs +0 -695
  118. data/sig/steep/diagnostic/signature.rbs +0 -252
  119. data/sig/steep/drivers/annotations.rbs +0 -17
  120. data/sig/steep/drivers/check.rbs +0 -33
  121. data/sig/steep/drivers/checkfile.rbs +0 -27
  122. data/sig/steep/drivers/diagnostic_printer.rbs +0 -25
  123. data/sig/steep/drivers/init.rbs +0 -19
  124. data/sig/steep/drivers/langserver.rbs +0 -36
  125. data/sig/steep/drivers/print_project.rbs +0 -15
  126. data/sig/steep/drivers/stats.rbs +0 -47
  127. data/sig/steep/drivers/utils/driver_helper.rbs +0 -25
  128. data/sig/steep/drivers/utils/jobs_option.rbs +0 -19
  129. data/sig/steep/drivers/validate.rbs +0 -15
  130. data/sig/steep/drivers/vendor.rbs +0 -19
  131. data/sig/steep/drivers/watch.rbs +0 -27
  132. data/sig/steep/drivers/worker.rbs +0 -29
  133. data/sig/steep/equatable.rbs +0 -11
  134. data/sig/steep/expectations.rbs +0 -72
  135. data/sig/steep/index/rbs_index.rbs +0 -141
  136. data/sig/steep/index/signature_symbol_provider.rbs +0 -41
  137. data/sig/steep/index/source_index.rbs +0 -63
  138. data/sig/steep/interface/block.rbs +0 -41
  139. data/sig/steep/interface/builder.rbs +0 -166
  140. data/sig/steep/interface/function.rbs +0 -265
  141. data/sig/steep/interface/method_type.rbs +0 -105
  142. data/sig/steep/interface/shape.rbs +0 -61
  143. data/sig/steep/interface/substitution.rbs +0 -49
  144. data/sig/steep/interface/type_param.rbs +0 -43
  145. data/sig/steep/method_name.rbs +0 -30
  146. data/sig/steep/module_helper.rbs +0 -16
  147. data/sig/steep/node_helper.rbs +0 -78
  148. data/sig/steep/path_helper.rbs +0 -15
  149. data/sig/steep/project/dsl.rbs +0 -104
  150. data/sig/steep/project/options.rbs +0 -27
  151. data/sig/steep/project/pattern.rbs +0 -47
  152. data/sig/steep/project/target.rbs +0 -25
  153. data/sig/steep/project.rbs +0 -26
  154. data/sig/steep/range_extension.rbs +0 -7
  155. data/sig/steep/server/base_worker.rbs +0 -49
  156. data/sig/steep/server/change_buffer.rbs +0 -36
  157. data/sig/steep/server/delay_queue.rbs +0 -37
  158. data/sig/steep/server/interaction_worker.rbs +0 -80
  159. data/sig/steep/server/lsp_formatter.rbs +0 -63
  160. data/sig/steep/server/master.rbs +0 -299
  161. data/sig/steep/server/type_check_worker.rbs +0 -141
  162. data/sig/steep/server/worker_process.rbs +0 -97
  163. data/sig/steep/services/completion_provider.rbs +0 -251
  164. data/sig/steep/services/content_change.rbs +0 -37
  165. data/sig/steep/services/file_loader.rbs +0 -21
  166. data/sig/steep/services/goto_service.rbs +0 -106
  167. data/sig/steep/services/hover_provider/rbs.rbs +0 -47
  168. data/sig/steep/services/hover_provider/ruby.rbs +0 -127
  169. data/sig/steep/services/hover_provider/singleton_methods.rbs +0 -11
  170. data/sig/steep/services/path_assignment.rbs +0 -21
  171. data/sig/steep/services/signature_help_provider.rbs +0 -49
  172. data/sig/steep/services/signature_service.rbs +0 -156
  173. data/sig/steep/services/stats_calculator.rbs +0 -41
  174. data/sig/steep/services/type_check_service.rbs +0 -107
  175. data/sig/steep/services/type_name_completion.rbs +0 -135
  176. data/sig/steep/signature/validator.rbs +0 -85
  177. data/sig/steep/source.rbs +0 -102
  178. data/sig/steep/subtyping/cache.rbs +0 -17
  179. data/sig/steep/subtyping/check.rbs +0 -129
  180. data/sig/steep/subtyping/constraints.rbs +0 -111
  181. data/sig/steep/subtyping/relation.rbs +0 -63
  182. data/sig/steep/subtyping/result.rbs +0 -175
  183. data/sig/steep/subtyping/variable_variance.rbs +0 -25
  184. data/sig/steep/thread_waiter.rbs +0 -13
  185. data/sig/steep/type_construction.rbs +0 -567
  186. data/sig/steep/type_inference/block_params.rbs +0 -170
  187. data/sig/steep/type_inference/constant_env.rbs +0 -29
  188. data/sig/steep/type_inference/context.rbs +0 -214
  189. data/sig/steep/type_inference/context_array.rbs +0 -38
  190. data/sig/steep/type_inference/logic_type_interpreter.rbs +0 -108
  191. data/sig/steep/type_inference/method_call.rbs +0 -124
  192. data/sig/steep/type_inference/method_params.rbs +0 -127
  193. data/sig/steep/type_inference/multiple_assignment.rbs +0 -76
  194. data/sig/steep/type_inference/send_args.rbs +0 -243
  195. data/sig/steep/type_inference/type_env.rbs +0 -160
  196. data/sig/steep/type_inference/type_env_builder.rbs +0 -81
  197. data/sig/steep/typing.rbs +0 -75
  198. data/sig/steep.rbs +0 -36
  199. data/smoke/alias/Steepfile +0 -6
  200. data/smoke/alias/a.rb +0 -16
  201. data/smoke/alias/a.rbs +0 -10
  202. data/smoke/alias/b.rb +0 -6
  203. data/smoke/alias/c.rb +0 -8
  204. data/smoke/alias/test_expectations.yml +0 -96
  205. data/smoke/and/Steepfile +0 -6
  206. data/smoke/and/a.rb +0 -8
  207. data/smoke/and/test_expectations.yml +0 -29
  208. data/smoke/array/Steepfile +0 -6
  209. data/smoke/array/a.rb +0 -18
  210. data/smoke/array/b.rb +0 -12
  211. data/smoke/array/c.rb +0 -6
  212. data/smoke/array/test_expectations.yml +0 -103
  213. data/smoke/block/Steepfile +0 -6
  214. data/smoke/block/a.rb +0 -10
  215. data/smoke/block/a.rbs +0 -6
  216. data/smoke/block/b.rb +0 -13
  217. data/smoke/block/c.rb +0 -9
  218. data/smoke/block/c.rbs +0 -3
  219. data/smoke/block/d.rb +0 -11
  220. data/smoke/block/e.rb +0 -12
  221. data/smoke/block/e.rbs +0 -4
  222. data/smoke/block/test_expectations.yml +0 -133
  223. data/smoke/case/Steepfile +0 -6
  224. data/smoke/case/a.rb +0 -18
  225. data/smoke/case/test_expectations.yml +0 -47
  226. data/smoke/class/Steepfile +0 -6
  227. data/smoke/class/a.rb +0 -25
  228. data/smoke/class/a.rbs +0 -23
  229. data/smoke/class/b.rb +0 -5
  230. data/smoke/class/c.rb +0 -9
  231. data/smoke/class/f.rb +0 -10
  232. data/smoke/class/g.rb +0 -6
  233. data/smoke/class/h.rb +0 -19
  234. data/smoke/class/h.rbs +0 -6
  235. data/smoke/class/i.rb +0 -14
  236. data/smoke/class/i.rbs +0 -9
  237. data/smoke/class/test_expectations.yml +0 -117
  238. data/smoke/compact/Steepfile +0 -6
  239. data/smoke/compact/a.rb +0 -2
  240. data/smoke/compact/a.rbs +0 -5
  241. data/smoke/compact/b.rb +0 -2
  242. data/smoke/compact/test_expectations.yml +0 -18
  243. data/smoke/const/Steepfile +0 -6
  244. data/smoke/const/a.rb +0 -27
  245. data/smoke/const/b.rb +0 -7
  246. data/smoke/const/b.rbs +0 -5
  247. data/smoke/const/test_expectations.yml +0 -134
  248. data/smoke/diagnostics/Steepfile +0 -6
  249. data/smoke/diagnostics/a.rbs +0 -22
  250. data/smoke/diagnostics/argument_type_mismatch.rb +0 -1
  251. data/smoke/diagnostics/block_body_type_mismatch.rb +0 -1
  252. data/smoke/diagnostics/block_type_mismatch.rb +0 -3
  253. data/smoke/diagnostics/break_type_mismatch.rb +0 -1
  254. data/smoke/diagnostics/different_method_parameter_kind.rb +0 -9
  255. data/smoke/diagnostics/else_on_exhaustive_case.rb +0 -12
  256. data/smoke/diagnostics/incompatible_annotation.rb +0 -6
  257. data/smoke/diagnostics/incompatible_argument.rb +0 -1
  258. data/smoke/diagnostics/incompatible_assignment.rb +0 -8
  259. data/smoke/diagnostics/method_arity_mismatch.rb +0 -11
  260. data/smoke/diagnostics/method_body_type_mismatch.rb +0 -6
  261. data/smoke/diagnostics/method_definition_missing.rb +0 -2
  262. data/smoke/diagnostics/method_parameter_mismatch.rb +0 -10
  263. data/smoke/diagnostics/method_return_type_annotation_mismatch.rb +0 -7
  264. data/smoke/diagnostics/missing_keyword.rb +0 -1
  265. data/smoke/diagnostics/no_method.rb +0 -1
  266. data/smoke/diagnostics/proc_type_expected.rb +0 -3
  267. data/smoke/diagnostics/required_block_missing.rb +0 -1
  268. data/smoke/diagnostics/return_type_mismatch.rb +0 -6
  269. data/smoke/diagnostics/test_expectations.yml +0 -591
  270. data/smoke/diagnostics/unexpected_block_given.rb +0 -1
  271. data/smoke/diagnostics/unexpected_dynamic_method.rb +0 -3
  272. data/smoke/diagnostics/unexpected_jump.rb +0 -4
  273. data/smoke/diagnostics/unexpected_jump_value.rb +0 -3
  274. data/smoke/diagnostics/unexpected_keyword.rb +0 -1
  275. data/smoke/diagnostics/unexpected_splat.rb +0 -1
  276. data/smoke/diagnostics/unexpected_yield.rb +0 -6
  277. data/smoke/diagnostics/unknown_constant_assigned.rb +0 -7
  278. data/smoke/diagnostics/unresolved_overloading.rb +0 -1
  279. data/smoke/diagnostics/unsupported_syntax.rb +0 -2
  280. data/smoke/diagnostics-rbs/Steepfile +0 -8
  281. data/smoke/diagnostics-rbs/duplicated-method-definition.rbs +0 -20
  282. data/smoke/diagnostics-rbs/generic-parameter-mismatch.rbs +0 -7
  283. data/smoke/diagnostics-rbs/inherit-module.rbs +0 -2
  284. data/smoke/diagnostics-rbs/invalid-method-overload.rbs +0 -3
  285. data/smoke/diagnostics-rbs/invalid-type-application.rbs +0 -7
  286. data/smoke/diagnostics-rbs/invalid_variance_annotation.rbs +0 -3
  287. data/smoke/diagnostics-rbs/mixin-class-error.rbs +0 -6
  288. data/smoke/diagnostics-rbs/nonregular-type-alias.rbs +0 -3
  289. data/smoke/diagnostics-rbs/recursive-alias.rbs +0 -5
  290. data/smoke/diagnostics-rbs/recursive-class.rbs +0 -8
  291. data/smoke/diagnostics-rbs/recursive-type-alias.rbs +0 -3
  292. data/smoke/diagnostics-rbs/superclass-mismatch.rbs +0 -7
  293. data/smoke/diagnostics-rbs/test_expectations.yml +0 -300
  294. data/smoke/diagnostics-rbs/unknown-method-alias.rbs +0 -3
  295. data/smoke/diagnostics-rbs/unknown-type-name-2.rbs +0 -5
  296. data/smoke/diagnostics-rbs/unknown-type-name.rbs +0 -13
  297. data/smoke/diagnostics-rbs-duplicated/Steepfile +0 -6
  298. data/smoke/diagnostics-rbs-duplicated/a.rbs +0 -5
  299. data/smoke/diagnostics-rbs-duplicated/test_expectations.yml +0 -13
  300. data/smoke/diagnostics-ruby-unsat/Steepfile +0 -6
  301. data/smoke/diagnostics-ruby-unsat/a.rbs +0 -3
  302. data/smoke/diagnostics-ruby-unsat/test_expectations.yml +0 -27
  303. data/smoke/diagnostics-ruby-unsat/unsatisfiable_constraint.rb +0 -6
  304. data/smoke/dstr/Steepfile +0 -6
  305. data/smoke/dstr/a.rb +0 -5
  306. data/smoke/dstr/test_expectations.yml +0 -13
  307. data/smoke/ensure/Steepfile +0 -6
  308. data/smoke/ensure/a.rb +0 -18
  309. data/smoke/ensure/test_expectations.yml +0 -62
  310. data/smoke/enumerator/Steepfile +0 -6
  311. data/smoke/enumerator/a.rb +0 -6
  312. data/smoke/enumerator/b.rb +0 -17
  313. data/smoke/enumerator/test_expectations.yml +0 -47
  314. data/smoke/extension/Steepfile +0 -6
  315. data/smoke/extension/a.rb +0 -10
  316. data/smoke/extension/a.rbs +0 -13
  317. data/smoke/extension/b.rb +0 -10
  318. data/smoke/extension/c.rb +0 -9
  319. data/smoke/extension/d.rb +0 -2
  320. data/smoke/extension/e.rb +0 -2
  321. data/smoke/extension/e.rbs +0 -7
  322. data/smoke/extension/f.rb +0 -2
  323. data/smoke/extension/f.rbs +0 -3
  324. data/smoke/extension/test_expectations.yml +0 -73
  325. data/smoke/hash/Steepfile +0 -6
  326. data/smoke/hash/a.rb +0 -17
  327. data/smoke/hash/a.rbs +0 -8
  328. data/smoke/hash/b.rb +0 -6
  329. data/smoke/hash/c.rb +0 -15
  330. data/smoke/hash/d.rb +0 -5
  331. data/smoke/hash/e.rb +0 -1
  332. data/smoke/hash/e.rbs +0 -3
  333. data/smoke/hash/f.rb +0 -11
  334. data/smoke/hash/test_expectations.yml +0 -81
  335. data/smoke/hello/Steepfile +0 -6
  336. data/smoke/hello/hello.rb +0 -11
  337. data/smoke/hello/hello.rbs +0 -7
  338. data/smoke/hello/test_expectations.yml +0 -25
  339. data/smoke/if/Steepfile +0 -6
  340. data/smoke/if/a.rb +0 -20
  341. data/smoke/if/test_expectations.yml +0 -34
  342. data/smoke/implements/Steepfile +0 -6
  343. data/smoke/implements/a.rb +0 -12
  344. data/smoke/implements/a.rbs +0 -6
  345. data/smoke/implements/b.rb +0 -13
  346. data/smoke/implements/b.rbs +0 -12
  347. data/smoke/implements/test_expectations.yml +0 -23
  348. data/smoke/initialize/Steepfile +0 -6
  349. data/smoke/initialize/a.rb +0 -12
  350. data/smoke/initialize/a.rbs +0 -3
  351. data/smoke/initialize/test_expectations.yml +0 -1
  352. data/smoke/integer/Steepfile +0 -6
  353. data/smoke/integer/a.rb +0 -26
  354. data/smoke/integer/test_expectations.yml +0 -110
  355. data/smoke/interface/Steepfile +0 -6
  356. data/smoke/interface/a.rb +0 -12
  357. data/smoke/interface/a.rbs +0 -12
  358. data/smoke/interface/test_expectations.yml +0 -23
  359. data/smoke/kwbegin/Steepfile +0 -6
  360. data/smoke/kwbegin/a.rb +0 -7
  361. data/smoke/kwbegin/test_expectations.yml +0 -17
  362. data/smoke/lambda/Steepfile +0 -6
  363. data/smoke/lambda/a.rb +0 -10
  364. data/smoke/lambda/test_expectations.yml +0 -17
  365. data/smoke/literal/Steepfile +0 -6
  366. data/smoke/literal/a.rb +0 -11
  367. data/smoke/literal/b.rb +0 -7
  368. data/smoke/literal/literal_methods.rbs +0 -4
  369. data/smoke/literal/test_expectations.yml +0 -106
  370. data/smoke/map/Steepfile +0 -6
  371. data/smoke/map/a.rb +0 -5
  372. data/smoke/map/test_expectations.yml +0 -1
  373. data/smoke/method/Steepfile +0 -6
  374. data/smoke/method/a.rb +0 -21
  375. data/smoke/method/a.rbs +0 -4
  376. data/smoke/method/b.rb +0 -25
  377. data/smoke/method/c.rb +0 -5
  378. data/smoke/method/d.rb +0 -1
  379. data/smoke/method/d.rbs +0 -3
  380. data/smoke/method/test_expectations.yml +0 -121
  381. data/smoke/module/Steepfile +0 -6
  382. data/smoke/module/a.rb +0 -19
  383. data/smoke/module/a.rbs +0 -16
  384. data/smoke/module/b.rb +0 -6
  385. data/smoke/module/c.rb +0 -22
  386. data/smoke/module/d.rb +0 -4
  387. data/smoke/module/e.rb +0 -13
  388. data/smoke/module/f.rb +0 -11
  389. data/smoke/module/test_expectations.yml +0 -75
  390. data/smoke/regexp/Steepfile +0 -6
  391. data/smoke/regexp/a.rb +0 -109
  392. data/smoke/regexp/b.rb +0 -79
  393. data/smoke/regexp/test_expectations.yml +0 -615
  394. data/smoke/regression/Steepfile +0 -6
  395. data/smoke/regression/array.rb +0 -7
  396. data/smoke/regression/block_param_split.rb +0 -7
  397. data/smoke/regression/block_param_split.rbs +0 -3
  398. data/smoke/regression/empty_yield.rb +0 -5
  399. data/smoke/regression/empty_yield.rbs +0 -3
  400. data/smoke/regression/enumerator_product.rb +0 -1
  401. data/smoke/regression/fun.rb +0 -8
  402. data/smoke/regression/fun.rbs +0 -4
  403. data/smoke/regression/hash.rb +0 -7
  404. data/smoke/regression/hello world.rb +0 -1
  405. data/smoke/regression/issue_328.rb +0 -1
  406. data/smoke/regression/issue_328.rbs +0 -0
  407. data/smoke/regression/issue_332.rb +0 -11
  408. data/smoke/regression/issue_332.rbs +0 -19
  409. data/smoke/regression/issue_372.rb +0 -8
  410. data/smoke/regression/issue_372.rbs +0 -4
  411. data/smoke/regression/lambda.rb +0 -3
  412. data/smoke/regression/masgn.rb +0 -4
  413. data/smoke/regression/poly_new.rb +0 -2
  414. data/smoke/regression/poly_new.rbs +0 -4
  415. data/smoke/regression/range.rb +0 -5
  416. data/smoke/regression/set_divide.rb +0 -12
  417. data/smoke/regression/test_expectations.yml +0 -120
  418. data/smoke/regression/thread.rb +0 -7
  419. data/smoke/rescue/Steepfile +0 -6
  420. data/smoke/rescue/a.rb +0 -48
  421. data/smoke/rescue/test_expectations.yml +0 -79
  422. data/smoke/self/Steepfile +0 -6
  423. data/smoke/self/a.rb +0 -21
  424. data/smoke/self/a.rbs +0 -4
  425. data/smoke/self/test_expectations.yml +0 -23
  426. data/smoke/skip/Steepfile +0 -6
  427. data/smoke/skip/skip.rb +0 -13
  428. data/smoke/skip/test_expectations.yml +0 -23
  429. data/smoke/stdout/Steepfile +0 -6
  430. data/smoke/stdout/a.rb +0 -8
  431. data/smoke/stdout/a.rbs +0 -7
  432. data/smoke/stdout/test_expectations.yml +0 -1
  433. data/smoke/super/Steepfile +0 -6
  434. data/smoke/super/a.rb +0 -30
  435. data/smoke/super/a.rbs +0 -10
  436. data/smoke/super/test_expectations.yml +0 -69
  437. data/smoke/toplevel/Steepfile +0 -6
  438. data/smoke/toplevel/a.rb +0 -3
  439. data/smoke/toplevel/a.rbs +0 -3
  440. data/smoke/toplevel/test_expectations.yml +0 -15
  441. data/smoke/tsort/Steepfile +0 -7
  442. data/smoke/tsort/a.rb +0 -12
  443. data/smoke/tsort/test_expectations.yml +0 -1
  444. data/smoke/type_case/Steepfile +0 -6
  445. data/smoke/type_case/a.rb +0 -24
  446. data/smoke/type_case/test_expectations.yml +0 -58
  447. data/smoke/unexpected/Steepfile +0 -6
  448. data/smoke/unexpected/test_expectations.yml +0 -13
  449. data/smoke/unexpected/unexpected.rbs +0 -3
  450. data/smoke/yield/Steepfile +0 -6
  451. data/smoke/yield/a.rb +0 -15
  452. data/smoke/yield/b.rb +0 -6
  453. data/smoke/yield/test_expectations.yml +0 -88
@@ -7,18 +7,22 @@ module Steep
7
7
  # @implements Item
8
8
 
9
9
  def parameters
10
- arguments = [] #: Array[String]
11
- arguments.push(*method_type.type.required_positionals.map(&:to_s))
12
- arguments.push(*method_type.type.optional_positionals.map {|p| "?#{p}"})
13
- arguments.push("*#{self.method_type.type.rest_positionals}") if method_type.type.rest_positionals
14
- arguments.push(*method_type.type.trailing_positionals.map(&:to_s))
15
- arguments.push(*method_type.type.required_keywords.map {|name, param| "#{name}: #{param}" })
16
- arguments.push(*method_type.type.optional_keywords.map {|name, param| "?#{name}: #{param}" })
17
- arguments.push("**#{method_type.type.rest_keywords}") if method_type.type.rest_keywords
18
- arguments
10
+ if method_type.type.is_a?(RBS::Types::Function)
11
+ arguments = [] #: Array[String]
12
+ arguments.push(*method_type.type.required_positionals.map(&:to_s))
13
+ arguments.push(*method_type.type.optional_positionals.map {|p| "?#{p}"})
14
+ arguments.push("*#{self.method_type.type.rest_positionals}") if method_type.type.rest_positionals
15
+ arguments.push(*method_type.type.trailing_positionals.map(&:to_s))
16
+ arguments.push(*method_type.type.required_keywords.map {|name, param| "#{name}: #{param}" })
17
+ arguments.push(*method_type.type.optional_keywords.map {|name, param| "?#{name}: #{param}" })
18
+ arguments.push("**#{method_type.type.rest_keywords}") if method_type.type.rest_keywords
19
+ arguments
20
+ end
19
21
  end
20
22
  end
21
23
 
24
+ include NodeHelper
25
+
22
26
  attr_reader :source, :path, :subtyping, :typing, :buffer
23
27
 
24
28
  def env
@@ -55,7 +59,7 @@ module Steep
55
59
  if begin_loc.end_pos <= pos && pos <= end_loc.begin_pos
56
60
  # Given position is between open/close parens of args of send node
57
61
 
58
- if parent && (parent.type == :block || parent.type == :numblock)
62
+ if parent && (parent.type == :block || parent.type == :numblock) && node.equal?(parent.children[0])
59
63
  send_node = parent
60
64
  else
61
65
  send_node = node
@@ -76,7 +80,8 @@ module Steep
76
80
  end
77
81
 
78
82
  def last_argument_nodes_for(argument_nodes:, line:, column:)
79
- return unless argument_nodes.last.children[2] # No arguments
83
+ last = argument_nodes.last or raise
84
+ return unless last.children[2] # No arguments
80
85
  return argument_nodes if argument_nodes.size > 1 # Cursor is on the last argument
81
86
 
82
87
  pos = buffer.loc_to_pos([line, column])
@@ -102,16 +107,11 @@ module Steep
102
107
  case call
103
108
  when MethodCall::Typed, MethodCall::Error
104
109
  type = call.receiver_type
105
- if type.is_a?(AST::Types::Self)
106
- type = context.self_type
107
- end
110
+ config = Interface::Builder::Config.new(self_type: context.self_type, variable_bounds: context.variable_context.upper_bounds)
111
+
112
+ if shape = subtyping.builder.shape(type, config)
113
+ shape = shape.public_shape if private_send?(node)
108
114
 
109
- shape = subtyping.builder.shape(
110
- type,
111
- public_only: !node.children[0].nil?,
112
- config: Interface::Builder::Config.new(self_type: type, class_type: nil, instance_type: nil, variable_bounds: {})
113
- )
114
- if shape
115
115
  if method = shape.methods[call.method_name]
116
116
  method.method_types.each.with_index do |method_type, i|
117
117
  defn = method_type.method_decls.to_a[0]&.method_def
@@ -150,9 +150,9 @@ module Steep
150
150
  case last_argument_nodes[-3].type
151
151
  when :pair
152
152
  argname = last_argument_nodes[-3].children.first.children.first
153
- if method_type.type.required_keywords[argname]
153
+ if method_type.type.required_keywords.key?(argname)
154
154
  positionals + method_type.type.required_keywords.keys.index(argname).to_i + 1
155
- elsif method_type.type.optional_keywords[argname]
155
+ elsif method_type.type.optional_keywords.key?(argname)
156
156
  positionals + method_type.type.required_keywords.size + method_type.type.optional_keywords.keys.index(argname).to_i + 1
157
157
  elsif method_type.type.rest_keywords
158
158
  positionals + method_type.type.required_keywords.size + method_type.type.optional_keywords.size
@@ -161,7 +161,7 @@ module Steep
161
161
  positionals + method_type.type.required_keywords.size + method_type.type.optional_keywords.size if method_type.type.rest_keywords
162
162
  end
163
163
  else
164
- pos = node.children[2...].index { |c| c.location == last_argument_nodes[-2].location }.to_i
164
+ pos = (node.children[2...] || raise).index { |c| c.location == last_argument_nodes[-2].location }.to_i
165
165
  if method_type.type.rest_positionals
166
166
  [pos + 1, positionals - 1].min
167
167
  else
@@ -174,21 +174,23 @@ module Steep
174
174
  when :splat
175
175
  method_type.type.required_positionals.size + method_type.type.optional_positionals.size if method_type.type.rest_positionals
176
176
  when :kwargs
177
- case argument_nodes[-3].type
178
- when :pair
179
- argname = argument_nodes[-3].children.first.children.first
180
- if method_type.type.required_keywords[argname]
181
- positionals + method_type.type.required_keywords.keys.index(argname).to_i
182
- elsif method_type.type.optional_keywords[argname]
183
- positionals + method_type.type.required_keywords.size + method_type.type.optional_keywords.keys.index(argname).to_i
184
- elsif method_type.type.rest_keywords
185
- positionals + method_type.type.required_keywords.size + method_type.type.optional_keywords.size
177
+ if argument_nodes[-3]
178
+ case argument_nodes[-3].type
179
+ when :pair
180
+ argname = argument_nodes[-3].children.first.children.first
181
+ if method_type.type.required_keywords.key?(argname)
182
+ positionals + method_type.type.required_keywords.keys.index(argname).to_i
183
+ elsif method_type.type.optional_keywords.key?(argname)
184
+ positionals + method_type.type.required_keywords.size + method_type.type.optional_keywords.keys.index(argname).to_i
185
+ elsif method_type.type.rest_keywords
186
+ positionals + method_type.type.required_keywords.size + method_type.type.optional_keywords.size
187
+ end
188
+ when :kwsplat
189
+ positionals + method_type.type.required_keywords.size + method_type.type.optional_keywords.size if method_type.type.rest_keywords
186
190
  end
187
- when :kwsplat
188
- positionals + method_type.type.required_keywords.size + method_type.type.optional_keywords.size if method_type.type.rest_keywords
189
191
  end
190
192
  else
191
- pos = node.children[2...].index { |c| c.location == argument_nodes[-2].location }.to_i
193
+ pos = (node.children[2...] || raise).index { |c| c.location == argument_nodes[-2].location }.to_i
192
194
  [pos, positionals - 1].min
193
195
  end
194
196
  end
@@ -13,25 +13,27 @@ module Steep
13
13
  attr_reader :node
14
14
  attr_reader :typing
15
15
  attr_reader :errors
16
+ attr_reader :ignores
16
17
 
17
- def initialize(path:, node:, content:, typing:, errors:)
18
+ def initialize(path:, node:, content:, typing:, ignores:, errors:)
18
19
  @path = path
19
20
  @node = node
20
21
  @content = content
21
22
  @typing = typing
23
+ @ignores = ignores
22
24
  @errors = errors
23
25
  end
24
26
 
25
27
  def self.with_syntax_error(path:, content:, error:)
26
- new(path: path, node: false, content: content, errors: [error], typing: nil)
28
+ new(path: path, node: false, content: content, errors: [error], typing: nil, ignores: nil)
27
29
  end
28
30
 
29
- def self.with_typing(path:, content:, typing:, node:)
30
- new(path: path, node: node, content: content, errors: nil, typing: typing)
31
+ def self.with_typing(path:, content:, typing:, node:, ignores:)
32
+ new(path: path, node: node, content: content, errors: nil, typing: typing, ignores: ignores)
31
33
  end
32
34
 
33
35
  def self.no_data(path:, content:)
34
- new(path: path, content: content, node: false, errors: nil, typing: nil)
36
+ new(path: path, content: content, node: false, errors: nil, typing: nil, ignores: nil)
35
37
  end
36
38
 
37
39
  def update_content(content)
@@ -40,12 +42,37 @@ module Steep
40
42
  content: content,
41
43
  node: node,
42
44
  errors: errors,
43
- typing: typing
45
+ typing: typing,
46
+ ignores: ignores
44
47
  )
45
48
  end
46
49
 
47
50
  def diagnostics
48
- errors || typing&.errors || []
51
+ case
52
+ when errors
53
+ errors
54
+ when typing && ignores
55
+ errors = [] #: Array[Diagnostic::Ruby::Base]
56
+
57
+ errors.concat(
58
+ typing.errors.delete_if do |diagnostic|
59
+ case diagnostic.location
60
+ when ::Parser::Source::Range
61
+ ignores.ignore?(diagnostic.location.first_line, diagnostic.location.last_line, diagnostic.diagnostic_code)
62
+ when RBS::Location
63
+ ignores.ignore?(diagnostic.location.start_line, diagnostic.location.end_line, diagnostic.diagnostic_code)
64
+ end
65
+ end
66
+ )
67
+
68
+ ignores.error_ignores.each do |ignore|
69
+ errors << Diagnostic::Ruby::InvalidIgnoreComment.new(comment: ignore.comment)
70
+ end
71
+
72
+ errors
73
+ else
74
+ []
75
+ end
49
76
  end
50
77
  end
51
78
 
@@ -327,7 +354,8 @@ module Steep
327
354
  Steep.logger.tagged "#type_check_file(#{path}@#{target.name})" do
328
355
  source = Source.parse(text, path: path, factory: subtyping.factory)
329
356
  typing = TypeCheckService.type_check(source: source, subtyping: subtyping, constant_resolver: yield)
330
- SourceFile.with_typing(path: path, content: text, node: source.node, typing: typing)
357
+ ignores = Source::IgnoreRanges.new(ignores: source.ignores)
358
+ SourceFile.with_typing(path: path, content: text, node: source.node, typing: typing, ignores: ignores)
331
359
  end
332
360
  rescue AnnotationParser::SyntaxError => exn
333
361
  error = Diagnostic::Ruby::SyntaxError.new(message: exn.message, location: exn.location)
@@ -5,10 +5,23 @@ module Steep
5
5
  Declarations = RBS::AST::Declarations
6
6
 
7
7
  attr_reader :checker
8
+ attr_reader :context
8
9
 
9
10
  def initialize(checker:)
10
11
  @checker = checker
11
12
  @errors = []
13
+ @context = []
14
+ end
15
+
16
+ def push_context(self_type: latest_context[0], class_type: latest_context[1], instance_type: latest_context[2])
17
+ @context.push([self_type, class_type, instance_type])
18
+ yield
19
+ ensure
20
+ @context.pop
21
+ end
22
+
23
+ def latest_context
24
+ context.last || [nil, nil, nil]
12
25
  end
13
26
 
14
27
  def has_error?
@@ -72,11 +85,13 @@ module Steep
72
85
 
73
86
  constraints = Subtyping::Constraints.empty
74
87
 
88
+ self_type, class_type, instance_type = latest_context
89
+
75
90
  checker.check(
76
91
  Subtyping::Relation.new(sub_type: arg_type, super_type: upper_bound_type),
77
- self_type: AST::Types::Self.instance,
78
- class_type: nil,
79
- instance_type: nil,
92
+ self_type: self_type,
93
+ class_type: class_type,
94
+ instance_type: instance_type,
80
95
  constraints: constraints
81
96
  ).else do |result|
82
97
  @errors << Diagnostic::Signature::UnsatisfiableTypeApplication.new(
@@ -134,7 +149,7 @@ module Steep
134
149
  end
135
150
 
136
151
  def validate_type(type)
137
- Steep.logger.debug "#{Location.to_string type.location}: Validating #{type}..."
152
+ Steep.logger.debug { "#{Location.to_string type.location}: Validating #{type}..." }
138
153
 
139
154
  validator.validate_type(type, context: nil)
140
155
  validate_type_application(type)
@@ -236,25 +251,113 @@ module Steep
236
251
  end
237
252
  end
238
253
 
239
- def validate_one_class_decl(name)
254
+ def validate_one_class_decl(name, entry)
240
255
  rescue_validation_errors(name) do
241
256
  Steep.logger.debug { "Validating class definition `#{name}`..." }
242
257
 
258
+ class_type = AST::Types::Name::Singleton.new(name: name, location: nil)
259
+ instance_type = AST::Types::Name::Instance.new(
260
+ name: name,
261
+ args: entry.type_params.map { AST::Types::Any.new(location: nil) },
262
+ location: nil
263
+ )
264
+
243
265
  Steep.logger.tagged "#{name}" do
244
266
  builder.build_instance(name).tap do |definition|
245
267
  upper_bounds = definition.type_params_decl.each.with_object({}) do |param, bounds|
246
268
  bounds[param.name] = factory.type_opt(param.upper_bound)
247
269
  end
248
270
 
249
- checker.push_variable_bounds(upper_bounds) do
271
+ self_type = AST::Types::Name::Instance.new(
272
+ name: name,
273
+ args: entry.type_params.map { AST::Types::Var.new(name: _1.name) },
274
+ location: nil
275
+ )
276
+
277
+ push_context(self_type: self_type, class_type: class_type, instance_type: instance_type) do
278
+ checker.push_variable_bounds(upper_bounds) do
279
+ definition.instance_variables.each do |name, var|
280
+ if parent = var.parent_variable
281
+ var_type = checker.factory.type(var.type)
282
+ parent_type = checker.factory.type(parent.type)
283
+
284
+ relation = Subtyping::Relation.new(sub_type: var_type, super_type: parent_type)
285
+ result1 = checker.check(relation, self_type: nil, instance_type: nil, class_type: nil, constraints: Subtyping::Constraints.empty)
286
+ result2 = checker.check(relation.flip, self_type: nil, instance_type: nil, class_type: nil, constraints: Subtyping::Constraints.empty)
287
+
288
+ unless result1.success? and result2.success?
289
+ @errors << Diagnostic::Signature::InstanceVariableTypeError.new(
290
+ name: name,
291
+ location: var.type.location,
292
+ var_type: var_type,
293
+ parent_type: parent_type
294
+ )
295
+ end
296
+ end
297
+ end
298
+
299
+ ancestors = builder.ancestor_builder.one_instance_ancestors(name)
300
+ mixin_constraints(definition, ancestors.included_modules || raise, immediate_self_types: ancestors.self_types).each do |relation, ancestor|
301
+ checker.check(
302
+ relation,
303
+ self_type: AST::Types::Self.instance,
304
+ instance_type: AST::Types::Instance.instance,
305
+ class_type: AST::Types::Class.instance,
306
+ constraints: Subtyping::Constraints.empty
307
+ ).else do
308
+ raise if ancestor.source.is_a?(Symbol)
309
+
310
+ @errors << Diagnostic::Signature::ModuleSelfTypeError.new(
311
+ name: name,
312
+ location: ancestor.source&.location || raise,
313
+ ancestor: ancestor,
314
+ relation: relation
315
+ )
316
+ end
317
+ end
318
+
319
+ ancestors.each_ancestor do |ancestor|
320
+ case ancestor
321
+ when RBS::Definition::Ancestor::Instance
322
+ validate_ancestor_application(name, ancestor)
323
+ end
324
+ end
325
+
326
+ validate_definition_type(definition)
327
+ end
328
+ end
329
+ end
330
+
331
+ builder.build_singleton(name).tap do |definition|
332
+ entry =
333
+ case definition.entry
334
+ when RBS::Environment::ClassEntry, RBS::Environment::ModuleEntry
335
+ definition.entry
336
+ else
337
+ raise
338
+ end
339
+
340
+ push_context(self_type: class_type, class_type: class_type, instance_type: instance_type) do
250
341
  definition.instance_variables.each do |name, var|
251
342
  if parent = var.parent_variable
252
343
  var_type = checker.factory.type(var.type)
253
344
  parent_type = checker.factory.type(parent.type)
254
345
 
255
346
  relation = Subtyping::Relation.new(sub_type: var_type, super_type: parent_type)
256
- result1 = checker.check(relation, self_type: nil, instance_type: nil, class_type: nil, constraints: Subtyping::Constraints.empty)
257
- result2 = checker.check(relation.flip, self_type: nil, instance_type: nil, class_type: nil, constraints: Subtyping::Constraints.empty)
347
+ result1 = checker.check(
348
+ relation,
349
+ self_type: AST::Types::Self.instance,
350
+ instance_type: AST::Types::Instance.instance,
351
+ class_type: AST::Types::Class.instance,
352
+ constraints: Subtyping::Constraints.empty
353
+ )
354
+ result2 = checker.check(
355
+ relation.flip,
356
+ self_type: AST::Types::Self.instance,
357
+ instance_type: AST::Types::Instance.instance,
358
+ class_type: AST::Types::Class.instance,
359
+ constraints: Subtyping::Constraints.empty
360
+ )
258
361
 
259
362
  unless result1.success? and result2.success?
260
363
  @errors << Diagnostic::Signature::InstanceVariableTypeError.new(
@@ -267,11 +370,32 @@ module Steep
267
370
  end
268
371
  end
269
372
 
270
- ancestors = builder.ancestor_builder.one_instance_ancestors(name)
271
- mixin_constraints(definition, ancestors.included_modules || raise, immediate_self_types: ancestors.self_types).each do |relation, ancestor|
373
+ definition.class_variables.each do |name, var|
374
+ if var.declared_in == definition.type_name
375
+ if (parent = var.parent_variable) && var.declared_in != parent.declared_in
376
+ class_var = entry.decls.flat_map {|decl| decl.decl.members }.find do |member|
377
+ member.is_a?(RBS::AST::Members::ClassVariable) && member.name == name
378
+ end
379
+
380
+ if class_var
381
+ loc = class_var.location #: RBS::Location[untyped, untyped]?
382
+ @errors << Diagnostic::Signature::ClassVariableDuplicationError.new(
383
+ class_name: definition.type_name,
384
+ other_class_name: parent.declared_in,
385
+ variable_name: name,
386
+ location: loc&.[](:name) || raise
387
+ )
388
+ end
389
+ end
390
+ end
391
+ end
392
+
393
+ ancestors = builder.ancestor_builder.one_singleton_ancestors(name)
394
+ ancestors.extended_modules or raise
395
+ mixin_constraints(definition, ancestors.extended_modules, immediate_self_types: ancestors.self_types).each do |relation, ancestor|
272
396
  checker.check(
273
397
  relation,
274
- self_type: AST::Types::Self.instance,
398
+ self_type: AST::Types::Self.instance ,
275
399
  instance_type: AST::Types::Instance.instance,
276
400
  class_type: AST::Types::Class.instance,
277
401
  constraints: Subtyping::Constraints.empty
@@ -286,7 +410,6 @@ module Steep
286
410
  )
287
411
  end
288
412
  end
289
-
290
413
  ancestors.each_ancestor do |ancestor|
291
414
  case ancestor
292
415
  when RBS::Definition::Ancestor::Instance
@@ -297,97 +420,6 @@ module Steep
297
420
  validate_definition_type(definition)
298
421
  end
299
422
  end
300
-
301
- builder.build_singleton(name).tap do |definition|
302
- entry =
303
- case definition.entry
304
- when RBS::Environment::ClassEntry, RBS::Environment::ModuleEntry
305
- definition.entry
306
- else
307
- raise
308
- end
309
-
310
- definition.instance_variables.each do |name, var|
311
- if parent = var.parent_variable
312
- var_type = checker.factory.type(var.type)
313
- parent_type = checker.factory.type(parent.type)
314
-
315
- relation = Subtyping::Relation.new(sub_type: var_type, super_type: parent_type)
316
- result1 = checker.check(
317
- relation,
318
- self_type: AST::Types::Self.instance,
319
- instance_type: AST::Types::Instance.instance,
320
- class_type: AST::Types::Class.instance,
321
- constraints: Subtyping::Constraints.empty
322
- )
323
- result2 = checker.check(
324
- relation.flip,
325
- self_type: AST::Types::Self.instance,
326
- instance_type: AST::Types::Instance.instance,
327
- class_type: AST::Types::Class.instance,
328
- constraints: Subtyping::Constraints.empty
329
- )
330
-
331
- unless result1.success? and result2.success?
332
- @errors << Diagnostic::Signature::InstanceVariableTypeError.new(
333
- name: name,
334
- location: var.type.location,
335
- var_type: var_type,
336
- parent_type: parent_type
337
- )
338
- end
339
- end
340
- end
341
-
342
- definition.class_variables.each do |name, var|
343
- if var.declared_in == definition.type_name
344
- if (parent = var.parent_variable) && var.declared_in != parent.declared_in
345
- class_var = entry.decls.flat_map {|decl| decl.decl.members }.find do |member|
346
- member.is_a?(RBS::AST::Members::ClassVariable) && member.name == name
347
- end
348
-
349
- if class_var
350
- loc = class_var.location #: RBS::Location[untyped, untyped]?
351
- @errors << Diagnostic::Signature::ClassVariableDuplicationError.new(
352
- class_name: definition.type_name,
353
- other_class_name: parent.declared_in,
354
- variable_name: name,
355
- location: loc&.[](:name) || raise
356
- )
357
- end
358
- end
359
- end
360
- end
361
-
362
- ancestors = builder.ancestor_builder.one_singleton_ancestors(name)
363
- ancestors.extended_modules or raise
364
- mixin_constraints(definition, ancestors.extended_modules, immediate_self_types: ancestors.self_types).each do |relation, ancestor|
365
- checker.check(
366
- relation,
367
- self_type: AST::Types::Self.instance ,
368
- instance_type: AST::Types::Instance.instance,
369
- class_type: AST::Types::Class.instance,
370
- constraints: Subtyping::Constraints.empty
371
- ).else do
372
- raise if ancestor.source.is_a?(Symbol)
373
-
374
- @errors << Diagnostic::Signature::ModuleSelfTypeError.new(
375
- name: name,
376
- location: ancestor.source&.location || raise,
377
- ancestor: ancestor,
378
- relation: relation
379
- )
380
- end
381
- end
382
- ancestors.each_ancestor do |ancestor|
383
- case ancestor
384
- when RBS::Definition::Ancestor::Instance
385
- validate_ancestor_application(name, ancestor)
386
- end
387
- end
388
-
389
- validate_definition_type(definition)
390
- end
391
423
  end
392
424
  end
393
425
  end
@@ -397,7 +429,7 @@ module Steep
397
429
 
398
430
  case entry
399
431
  when RBS::Environment::ClassEntry, RBS::Environment::ModuleEntry
400
- validate_one_class_decl(name)
432
+ validate_one_class_decl(name, entry)
401
433
  when RBS::Environment::ClassAliasEntry, RBS::Environment::ModuleAliasEntry
402
434
  validate_one_class_alias(name, entry)
403
435
  end
@@ -453,23 +485,31 @@ module Steep
453
485
  bounds[param.name] = factory.type_opt(param.upper_bound)
454
486
  end
455
487
 
456
- checker.push_variable_bounds(upper_bounds) do
457
- validate_definition_type(definition)
458
-
459
- ancestors = builder.ancestor_builder.one_interface_ancestors(name)
460
- ancestors.each_ancestor do |ancestor|
461
- case ancestor
462
- when RBS::Definition::Ancestor::Instance
463
- # Interface ancestor cannot be other than Interface
464
- ancestor.source.is_a?(Symbol) and raise
465
-
466
- defn = builder.build_interface(ancestor.name)
467
- validate_type_application_constraints(
468
- ancestor.name,
469
- defn.type_params_decl,
470
- ancestor.args,
471
- location: ancestor.source&.location || raise
472
- )
488
+ self_type = AST::Types::Name::Interface.new(
489
+ name: name,
490
+ args: definition.type_params.map { AST::Types::Var.new(name: _1) },
491
+ location: nil
492
+ )
493
+
494
+ push_context(self_type: self_type, class_type: nil, instance_type: nil) do
495
+ checker.push_variable_bounds(upper_bounds) do
496
+ validate_definition_type(definition)
497
+
498
+ ancestors = builder.ancestor_builder.one_interface_ancestors(name)
499
+ ancestors.each_ancestor do |ancestor|
500
+ case ancestor
501
+ when RBS::Definition::Ancestor::Instance
502
+ # Interface ancestor cannot be other than Interface
503
+ ancestor.source.is_a?(Symbol) and raise
504
+
505
+ defn = builder.build_interface(ancestor.name)
506
+ validate_type_application_constraints(
507
+ ancestor.name,
508
+ defn.type_params_decl,
509
+ ancestor.args,
510
+ location: ancestor.source&.location || raise
511
+ )
512
+ end
473
513
  end
474
514
  end
475
515
  end
@@ -519,21 +559,33 @@ module Steep
519
559
  end
520
560
 
521
561
  def validate_one_alias(name, entry = env.type_alias_decls[name])
522
- rescue_validation_errors(name) do
523
- Steep.logger.debug "Validating alias `#{name}`..."
562
+ *, inner_most_outer_module = entry.outer
563
+ if inner_most_outer_module
564
+ class_type = AST::Types::Name::Singleton.new(name: inner_most_outer_module.name, location: nil)
565
+ instance_type = AST::Types::Name::Instance.new(
566
+ name: inner_most_outer_module.name,
567
+ args: inner_most_outer_module.type_params.map { AST::Types::Any.new(location: nil) },
568
+ location: nil
569
+ )
570
+ end
524
571
 
525
- unless name.namespace.empty?
526
- outer = name.namespace.to_type_name
527
- builder.validate_type_name(outer, entry.decl.location&.aref(:name))
528
- end
572
+ push_context(class_type: class_type, instance_type: instance_type, self_type: nil) do
573
+ rescue_validation_errors(name) do
574
+ Steep.logger.debug "Validating alias `#{name}`..."
529
575
 
530
- upper_bounds = entry.decl.type_params.each.with_object({}) do |param, bounds|
531
- bounds[param.name] = factory.type_opt(param.upper_bound)
532
- end
576
+ unless name.namespace.empty?
577
+ outer = name.namespace.to_type_name
578
+ builder.validate_type_name(outer, entry.decl.location&.aref(:name))
579
+ end
580
+
581
+ upper_bounds = entry.decl.type_params.each.with_object({}) do |param, bounds|
582
+ bounds[param.name] = factory.type_opt(param.upper_bound)
583
+ end
533
584
 
534
- validator.validate_type_alias(entry: entry) do |type|
535
- checker.push_variable_bounds(upper_bounds) do
536
- validate_type(entry.decl.type)
585
+ validator.validate_type_alias(entry: entry) do |type|
586
+ checker.push_variable_bounds(upper_bounds) do
587
+ validate_type(entry.decl.type)
588
+ end
537
589
  end
538
590
  end
539
591
  end