rbs 2.8.4 → 3.8.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (434) hide show
  1. checksums.yaml +4 -4
  2. data/.github/dependabot.yml +12 -4
  3. data/.github/workflows/comments.yml +11 -11
  4. data/.github/workflows/dependabot.yml +30 -0
  5. data/.github/workflows/ruby.yml +40 -49
  6. data/.github/workflows/typecheck.yml +36 -0
  7. data/.github/workflows/windows.yml +28 -0
  8. data/.gitignore +1 -0
  9. data/.rubocop.yml +42 -2
  10. data/CHANGELOG.md +845 -1
  11. data/README.md +64 -4
  12. data/Rakefile +198 -18
  13. data/Steepfile +11 -11
  14. data/config.yml +311 -0
  15. data/core/array.rbs +2189 -1914
  16. data/core/basic_object.rbs +59 -84
  17. data/core/binding.rbs +7 -69
  18. data/core/builtin.rbs +210 -11
  19. data/core/class.rbs +37 -0
  20. data/core/comparable.rbs +23 -25
  21. data/core/complex.rbs +449 -227
  22. data/core/constants.rbs +29 -21
  23. data/core/data.rbs +415 -0
  24. data/core/dir.rbs +698 -415
  25. data/core/encoding.rbs +468 -843
  26. data/core/enumerable.rbs +495 -455
  27. data/core/enumerator/product.rbs +92 -0
  28. data/core/enumerator.rbs +106 -9
  29. data/core/env.rbs +1 -1
  30. data/core/errno.rbs +506 -605
  31. data/core/errors.rbs +15 -17
  32. data/core/exception.rbs +361 -145
  33. data/core/false_class.rbs +39 -26
  34. data/core/fiber.rbs +121 -14
  35. data/core/file.rbs +1262 -320
  36. data/core/file_test.rbs +62 -45
  37. data/core/float.rbs +187 -208
  38. data/core/gc.rbs +446 -196
  39. data/core/global_variables.rbs +29 -29
  40. data/core/hash.rbs +242 -349
  41. data/core/integer.rbs +246 -308
  42. data/core/io/buffer.rbs +373 -122
  43. data/core/io/wait.rbs +29 -17
  44. data/core/io.rbs +1881 -1518
  45. data/core/kernel.rbs +2116 -1538
  46. data/core/marshal.rbs +24 -14
  47. data/core/match_data.rbs +413 -166
  48. data/core/math.rbs +531 -291
  49. data/core/method.rbs +101 -32
  50. data/core/module.rbs +228 -64
  51. data/core/nil_class.rbs +106 -47
  52. data/core/numeric.rbs +206 -292
  53. data/core/object.rbs +73 -1168
  54. data/core/object_space/weak_key_map.rbs +166 -0
  55. data/core/object_space.rbs +5 -3
  56. data/core/proc.rbs +280 -39
  57. data/core/process.rbs +1318 -658
  58. data/core/ractor.rbs +200 -134
  59. data/core/random.rbs +21 -4
  60. data/core/range.rbs +309 -153
  61. data/core/rational.rbs +4 -12
  62. data/core/rb_config.rbs +64 -43
  63. data/core/rbs/unnamed/argf.rbs +411 -147
  64. data/core/rbs/unnamed/env_class.rbs +137 -253
  65. data/core/rbs/unnamed/random.rbs +49 -26
  66. data/core/refinement.rbs +16 -1
  67. data/core/regexp.rbs +1568 -862
  68. data/core/ruby_vm.rbs +719 -7
  69. data/core/rubygems/config_file.rbs +3 -0
  70. data/core/rubygems/errors.rbs +69 -6
  71. data/core/rubygems/rubygems.rbs +71 -17
  72. data/core/rubygems/version.rbs +11 -7
  73. data/{stdlib/set/0 → core}/set.rbs +80 -91
  74. data/core/signal.rbs +14 -8
  75. data/core/string.rbs +1732 -1607
  76. data/core/struct.rbs +467 -95
  77. data/core/symbol.rbs +215 -245
  78. data/core/thread.rbs +133 -89
  79. data/core/thread_group.rbs +9 -9
  80. data/core/time.rbs +1141 -841
  81. data/core/trace_point.rbs +181 -121
  82. data/core/true_class.rbs +58 -32
  83. data/core/unbound_method.rbs +103 -30
  84. data/core/warning.rbs +50 -5
  85. data/docs/CONTRIBUTING.md +1 -1
  86. data/docs/architecture.md +110 -0
  87. data/docs/collection.md +59 -5
  88. data/docs/data_and_struct.md +86 -0
  89. data/docs/gem.md +57 -0
  90. data/docs/rbs_by_example.md +16 -35
  91. data/docs/repo.md +1 -1
  92. data/docs/sigs.md +7 -7
  93. data/docs/stdlib.md +63 -5
  94. data/docs/syntax.md +255 -61
  95. data/docs/tools.md +1 -0
  96. data/ext/rbs_extension/extconf.rb +10 -0
  97. data/ext/rbs_extension/lexer.c +1741 -1548
  98. data/ext/rbs_extension/lexer.h +11 -1
  99. data/ext/rbs_extension/lexer.re +12 -6
  100. data/ext/rbs_extension/lexstate.c +26 -3
  101. data/ext/rbs_extension/location.c +119 -111
  102. data/ext/rbs_extension/location.h +32 -7
  103. data/ext/rbs_extension/main.c +3 -0
  104. data/ext/rbs_extension/parser.c +883 -481
  105. data/ext/rbs_extension/parserstate.c +65 -25
  106. data/ext/rbs_extension/parserstate.h +13 -3
  107. data/ext/rbs_extension/rbs_extension.h +1 -10
  108. data/ext/rbs_extension/unescape.c +7 -47
  109. data/goodcheck.yml +2 -2
  110. data/{ext/rbs_extension → include/rbs}/constants.h +26 -15
  111. data/include/rbs/ruby_objs.h +72 -0
  112. data/include/rbs.h +7 -0
  113. data/lib/rbs/annotate/annotations.rb +3 -3
  114. data/lib/rbs/annotate/formatter.rb +13 -3
  115. data/lib/rbs/annotate/rdoc_annotator.rb +1 -1
  116. data/lib/rbs/annotate/rdoc_source.rb +12 -3
  117. data/lib/rbs/ast/declarations.rb +85 -2
  118. data/lib/rbs/ast/directives.rb +39 -0
  119. data/lib/rbs/ast/members.rb +49 -15
  120. data/lib/rbs/ast/type_param.rb +104 -15
  121. data/lib/rbs/ast/visitor.rb +137 -0
  122. data/lib/rbs/buffer.rb +5 -0
  123. data/lib/rbs/cli/colored_io.rb +48 -0
  124. data/lib/rbs/cli/diff.rb +83 -0
  125. data/lib/rbs/cli/validate.rb +356 -0
  126. data/lib/rbs/cli.rb +253 -143
  127. data/lib/rbs/collection/cleaner.rb +8 -1
  128. data/lib/rbs/collection/config/lockfile.rb +92 -0
  129. data/lib/rbs/collection/config/lockfile_generator.rb +154 -65
  130. data/lib/rbs/collection/config.rb +19 -46
  131. data/lib/rbs/collection/installer.rb +12 -13
  132. data/lib/rbs/collection/sources/base.rb +2 -2
  133. data/lib/rbs/collection/sources/git.rb +146 -69
  134. data/lib/rbs/collection/sources/local.rb +81 -0
  135. data/lib/rbs/collection/sources/rubygems.rb +10 -12
  136. data/lib/rbs/collection/sources/stdlib.rb +14 -13
  137. data/lib/rbs/collection/sources.rb +15 -2
  138. data/lib/rbs/collection.rb +2 -1
  139. data/lib/rbs/definition.rb +13 -16
  140. data/lib/rbs/definition_builder/ancestor_builder.rb +100 -24
  141. data/lib/rbs/definition_builder/method_builder.rb +4 -4
  142. data/lib/rbs/definition_builder.rb +489 -584
  143. data/lib/rbs/diff.rb +125 -0
  144. data/lib/rbs/environment/use_map.rb +77 -0
  145. data/lib/rbs/environment.rb +406 -105
  146. data/lib/rbs/environment_loader.rb +48 -44
  147. data/lib/rbs/environment_walker.rb +1 -1
  148. data/lib/rbs/errors.rb +175 -56
  149. data/lib/rbs/file_finder.rb +28 -0
  150. data/lib/rbs/location_aux.rb +8 -7
  151. data/lib/rbs/locator.rb +37 -15
  152. data/lib/rbs/method_type.rb +23 -0
  153. data/lib/rbs/namespace.rb +1 -0
  154. data/lib/rbs/parser/lex_result.rb +15 -0
  155. data/lib/rbs/parser/token.rb +23 -0
  156. data/lib/rbs/parser_aux.rb +22 -13
  157. data/lib/rbs/prototype/helpers.rb +48 -22
  158. data/lib/rbs/prototype/node_usage.rb +99 -0
  159. data/lib/rbs/prototype/rb.rb +125 -31
  160. data/lib/rbs/prototype/rbi.rb +49 -36
  161. data/lib/rbs/prototype/runtime/helpers.rb +59 -0
  162. data/lib/rbs/prototype/runtime/reflection.rb +19 -0
  163. data/lib/rbs/prototype/runtime/value_object_generator.rb +279 -0
  164. data/lib/rbs/prototype/runtime.rb +273 -159
  165. data/lib/rbs/resolver/constant_resolver.rb +24 -8
  166. data/lib/rbs/resolver/type_name_resolver.rb +41 -7
  167. data/lib/rbs/sorter.rb +153 -123
  168. data/lib/rbs/substitution.rb +19 -0
  169. data/lib/rbs/subtractor.rb +201 -0
  170. data/lib/rbs/test/errors.rb +24 -11
  171. data/lib/rbs/test/guaranteed.rb +30 -0
  172. data/lib/rbs/test/hook.rb +45 -40
  173. data/lib/rbs/test/setup.rb +1 -1
  174. data/lib/rbs/test/tester.rb +1 -1
  175. data/lib/rbs/test/type_check.rb +120 -23
  176. data/lib/rbs/test.rb +6 -3
  177. data/lib/rbs/type_alias_dependency.rb +13 -3
  178. data/lib/rbs/type_alias_regularity.rb +21 -14
  179. data/lib/rbs/type_name.rb +18 -13
  180. data/lib/rbs/types.rb +352 -18
  181. data/lib/rbs/unit_test/convertibles.rb +176 -0
  182. data/lib/rbs/unit_test/spy.rb +136 -0
  183. data/lib/rbs/unit_test/type_assertions.rb +341 -0
  184. data/lib/rbs/unit_test/with_aliases.rb +143 -0
  185. data/lib/rbs/unit_test.rb +6 -0
  186. data/lib/rbs/validator.rb +55 -30
  187. data/lib/rbs/variance_calculator.rb +26 -23
  188. data/lib/rbs/vendorer.rb +3 -3
  189. data/lib/rbs/version.rb +1 -1
  190. data/lib/rbs/writer.rb +69 -22
  191. data/lib/rbs.rb +7 -2
  192. data/lib/rdoc/discover.rb +1 -1
  193. data/lib/rdoc_plugin/parser.rb +5 -5
  194. data/rbs.gemspec +12 -2
  195. data/schema/decls.json +1 -1
  196. data/schema/members.json +15 -10
  197. data/sig/ancestor_builder.rbs +4 -0
  198. data/sig/ancestor_graph.rbs +22 -2
  199. data/sig/annotate/formatter.rbs +2 -2
  200. data/sig/annotate/rdoc_annotater.rbs +1 -1
  201. data/sig/cli/colored_io.rbs +15 -0
  202. data/sig/cli/diff.rbs +21 -0
  203. data/sig/cli/validate.rbs +43 -0
  204. data/sig/cli.rbs +4 -0
  205. data/sig/collection/config/lockfile.rbs +74 -0
  206. data/sig/collection/config/lockfile_generator.rbs +66 -0
  207. data/sig/collection/config.rbs +5 -48
  208. data/sig/collection/installer.rbs +1 -1
  209. data/sig/collection/sources.rbs +105 -33
  210. data/sig/constant.rbs +1 -1
  211. data/sig/declarations.rbs +42 -3
  212. data/sig/definition.rbs +26 -10
  213. data/sig/definition_builder.rbs +103 -81
  214. data/sig/diff.rbs +28 -0
  215. data/sig/directives.rbs +61 -0
  216. data/sig/environment.rbs +175 -29
  217. data/sig/environment_loader.rbs +20 -18
  218. data/sig/errors.rbs +123 -2
  219. data/sig/file_finder.rbs +28 -0
  220. data/sig/location.rbs +0 -3
  221. data/sig/locator.rbs +14 -2
  222. data/sig/manifest.yaml +0 -1
  223. data/sig/members.rbs +32 -9
  224. data/sig/method_types.rbs +10 -4
  225. data/sig/namespace.rbs +2 -3
  226. data/sig/parser.rbs +55 -16
  227. data/sig/prototype/helpers.rbs +4 -0
  228. data/sig/prototype/node_usage.rbs +20 -0
  229. data/sig/prototype/rb.rbs +10 -2
  230. data/sig/prototype/rbi.rbs +2 -0
  231. data/sig/prototype/runtime.rbs +182 -0
  232. data/sig/rbs.rbs +1 -1
  233. data/sig/rdoc/rbs.rbs +4 -0
  234. data/sig/repository.rbs +7 -5
  235. data/sig/resolver/constant_resolver.rbs +3 -4
  236. data/sig/resolver/context.rbs +1 -1
  237. data/sig/resolver/type_name_resolver.rbs +5 -1
  238. data/sig/shims/bundler.rbs +38 -0
  239. data/sig/shims/rubygems.rbs +19 -0
  240. data/sig/sorter.rbs +23 -5
  241. data/sig/substitution.rbs +6 -0
  242. data/sig/subtractor.rbs +37 -0
  243. data/sig/test/errors.rbs +52 -0
  244. data/sig/test/guranteed.rbs +9 -0
  245. data/sig/test/type_check.rbs +19 -0
  246. data/sig/test.rbs +82 -0
  247. data/sig/type_alias_dependency.rbs +31 -0
  248. data/sig/type_alias_regularity.rbs +12 -6
  249. data/sig/type_param.rbs +45 -9
  250. data/sig/typename.rbs +8 -5
  251. data/sig/types.rbs +119 -12
  252. data/sig/unit_test/convertibles.rbs +154 -0
  253. data/sig/unit_test/spy.rbs +28 -0
  254. data/sig/unit_test/type_assertions.rbs +194 -0
  255. data/sig/unit_test/with_aliases.rbs +136 -0
  256. data/sig/use_map.rbs +35 -0
  257. data/sig/validator.rbs +12 -5
  258. data/sig/variance_calculator.rbs +3 -1
  259. data/sig/vendorer.rbs +1 -1
  260. data/sig/visitor.rbs +47 -0
  261. data/sig/writer.rbs +6 -2
  262. data/src/constants.c +153 -0
  263. data/src/ruby_objs.c +793 -0
  264. data/stdlib/base64/0/base64.rbs +298 -45
  265. data/stdlib/benchmark/0/benchmark.rbs +12 -3
  266. data/stdlib/bigdecimal/0/big_decimal.rbs +62 -198
  267. data/stdlib/cgi/0/core.rbs +68 -15
  268. data/stdlib/cgi/0/manifest.yaml +1 -0
  269. data/stdlib/coverage/0/coverage.rbs +50 -11
  270. data/stdlib/csv/0/csv.rbs +90 -119
  271. data/stdlib/csv/0/manifest.yaml +1 -0
  272. data/stdlib/date/0/date.rbs +806 -735
  273. data/stdlib/date/0/date_time.rbs +70 -211
  274. data/stdlib/dbm/0/dbm.rbs +0 -2
  275. data/stdlib/delegate/0/delegator.rbs +184 -0
  276. data/stdlib/delegate/0/kernel.rbs +47 -0
  277. data/stdlib/delegate/0/simple_delegator.rbs +96 -0
  278. data/stdlib/did_you_mean/0/did_you_mean.rbs +3 -8
  279. data/stdlib/digest/0/digest.rbs +48 -35
  280. data/stdlib/erb/0/erb.rbs +15 -39
  281. data/stdlib/etc/0/etc.rbs +174 -54
  282. data/stdlib/fileutils/0/fileutils.rbs +1234 -385
  283. data/stdlib/forwardable/0/forwardable.rbs +4 -4
  284. data/stdlib/io-console/0/io-console.rbs +82 -17
  285. data/stdlib/ipaddr/0/ipaddr.rbs +11 -6
  286. data/stdlib/json/0/json.rbs +434 -151
  287. data/stdlib/kconv/0/kconv.rbs +166 -0
  288. data/stdlib/logger/0/formatter.rbs +0 -2
  289. data/stdlib/logger/0/log_device.rbs +1 -3
  290. data/stdlib/logger/0/logger.rbs +465 -328
  291. data/stdlib/minitest/0/kernel.rbs +2 -2
  292. data/stdlib/minitest/0/minitest/abstract_reporter.rbs +4 -1
  293. data/stdlib/minitest/0/minitest/assertion.rbs +1 -0
  294. data/stdlib/minitest/0/minitest/assertions.rbs +58 -13
  295. data/stdlib/minitest/0/minitest/backtrace_filter.rbs +7 -0
  296. data/stdlib/minitest/0/minitest/bench_spec.rbs +8 -8
  297. data/stdlib/minitest/0/minitest/benchmark.rbs +17 -16
  298. data/stdlib/minitest/0/minitest/compress.rbs +13 -0
  299. data/stdlib/minitest/0/minitest/error_on_warning.rbs +3 -0
  300. data/stdlib/minitest/0/minitest/mock.rbs +9 -5
  301. data/stdlib/minitest/0/minitest/parallel/executor.rbs +4 -0
  302. data/stdlib/minitest/0/minitest/parallel/test/class_methods.rbs +0 -1
  303. data/stdlib/minitest/0/minitest/pride_io.rbs +8 -0
  304. data/stdlib/minitest/0/minitest/pride_lol.rbs +2 -0
  305. data/stdlib/minitest/0/minitest/progress_reporter.rbs +1 -1
  306. data/stdlib/minitest/0/minitest/reportable.rbs +2 -0
  307. data/stdlib/minitest/0/minitest/runnable.rbs +33 -1
  308. data/stdlib/minitest/0/minitest/spec/dsl/instance_methods.rbs +1 -1
  309. data/stdlib/minitest/0/minitest/spec/dsl.rbs +10 -6
  310. data/stdlib/minitest/0/minitest/spec.rbs +1 -1
  311. data/stdlib/minitest/0/minitest/statistics_reporter.rbs +5 -0
  312. data/stdlib/minitest/0/minitest/summary_reporter.rbs +0 -7
  313. data/stdlib/minitest/0/minitest/test/lifecycle_hooks.rbs +7 -7
  314. data/stdlib/minitest/0/minitest/test.rbs +7 -14
  315. data/stdlib/minitest/0/minitest/unexpected_error.rbs +2 -0
  316. data/stdlib/minitest/0/minitest/unexpected_warning.rbs +6 -0
  317. data/stdlib/minitest/0/minitest/unit.rbs +1 -2
  318. data/stdlib/minitest/0/minitest.rbs +41 -892
  319. data/stdlib/monitor/0/monitor.rbs +91 -10
  320. data/stdlib/mutex_m/0/mutex_m.rbs +0 -2
  321. data/stdlib/net-http/0/manifest.yaml +1 -1
  322. data/stdlib/net-http/0/net-http.rbs +3858 -964
  323. data/stdlib/net-protocol/0/manifest.yaml +2 -0
  324. data/stdlib/net-protocol/0/net-protocol.rbs +56 -0
  325. data/stdlib/net-smtp/0/manifest.yaml +2 -0
  326. data/stdlib/net-smtp/0/net-smtp.rbs +55 -0
  327. data/stdlib/nkf/0/nkf.rbs +35 -5
  328. data/stdlib/objspace/0/objspace.rbs +40 -18
  329. data/stdlib/observable/0/observable.rbs +217 -0
  330. data/stdlib/open-uri/0/manifest.yaml +4 -0
  331. data/stdlib/open-uri/0/open-uri.rbs +393 -0
  332. data/stdlib/open3/0/open3.rbs +147 -0
  333. data/stdlib/openssl/0/manifest.yaml +1 -0
  334. data/stdlib/openssl/0/openssl.rbs +681 -316
  335. data/stdlib/optparse/0/optparse.rbs +100 -65
  336. data/stdlib/pathname/0/pathname.rbs +24 -15
  337. data/stdlib/pp/0/manifest.yaml +2 -0
  338. data/stdlib/pp/0/pp.rbs +300 -0
  339. data/stdlib/prettyprint/0/prettyprint.rbs +2 -6
  340. data/stdlib/pstore/0/pstore.rbs +370 -156
  341. data/stdlib/psych/0/core_ext.rbs +12 -0
  342. data/stdlib/{yaml → psych}/0/dbm.rbs +3 -3
  343. data/stdlib/psych/0/manifest.yaml +3 -0
  344. data/stdlib/psych/0/psych.rbs +402 -0
  345. data/stdlib/{yaml → psych}/0/store.rbs +2 -2
  346. data/stdlib/pty/0/pty.rbs +63 -11
  347. data/stdlib/rdoc/0/code_object.rbs +51 -0
  348. data/stdlib/rdoc/0/comment.rbs +59 -0
  349. data/stdlib/rdoc/0/context.rbs +153 -0
  350. data/stdlib/rdoc/0/markup.rbs +117 -0
  351. data/stdlib/rdoc/0/parser.rbs +56 -0
  352. data/stdlib/rdoc/0/rdoc.rbs +13 -380
  353. data/stdlib/rdoc/0/ri.rbs +17 -0
  354. data/stdlib/rdoc/0/store.rbs +48 -0
  355. data/stdlib/rdoc/0/top_level.rbs +97 -0
  356. data/stdlib/resolv/0/resolv.rbs +16 -79
  357. data/stdlib/ripper/0/ripper.rbs +1648 -0
  358. data/stdlib/securerandom/0/securerandom.rbs +7 -2
  359. data/stdlib/shellwords/0/shellwords.rbs +11 -12
  360. data/stdlib/singleton/0/singleton.rbs +0 -3
  361. data/stdlib/socket/0/addrinfo.rbs +13 -18
  362. data/stdlib/socket/0/basic_socket.rbs +5 -10
  363. data/stdlib/socket/0/ip_socket.rbs +0 -2
  364. data/stdlib/socket/0/socket.rbs +77 -46
  365. data/stdlib/socket/0/tcp_server.rbs +0 -5
  366. data/stdlib/socket/0/tcp_socket.rbs +36 -3
  367. data/stdlib/socket/0/udp_socket.rbs +4 -5
  368. data/stdlib/socket/0/unix_server.rbs +0 -5
  369. data/stdlib/socket/0/unix_socket.rbs +2 -4
  370. data/{core/string_io.rbs → stdlib/stringio/0/stringio.rbs} +188 -107
  371. data/stdlib/strscan/0/string_scanner.rbs +1269 -425
  372. data/stdlib/tempfile/0/tempfile.rbs +224 -61
  373. data/stdlib/time/0/time.rbs +48 -35
  374. data/stdlib/timeout/0/timeout.rbs +17 -8
  375. data/stdlib/tmpdir/0/tmpdir.rbs +10 -3
  376. data/stdlib/tsort/0/tsort.rbs +0 -4
  377. data/stdlib/uri/0/common.rbs +271 -144
  378. data/stdlib/uri/0/file.rbs +5 -0
  379. data/stdlib/uri/0/ftp.rbs +1 -1
  380. data/stdlib/uri/0/generic.rbs +26 -22
  381. data/stdlib/uri/0/http.rbs +4 -4
  382. data/stdlib/uri/0/ldap.rbs +1 -1
  383. data/stdlib/uri/0/mailto.rbs +84 -0
  384. data/stdlib/uri/0/rfc2396_parser.rbs +3 -0
  385. data/stdlib/yaml/0/manifest.yaml +1 -2
  386. data/stdlib/yaml/0/yaml.rbs +1 -199
  387. data/stdlib/zlib/0/buf_error.rbs +10 -0
  388. data/stdlib/zlib/0/data_error.rbs +10 -0
  389. data/stdlib/zlib/0/deflate.rbs +210 -0
  390. data/stdlib/zlib/0/error.rbs +20 -0
  391. data/stdlib/zlib/0/gzip_file/crc_error.rbs +12 -0
  392. data/stdlib/zlib/0/gzip_file/error.rbs +23 -0
  393. data/stdlib/zlib/0/gzip_file/length_error.rbs +12 -0
  394. data/stdlib/zlib/0/gzip_file/no_footer.rbs +11 -0
  395. data/stdlib/zlib/0/gzip_file.rbs +156 -0
  396. data/stdlib/zlib/0/gzip_reader.rbs +293 -0
  397. data/stdlib/zlib/0/gzip_writer.rbs +166 -0
  398. data/stdlib/zlib/0/inflate.rbs +180 -0
  399. data/stdlib/zlib/0/mem_error.rbs +10 -0
  400. data/stdlib/zlib/0/need_dict.rbs +13 -0
  401. data/stdlib/zlib/0/stream_end.rbs +11 -0
  402. data/stdlib/zlib/0/stream_error.rbs +11 -0
  403. data/stdlib/zlib/0/version_error.rbs +11 -0
  404. data/stdlib/zlib/0/zlib.rbs +1 -3
  405. data/stdlib/zlib/0/zstream.rbs +200 -0
  406. data/templates/include/rbs/constants.h.erb +20 -0
  407. data/templates/include/rbs/ruby_objs.h.erb +10 -0
  408. data/templates/src/constants.c.erb +36 -0
  409. data/templates/src/ruby_objs.c.erb +27 -0
  410. data/templates/template.rb +122 -0
  411. metadata +136 -36
  412. data/Gemfile +0 -33
  413. data/Gemfile.lock +0 -118
  414. data/core/deprecated.rbs +0 -9
  415. data/ext/rbs_extension/constants.c +0 -135
  416. data/ext/rbs_extension/ruby_objs.c +0 -525
  417. data/ext/rbs_extension/ruby_objs.h +0 -43
  418. data/lib/rbs/constant_table.rb +0 -167
  419. data/lib/rbs/parser_compat/lexer_error.rb +0 -6
  420. data/lib/rbs/parser_compat/located_value.rb +0 -7
  421. data/lib/rbs/parser_compat/semantics_error.rb +0 -6
  422. data/lib/rbs/parser_compat/syntax_error.rb +0 -6
  423. data/lib/rbs/test/spy.rb +0 -6
  424. data/lib/rbs/type_name_resolver.rb +0 -67
  425. data/sig/constant_table.rbs +0 -30
  426. data/sig/shims/abstract_syntax_tree.rbs +0 -25
  427. data/sig/shims/pp.rbs +0 -3
  428. data/sig/shims/ripper.rbs +0 -8
  429. data/sig/shims.rbs +0 -69
  430. data/sig/type_name_resolver.rbs +0 -26
  431. data/stdlib/minitest/0/manifest.yaml +0 -2
  432. data/stdlib/prime/0/integer-extension.rbs +0 -41
  433. data/stdlib/prime/0/manifest.yaml +0 -2
  434. data/stdlib/prime/0/prime.rbs +0 -372
@@ -3,7 +3,6 @@
3
3
  module RBS
4
4
  class DefinitionBuilder
5
5
  attr_reader :env
6
- attr_reader :type_name_resolver
7
6
  attr_reader :ancestor_builder
8
7
  attr_reader :method_builder
9
8
 
@@ -14,7 +13,6 @@ module RBS
14
13
 
15
14
  def initialize(env:, ancestor_builder: nil, method_builder: nil)
16
15
  @env = env
17
- @type_name_resolver = TypeNameResolver.from_env(env)
18
16
  @ancestor_builder = ancestor_builder || AncestorBuilder.new(env: env)
19
17
  @method_builder = method_builder || MethodBuilder.new(env: env)
20
18
 
@@ -32,243 +30,197 @@ module RBS
32
30
  end
33
31
  end
34
32
 
33
+ def define_interface(definition, type_name, subst)
34
+ included_interfaces = ancestor_builder.interface_ancestors(type_name).ancestors #: Array[Definition::Ancestor::Instance]
35
+ included_interfaces = included_interfaces.reject {|ancestor| ancestor.source == nil }
36
+
37
+ interface_methods = interface_methods(included_interfaces)
38
+ methods = method_builder.build_interface(type_name)
39
+
40
+ import_methods(definition, type_name, methods, interface_methods, subst, nil)
41
+ end
42
+
35
43
  def build_interface(type_name)
36
44
  try_cache(type_name, cache: interface_cache) do
37
45
  entry = env.interface_decls[type_name] or raise "Unknown name for build_interface: #{type_name}"
38
46
  declaration = entry.decl
39
47
  ensure_namespace!(type_name.namespace, location: declaration.location)
40
48
 
41
- self_type = Types::Interface.new(
42
- name: type_name,
43
- args: Types::Variable.build(declaration.type_params.each.map(&:name)),
44
- location: nil
45
- )
49
+ type_params = declaration.type_params.each.map(&:name)
50
+ type_args = Types::Variable.build(type_params)
51
+ self_type = Types::Interface.new(name: type_name, args: type_args, location: nil)
52
+
53
+ subst = Substitution.build(type_params, type_args)
46
54
 
47
55
  ancestors = ancestor_builder.interface_ancestors(type_name)
48
56
  Definition.new(type_name: type_name, entry: entry, self_type: self_type, ancestors: ancestors).tap do |definition|
49
- included_interfaces = ancestor_builder.one_interface_ancestors(type_name).included_interfaces or raise
50
- included_interfaces.each do |mod|
51
- defn = build_interface(mod.name)
52
- subst = Substitution.build(defn.type_params, mod.args)
53
-
54
- defn.methods.each do |name, method|
55
- definition.methods[name] = method.sub(subst)
56
- end
57
- end
58
-
59
57
  methods = method_builder.build_interface(type_name)
60
58
  one_ancestors = ancestor_builder.one_interface_ancestors(type_name)
61
-
62
59
  validate_type_params(definition, methods: methods, ancestors: one_ancestors)
63
60
 
64
- methods.each do |defn|
65
- method = case original = defn.original
66
- when AST::Members::MethodDefinition
67
- defs = original.types.map do |method_type|
68
- Definition::Method::TypeDef.new(
69
- type: method_type,
70
- member: original,
71
- defined_in: type_name,
72
- implemented_in: nil
73
- )
74
- end
75
-
76
- Definition::Method.new(
77
- super_method: nil,
78
- defs: defs,
79
- accessibility: :public,
80
- alias_of: nil
81
- )
82
- when AST::Members::Alias
83
- unless definition.methods.key?(original.old_name)
84
- raise UnknownMethodAliasError.new(
85
- type_name: type_name,
86
- original_name: original.old_name,
87
- aliased_name: original.new_name,
88
- location: original.location
89
- )
90
- end
61
+ define_interface(definition, type_name, subst)
62
+ end
63
+ end
64
+ end
91
65
 
92
- original_method = definition.methods[original.old_name]
93
- Definition::Method.new(
94
- super_method: nil,
95
- defs: original_method.defs.map do |defn|
96
- defn.update(implemented_in: nil, defined_in: type_name)
97
- end,
98
- accessibility: :public,
99
- alias_of: original_method
100
- )
101
- when nil
102
- unless definition.methods.key?(defn.name)
103
- raise InvalidOverloadMethodError.new(
104
- type_name: type_name,
105
- method_name: defn.name,
106
- kind: :instance,
107
- members: defn.overloads
108
- )
109
- end
66
+ def tapp_subst(name, args)
67
+ params =
68
+ case
69
+ when name.interface?
70
+ entry = env.interface_decls[name] or raise "Unknown interface name: #{name}"
71
+ entry.decl.type_params
72
+ when name.alias?
73
+ entry = env.type_alias_decls[name] or raise "Unknown alias name: #{name}"
74
+ entry.decl.type_params
75
+ when name.class?
76
+ entry = env.class_decls[name] or raise "Unknown module name: #{name}"
77
+ entry.type_params
78
+ else
79
+ raise
80
+ end
110
81
 
111
- definition.methods[defn.name]
82
+ AST::TypeParam.application(params, args) || Substitution.new()
83
+ end
112
84
 
113
- when AST::Members::AttrReader, AST::Members::AttrWriter, AST::Members::AttrAccessor
114
- raise
85
+ def define_instance(definition, type_name, subst)
86
+ one_ancestors = ancestor_builder.one_instance_ancestors(type_name)
87
+ methods = method_builder.build_instance(type_name)
115
88
 
116
- end
89
+ self_type_methods = one_ancestors.each_self_type.with_object({}) do |self_type, hash| #$ Hash[Symbol, Definition::Method]
90
+ self_type.args.each do |arg|
91
+ validate_type_presence(arg)
92
+ end
117
93
 
118
- defn.overloads.each do |overload|
119
- overload_defs = overload.types.map do |method_type|
120
- Definition::Method::TypeDef.new(
121
- type: method_type,
122
- member: overload,
123
- defined_in: type_name,
124
- implemented_in: nil
125
- )
126
- end
94
+ self_type_defn = self_type.name.interface? ? build_interface(self_type.name) : build_instance(self_type.name)
127
95
 
128
- method.defs.unshift(*overload_defs)
129
- end
96
+ s = subst + tapp_subst(self_type.name, self_type.args)
97
+ self_type_defn.methods.each do |method_name, method_def|
98
+ hash[method_name] = method_def.sub(s)
99
+ end
100
+ end
130
101
 
131
- definition.methods[defn.name] = method
132
- end
102
+ one_ancestors.each_included_module do |mod|
103
+ mod.args.each do |arg|
104
+ validate_type_presence(arg)
133
105
  end
106
+
107
+ define_instance(definition, mod.name, subst + tapp_subst(mod.name, mod.args))
134
108
  end
135
- end
136
109
 
137
- def build_instance(type_name, no_self_types: false)
138
- try_cache(type_name, cache: instance_cache, key: [type_name, no_self_types]) do
139
- entry = env.class_decls[type_name] or raise "Unknown name for build_instance: #{type_name}"
140
- ensure_namespace!(type_name.namespace, location: entry.decls[0].decl.location)
110
+ all_interfaces = one_ancestors.each_included_interface.flat_map do |interface|
111
+ other_interfaces = ancestor_builder.interface_ancestors(interface.name).ancestors #: Array[Definition::Ancestor::Instance]
112
+ other_interfaces = other_interfaces.select {|ancestor| ancestor.source }
113
+ [interface, *other_interfaces]
114
+ end
115
+ interface_methods = interface_methods(all_interfaces)
116
+ import_methods(definition, type_name, methods, interface_methods, subst, self_type_methods)
141
117
 
142
- case entry
143
- when Environment::ClassEntry, Environment::ModuleEntry
144
- ancestors = ancestor_builder.instance_ancestors(type_name)
145
- args = entry.type_params.map {|param| Types::Variable.new(name: param.name, location: param.location) }
146
- self_type = Types::ClassInstance.new(name: type_name, args: args, location: nil)
118
+ one_ancestors.each_prepended_module do |mod|
119
+ mod.args.each do |arg|
120
+ validate_type_presence(arg)
121
+ end
147
122
 
148
- Definition.new(type_name: type_name, entry: entry, self_type: self_type, ancestors: ancestors).tap do |definition|
149
- one_ancestors = ancestor_builder.one_instance_ancestors(type_name)
150
- methods = method_builder.build_instance(type_name)
123
+ define_instance(definition, mod.name, subst + tapp_subst(mod.name, mod.args))
124
+ end
151
125
 
152
- validate_type_params definition, methods: methods, ancestors: one_ancestors
126
+ entry = env.class_decls[type_name] or raise "Unknown name for build_instance: #{type_name}"
127
+ args = entry.type_params.map {|param| Types::Variable.new(name: param.name, location: param.location) }
153
128
 
154
- if super_class = one_ancestors.super_class
155
- case super_class
156
- when Definition::Ancestor::Instance
157
- build_instance(super_class.name).yield_self do |defn|
158
- merge_definition(src: defn,
159
- dest: definition,
160
- subst: Substitution.build(defn.type_params, super_class.args),
161
- keep_super: true)
162
- end
163
- else
164
- raise
165
- end
166
- end
129
+ entry.decls.each do |d|
130
+ subst_ = subst + Substitution.build(d.decl.type_params.each.map(&:name), args)
167
131
 
168
- if self_types = one_ancestors.self_types
169
- unless no_self_types
170
- self_types.each do |ans|
171
- defn = if ans.name.interface?
172
- build_interface(ans.name)
173
- else
174
- build_instance(ans.name)
175
- end
132
+ d.decl.members.each do |member|
133
+ case member
134
+ when AST::Members::AttrReader, AST::Members::AttrAccessor, AST::Members::AttrWriter
135
+ if member.kind == :instance
136
+ ivar_name = case member.ivar_name
137
+ when false
138
+ nil
139
+ else
140
+ member.ivar_name || :"@#{member.name}"
141
+ end
176
142
 
177
- # Successor interface method overwrites.
178
- merge_definition(
179
- src: defn,
180
- dest: definition,
181
- subst: Substitution.build(defn.type_params, ans.args),
182
- keep_super: true
183
- )
184
- end
185
- else
186
- methods_with_self = build_instance(type_name, no_self_types: false).methods
143
+ if ivar_name
144
+ insert_variable(
145
+ type_name,
146
+ definition.instance_variables,
147
+ name: ivar_name,
148
+ type: member.type.sub(subst_)
149
+ )
187
150
  end
188
151
  end
189
152
 
190
- one_ancestors.each_included_module do |mod|
191
- defn = build_instance(mod.name, no_self_types: true)
192
- merge_definition(src: defn,
193
- dest: definition,
194
- subst: Substitution.build(defn.type_params, mod.args))
195
- end
153
+ when AST::Members::InstanceVariable
154
+ insert_variable(
155
+ type_name,
156
+ definition.instance_variables,
157
+ name: member.name,
158
+ type: member.type.sub(subst_)
159
+ )
196
160
 
197
- interface_methods = {}
161
+ when AST::Members::ClassVariable
162
+ insert_variable(type_name, definition.class_variables, name: member.name, type: member.type)
163
+ end
164
+ end
165
+ end
166
+ end
198
167
 
199
- one_ancestors.each_included_interface do |mod|
200
- defn = build_interface(mod.name)
201
- subst = Substitution.build(defn.type_params, mod.args)
168
+ def build_instance(type_name)
169
+ type_name = env.normalize_module_name(type_name)
202
170
 
203
- defn.methods.each do |name, method|
204
- if interface_methods.key?(name)
205
- include_member = mod.source
171
+ try_cache(type_name, cache: instance_cache) do
172
+ entry = env.class_decls[type_name] or raise "Unknown name for build_instance: #{type_name}"
173
+ ensure_namespace!(type_name.namespace, location: entry.decls[0].decl.location)
206
174
 
207
- raise unless include_member.is_a?(AST::Members::Include)
175
+ ancestors = ancestor_builder.instance_ancestors(type_name)
176
+ args = entry.type_params.map {|param| Types::Variable.new(name: param.name, location: param.location) }
177
+ self_type = Types::ClassInstance.new(name: type_name, args: args, location: nil)
208
178
 
209
- raise DuplicatedInterfaceMethodDefinitionError.new(
210
- type: self_type,
211
- method_name: name,
212
- member: include_member
213
- )
214
- end
179
+ Definition.new(type_name: type_name, entry: entry, self_type: self_type, ancestors: ancestors).tap do |definition|
180
+ one_ancestors = ancestor_builder.one_instance_ancestors(type_name)
181
+ methods = method_builder.build_instance(type_name)
215
182
 
216
- merge_method(type_name, interface_methods, name, method, subst, implemented_in: type_name)
217
- end
218
- end
183
+ validate_type_params definition, methods: methods, ancestors: one_ancestors
219
184
 
220
- if entry.is_a?(Environment::ModuleEntry)
221
- define_methods_module_instance(
222
- definition,
223
- methods: methods,
224
- interface_methods: interface_methods,
225
- module_self_methods: methods_with_self
226
- )
227
- else
228
- define_methods_instance(definition, methods: methods, interface_methods: interface_methods)
229
- end
185
+ if entry.is_a?(Environment::ClassEntry)
186
+ if super_class = one_ancestors.super_class
187
+ super_class.is_a?(Definition::Ancestor::Instance) or raise
230
188
 
231
- entry.decls.each do |d|
232
- subst = Substitution.build(d.decl.type_params.each.map(&:name), args)
233
-
234
- d.decl.members.each do |member|
235
- case member
236
- when AST::Members::AttrReader, AST::Members::AttrAccessor, AST::Members::AttrWriter
237
- if member.kind == :instance
238
- ivar_name = case member.ivar_name
239
- when false
240
- nil
241
- else
242
- member.ivar_name || :"@#{member.name}"
243
- end
244
-
245
- if ivar_name
246
- insert_variable(type_name,
247
- definition.instance_variables,
248
- name: ivar_name,
249
- type: member.type.sub(subst))
250
- end
189
+ build_instance(super_class.name).tap do |defn|
190
+ unless super_class.args.empty?
191
+ super_class.args.each do |arg|
192
+ validate_type_presence(arg)
251
193
  end
252
194
 
253
- when AST::Members::InstanceVariable
254
- insert_variable(type_name,
255
- definition.instance_variables,
256
- name: member.name,
257
- type: member.type.sub(subst))
258
-
259
- when AST::Members::ClassVariable
260
- insert_variable(type_name, definition.class_variables, name: member.name, type: member.type)
195
+ subst = tapp_subst(super_class.name, super_class.args)
196
+ defn = defn.sub(subst)
261
197
  end
198
+
199
+ definition.methods.merge!(defn.methods)
200
+ definition.instance_variables.merge!(defn.instance_variables)
201
+ definition.class_variables.merge!(defn.class_variables)
262
202
  end
263
203
  end
204
+ end
205
+
206
+ if entry.is_a?(Environment::ModuleEntry)
207
+ if self_types = one_ancestors.self_types
208
+ self_types.each do |ans|
209
+ ans.args.each do |arg|
210
+ validate_type_presence(arg)
211
+ end
264
212
 
265
- one_ancestors.each_prepended_module do |mod|
266
- defn = build_instance(mod.name, no_self_types: true)
267
- merge_definition(src: defn,
268
- dest: definition,
269
- subst: Substitution.build(defn.type_params, mod.args))
213
+ subst = tapp_subst(ans.name, ans.args)
214
+ if ans.name.interface?
215
+ define_interface(definition, ans.name, subst)
216
+ else
217
+ define_instance(definition, ans.name, subst)
218
+ end
219
+ end
270
220
  end
271
221
  end
222
+
223
+ define_instance(definition, type_name, Substitution.new)
272
224
  end
273
225
  end
274
226
  end
@@ -280,91 +232,65 @@ module RBS
280
232
  entry = env.class_decls[type_name] or raise "Unknown name for build_singleton0: #{type_name}"
281
233
  ensure_namespace!(type_name.namespace, location: entry.decls[0].decl.location)
282
234
 
283
- case entry
284
- when Environment::ClassEntry, Environment::ModuleEntry
285
- ancestors = ancestor_builder.singleton_ancestors(type_name)
286
- self_type = Types::ClassSingleton.new(name: type_name, location: nil)
235
+ ancestors = ancestor_builder.singleton_ancestors(type_name)
236
+ self_type = Types::ClassSingleton.new(name: type_name, location: nil)
287
237
 
288
- Definition.new(type_name: type_name, entry: entry, self_type: self_type, ancestors: ancestors).tap do |definition|
289
- one_ancestors = ancestor_builder.one_singleton_ancestors(type_name)
290
-
291
- if super_class = one_ancestors.super_class
292
- case super_class
293
- when Definition::Ancestor::Instance
294
- defn = build_instance(super_class.name)
295
- merge_definition(src: defn,
296
- dest: definition,
297
- subst: Substitution.build(defn.type_params, super_class.args),
298
- keep_super: true)
299
- when Definition::Ancestor::Singleton
300
- defn = build_singleton0(super_class.name)
301
- merge_definition(src: defn, dest: definition, subst: Substitution.new, keep_super: true)
302
- end
238
+ Definition.new(type_name: type_name, entry: entry, self_type: self_type, ancestors: ancestors).tap do |definition|
239
+ one_ancestors = ancestor_builder.one_singleton_ancestors(type_name)
240
+ methods = method_builder.build_singleton(type_name)
241
+
242
+ if super_class = one_ancestors.super_class
243
+ case super_class
244
+ when Definition::Ancestor::Instance
245
+ defn = build_instance(super_class.name)
246
+ when Definition::Ancestor::Singleton
247
+ defn = build_singleton0(super_class.name)
303
248
  end
304
249
 
305
- one_ancestors.each_extended_module do |mod|
306
- mod.args.each do |arg|
307
- validate_type_presence(arg)
308
- end
250
+ definition.methods.merge!(defn.methods)
251
+ definition.instance_variables.merge!(defn.instance_variables)
252
+ definition.class_variables.merge!(defn.class_variables)
253
+ end
309
254
 
310
- mod_defn = build_instance(mod.name, no_self_types: true)
311
- merge_definition(src: mod_defn,
312
- dest: definition,
313
- subst: Substitution.build(mod_defn.type_params, mod.args))
255
+ one_ancestors.each_extended_module do |mod|
256
+ mod.args.each do |arg|
257
+ validate_type_presence(arg)
314
258
  end
315
259
 
316
- interface_methods = {}
317
- one_ancestors.each_extended_interface do |mod|
318
- mod.args.each do |arg|
319
- validate_type_presence(arg)
320
- end
321
-
322
- mod_defn = build_interface(mod.name)
323
- subst = Substitution.build(mod_defn.type_params, mod.args)
324
-
325
- mod_defn.methods.each do |name, method|
326
- if interface_methods.key?(name)
327
- src_member = mod.source
328
-
329
- raise unless src_member.is_a?(AST::Members::Extend)
330
-
331
- raise DuplicatedInterfaceMethodDefinitionError.new(
332
- type: self_type,
333
- method_name: name,
334
- member: src_member
335
- )
336
- end
260
+ subst = tapp_subst(mod.name, mod.args)
261
+ define_instance(definition, mod.name, subst)
262
+ end
337
263
 
338
- merge_method(type_name, interface_methods, name, method, subst, implemented_in: type_name)
339
- end
340
- end
264
+ all_interfaces = one_ancestors.each_extended_interface.flat_map do |interface|
265
+ other_interfaces = ancestor_builder.interface_ancestors(interface.name).ancestors #: Array[Definition::Ancestor::Instance]
266
+ other_interfaces = other_interfaces.select {|ancestor| ancestor.source }
267
+ [interface, *other_interfaces]
268
+ end
269
+ interface_methods = interface_methods(all_interfaces)
270
+ import_methods(definition, type_name, methods, interface_methods, Substitution.new, nil)
271
+
272
+ entry.decls.each do |d|
273
+ d.decl.members.each do |member|
274
+ case member
275
+ when AST::Members::AttrReader, AST::Members::AttrAccessor, AST::Members::AttrWriter
276
+ if member.kind == :singleton
277
+ ivar_name = case member.ivar_name
278
+ when false
279
+ nil
280
+ else
281
+ member.ivar_name || :"@#{member.name}"
282
+ end
341
283
 
342
- methods = method_builder.build_singleton(type_name)
343
- define_methods_singleton(definition, methods: methods, interface_methods: interface_methods)
344
-
345
- entry.decls.each do |d|
346
- d.decl.members.each do |member|
347
- case member
348
- when AST::Members::AttrReader, AST::Members::AttrAccessor, AST::Members::AttrWriter
349
- if member.kind == :singleton
350
- ivar_name = case member.ivar_name
351
- when false
352
- nil
353
- else
354
- member.ivar_name || :"@#{member.name}"
355
- end
356
-
357
- if ivar_name
358
- insert_variable(type_name, definition.instance_variables, name: ivar_name, type: member.type)
359
- end
284
+ if ivar_name
285
+ insert_variable(type_name, definition.instance_variables, name: ivar_name, type: member.type)
360
286
  end
287
+ end
361
288
 
362
- when AST::Members::ClassInstanceVariable
363
- insert_variable(type_name, definition.instance_variables, name: member.name, type: member.type)
289
+ when AST::Members::ClassInstanceVariable
290
+ insert_variable(type_name, definition.instance_variables, name: member.name, type: member.type)
364
291
 
365
- when AST::Members::ClassVariable
366
- insert_variable(type_name, definition.class_variables, name: member.name, type: member.type)
367
- end
292
+ when AST::Members::ClassVariable
293
+ insert_variable(type_name, definition.class_variables, name: member.name, type: member.type)
368
294
  end
369
295
  end
370
296
  end
@@ -373,108 +299,108 @@ module RBS
373
299
  end
374
300
 
375
301
  def build_singleton(type_name)
302
+ type_name = env.normalize_module_name(type_name)
303
+
376
304
  try_cache type_name, cache: singleton_cache do
377
305
  entry = env.class_decls[type_name] or raise "Unknown name for build_singleton: #{type_name}"
378
306
  ensure_namespace!(type_name.namespace, location: entry.decls[0].decl.location)
379
307
 
380
- case entry
381
- when Environment::ClassEntry, Environment::ModuleEntry
382
- ancestors = ancestor_builder.singleton_ancestors(type_name)
383
- self_type = Types::ClassSingleton.new(name: type_name, location: nil)
384
-
385
- Definition.new(type_name: type_name, entry: entry, self_type: self_type, ancestors: ancestors).tap do |definition|
386
- def0 = build_singleton0(type_name)
387
- subst = Substitution.new
388
-
389
- merge_definition(src: def0, dest: definition, subst: subst, keep_super: true)
390
-
391
- if entry.is_a?(Environment::ClassEntry)
392
- new_method = definition.methods[:new]
393
- if new_method.defs.all? {|d| d.defined_in == BuiltinNames::Class.name }
394
- alias_methods = definition.methods.each.with_object([]) do |entry, array|
395
- # @type var method: Definition::Method?
396
- name, method = entry
397
- while method
398
- if method.alias_of == new_method
399
- array << name
400
- break
401
- end
402
- method = method.alias_of
308
+ ancestors = ancestor_builder.singleton_ancestors(type_name)
309
+ self_type = Types::ClassSingleton.new(name: type_name, location: nil)
310
+
311
+ Definition.new(type_name: type_name, entry: entry, self_type: self_type, ancestors: ancestors).tap do |definition|
312
+ definition0 = build_singleton0(type_name)
313
+ definition.methods.merge!(definition0.methods)
314
+ definition.instance_variables.merge!(definition0.instance_variables)
315
+ definition.class_variables.merge!(definition0.class_variables)
316
+
317
+ if entry.is_a?(Environment::ClassEntry)
318
+ new_method = definition.methods[:new]
319
+
320
+ if new_method.defs.all? {|d| d.defined_in == BuiltinNames::Class.name }
321
+ # The method is _untyped new_.
322
+
323
+ alias_methods = definition.methods.each.with_object([]) do |entry, array|
324
+ # @type var method: Definition::Method?
325
+ name, method = entry
326
+ while method
327
+ if method.alias_of == new_method
328
+ array << name
329
+ break
403
330
  end
331
+ method = method.alias_of
404
332
  end
333
+ end
405
334
 
406
- # The method is _untyped new_.
407
-
408
- instance = build_instance(type_name)
409
- initialize = instance.methods[:initialize]
335
+ instance = build_instance(type_name)
336
+ initialize = instance.methods[:initialize]
410
337
 
411
- if initialize
412
- class_params = entry.type_params
338
+ if initialize
339
+ class_params = entry.type_params
413
340
 
414
- # Inject a virtual _typed new_.
415
- initialize_defs = initialize.defs
416
- typed_new = Definition::Method.new(
417
- super_method: new_method,
418
- defs: initialize_defs.map do |initialize_def|
419
- method_type = initialize_def.type
341
+ # Inject a virtual _typed new_.
342
+ initialize_defs = initialize.defs
343
+ typed_new = Definition::Method.new(
344
+ super_method: new_method,
345
+ defs: initialize_defs.map do |initialize_def|
346
+ method_type = initialize_def.type
420
347
 
421
- class_type_param_vars = Set.new(class_params.map(&:name))
422
- method_type_param_vars = Set.new(method_type.type_params.map(&:name))
348
+ class_type_param_vars = Set.new(class_params.map(&:name))
349
+ method_type_param_vars = Set.new(method_type.type_params.map(&:name))
423
350
 
424
- if class_type_param_vars.intersect?(method_type_param_vars)
425
- new_method_param_names = method_type.type_params.map do |method_param|
426
- if class_type_param_vars.include?(method_param.name)
427
- Types::Variable.fresh(method_param.name).name
428
- else
429
- method_param.name
430
- end
351
+ if class_type_param_vars.intersect?(method_type_param_vars)
352
+ new_method_param_names = method_type.type_params.map do |method_param|
353
+ if class_type_param_vars.include?(method_param.name)
354
+ Types::Variable.fresh(method_param.name).name
355
+ else
356
+ method_param.name
431
357
  end
358
+ end
432
359
 
433
- sub = Substitution.build(
434
- method_type.type_params.map(&:name),
435
- Types::Variable.build(new_method_param_names)
436
- )
360
+ sub = Substitution.build(
361
+ method_type.type_params.map(&:name),
362
+ Types::Variable.build(new_method_param_names)
363
+ )
437
364
 
438
- method_params = class_params + AST::TypeParam.rename(method_type.type_params, new_names: new_method_param_names)
439
- method_type = method_type
440
- .update(type_params: [])
441
- .sub(sub)
442
- .update(type_params: method_params)
443
- else
444
- method_type = method_type
445
- .update(type_params: class_params + method_type.type_params)
446
- end
365
+ method_params = class_params + AST::TypeParam.rename(method_type.type_params, new_names: new_method_param_names)
366
+ method_type = method_type
367
+ .update(type_params: [])
368
+ .sub(sub)
369
+ .update(type_params: method_params)
370
+ else
371
+ method_type = method_type
372
+ .update(type_params: class_params + method_type.type_params)
373
+ end
447
374
 
448
- method_type = method_type.update(
449
- type: method_type.type.with_return_type(
450
- Types::ClassInstance.new(
451
- name: type_name,
452
- args: entry.type_params.map {|param| Types::Variable.new(name: param.name, location: param.location) },
453
- location: nil
454
- )
375
+ method_type = method_type.update(
376
+ type: method_type.type.with_return_type(
377
+ Types::ClassInstance.new(
378
+ name: type_name,
379
+ args: entry.type_params.map {|param| Types::Variable.new(name: param.name, location: param.location) },
380
+ location: nil
455
381
  )
456
382
  )
383
+ )
457
384
 
458
- Definition::Method::TypeDef.new(
459
- type: method_type,
460
- member: initialize_def.member,
461
- defined_in: initialize_def.defined_in,
462
- implemented_in: initialize_def.implemented_in
463
- )
464
- end,
465
- accessibility: :public,
466
- annotations: [],
467
- alias_of: nil
468
- )
385
+ Definition::Method::TypeDef.new(
386
+ type: method_type,
387
+ member: initialize_def.member,
388
+ defined_in: initialize_def.defined_in,
389
+ implemented_in: initialize_def.implemented_in,
390
+ overload_annotations: initialize_def.overload_annotations
391
+ )
392
+ end,
393
+ accessibility: :public,
394
+ alias_of: nil
395
+ )
469
396
 
470
- definition.methods[:new] = typed_new
397
+ definition.methods[:new] = typed_new
471
398
 
472
- alias_methods.each do |alias_name|
473
- definition.methods[alias_name] = definition.methods[alias_name].update(
474
- alias_of: typed_new,
475
- defs: typed_new.defs
476
- )
477
- end
399
+ alias_methods.each do |alias_name|
400
+ definition.methods[alias_name] = definition.methods[alias_name].update(
401
+ alias_of: typed_new,
402
+ defs: typed_new.defs
403
+ )
478
404
  end
479
405
  end
480
406
  end
@@ -483,6 +409,26 @@ module RBS
483
409
  end
484
410
  end
485
411
 
412
+ def interface_methods(interface_ancestors)
413
+ interface_methods = {} #: interface_methods
414
+
415
+ interface_ancestors.each do |mod|
416
+ source =
417
+ case mod.source
418
+ when AST::Members::Include, AST::Members::Extend
419
+ mod.source
420
+ else
421
+ raise "Interface mixin must be include/extend: #{mod.source.inspect}"
422
+ end
423
+
424
+ methods = method_builder.build_interface(mod.name)
425
+
426
+ interface_methods[mod] = [methods, source]
427
+ end
428
+
429
+ interface_methods
430
+ end
431
+
486
432
  def validate_params_with(type_params, result:)
487
433
  type_params.each do |param|
488
434
  unless param.unchecked?
@@ -539,7 +485,7 @@ module RBS
539
485
 
540
486
  method_types = case original = defn.original
541
487
  when AST::Members::MethodDefinition
542
- original.types
488
+ original.overloads.map(&:method_type)
543
489
  when AST::Members::AttrWriter, AST::Members::AttrReader, AST::Members::AttrAccessor
544
490
  if defn.name.to_s.end_with?("=")
545
491
  [
@@ -597,267 +543,228 @@ module RBS
597
543
  )
598
544
  end
599
545
 
600
- def define_methods_instance(definition, methods:, interface_methods:)
601
- define_methods(
602
- definition,
603
- methods: methods,
604
- interface_methods: interface_methods,
605
- methods_with_self: nil,
606
- super_interface_method: false
607
- )
608
- end
546
+ def import_methods(definition, module_name, module_methods, interfaces_methods, subst, self_type_methods)
547
+ new_methods = {} #: Hash[Symbol, Definition::Method]
548
+ interface_method_duplicates = Set[] #: Set[Symbol]
609
549
 
610
- def define_methods_module_instance(definition, methods:, interface_methods:, module_self_methods:)
611
- define_methods(definition, methods: methods, interface_methods: interface_methods, methods_with_self: module_self_methods, super_interface_method: true)
612
- end
550
+ interfaces_methods.each do |interface, (methods, member)|
551
+ unless interface.args.empty?
552
+ methods.type.is_a?(Types::Interface) or raise
613
553
 
614
- def define_methods_singleton(definition, methods:, interface_methods:)
615
- define_methods(
616
- definition,
617
- methods: methods,
618
- interface_methods: interface_methods,
619
- methods_with_self: nil,
620
- super_interface_method: false
621
- )
622
- end
554
+ interface.args.each do |arg|
555
+ validate_type_presence(arg)
556
+ end
623
557
 
624
- def define_methods(definition, methods:, interface_methods:, methods_with_self:, super_interface_method:)
625
- methods.each do |method_def|
626
- method_name = method_def.name
627
- original = method_def.original
558
+ type_params = env.interface_decls.fetch(interface.name).decl.type_params
559
+ if s = AST::TypeParam.application(type_params, interface.args)
560
+ subst_ = subst + s
561
+ else
562
+ subst_ = subst
563
+ end
564
+ else
565
+ subst_ = subst
566
+ end
628
567
 
629
- if original.is_a?(AST::Members::Alias)
630
- existing_method = interface_methods[method_name] || definition.methods[method_name]
631
- original_method =
632
- interface_methods[original.old_name] ||
633
- methods_with_self&.[](original.old_name) ||
634
- definition.methods[original.old_name]
568
+ methods.each do |method|
569
+ if interface_method_duplicates.include?(method.name)
570
+ member.is_a?(AST::Members::Include) || member.is_a?(AST::Members::Extend) or raise
635
571
 
636
- unless original_method
637
- raise UnknownMethodAliasError.new(
638
- type_name: definition.type_name,
639
- original_name: original.old_name,
640
- aliased_name: original.new_name,
641
- location: original.location
572
+ raise DuplicatedInterfaceMethodDefinitionError.new(
573
+ type: definition.self_type,
574
+ method_name: method.name,
575
+ member: member
642
576
  )
643
577
  end
644
578
 
645
- method = Definition::Method.new(
646
- super_method: existing_method,
647
- defs: original_method.defs.map do |defn|
648
- defn.update(defined_in: definition.type_name, implemented_in: definition.type_name)
649
- end,
650
- accessibility: original_method.accessibility,
651
- alias_of: original_method
579
+ interface_method_duplicates << method.name
580
+ define_method(
581
+ new_methods,
582
+ definition,
583
+ method,
584
+ subst_,
585
+ nil,
586
+ defined_in: interface.name,
587
+ implemented_in: module_name
652
588
  )
653
- else
654
- if interface_methods.key?(method_name)
655
- interface_method = interface_methods[method_name]
656
-
657
- if original = method_def.original
658
- raise DuplicatedMethodDefinitionError.new(
659
- type: definition.self_type,
660
- method_name: method_name,
661
- members: [original]
662
- )
663
- end
664
-
665
- definition.methods[method_name] = interface_method
666
- end
589
+ end
590
+ end
667
591
 
668
- existing_method = definition.methods[method_name]
592
+ module_methods.each do |method|
593
+ define_method(
594
+ new_methods,
595
+ definition,
596
+ method,
597
+ subst,
598
+ self_type_methods,
599
+ defined_in: module_name,
600
+ implemented_in: module_name.interface? ? nil : module_name
601
+ )
602
+ end
669
603
 
670
- case original
671
- when AST::Members::MethodDefinition
672
- defs = original.types.map do |method_type|
673
- Definition::Method::TypeDef.new(
674
- type: method_type,
675
- member: original,
676
- defined_in: definition.type_name,
677
- implemented_in: definition.type_name
678
- )
679
- end
604
+ definition.methods.merge!(new_methods)
605
+ end
680
606
 
681
- # @type var accessibility: RBS::Definition::accessibility
682
- accessibility = if method_name == :initialize
683
- :private
684
- else
685
- method_def.accessibility
686
- end
687
-
688
- method = Definition::Method.new(
689
- super_method: existing_method,
690
- defs: defs,
691
- accessibility: accessibility,
692
- alias_of: nil
693
- )
607
+ def define_method(methods, definition, method, subst, self_type_methods, defined_in:, implemented_in: defined_in)
608
+ existing_method = methods[method.name] || definition.methods[method.name]
694
609
 
695
- when AST::Members::AttrReader, AST::Members::AttrWriter, AST::Members::AttrAccessor
696
- method_type = if method_name.to_s.end_with?("=")
697
- # setter
698
- MethodType.new(
699
- type_params: [],
700
- type: Types::Function.empty(original.type).update(
701
- required_positionals: [
702
- Types::Function::Param.new(type: original.type, name: original.name)
703
- ]
704
- ),
705
- block: nil,
706
- location: nil
707
- )
708
- else
709
- # getter
710
- MethodType.new(
711
- type_params: [],
712
- type: Types::Function.empty(original.type),
713
- block: nil,
714
- location: nil
715
- )
716
- end
717
- defs = [
718
- Definition::Method::TypeDef.new(
719
- type: method_type,
720
- member: original,
721
- defined_in: definition.type_name,
722
- implemented_in: definition.type_name
723
- )
724
- ]
610
+ case original = method.original
611
+ when AST::Members::Alias
612
+ original_method = methods[original.old_name] || definition.methods[original.old_name] || self_type_methods&.fetch(original.old_name, nil)
725
613
 
726
- method = Definition::Method.new(
727
- super_method: existing_method,
728
- defs: defs,
729
- accessibility: method_def.accessibility,
730
- alias_of: nil
731
- )
614
+ unless original_method
615
+ raise UnknownMethodAliasError.new(
616
+ type_name: definition.type_name,
617
+ original_name: original.old_name,
618
+ aliased_name: original.new_name,
619
+ location: original.location
620
+ )
621
+ end
732
622
 
733
- when nil
734
- unless definition.methods.key?(method_name)
735
- raise InvalidOverloadMethodError.new(
736
- type_name: definition.type_name,
737
- method_name: method_name,
738
- kind: :instance,
739
- members: method_def.overloads
740
- )
741
- end
623
+ method_definition = Definition::Method.new(
624
+ super_method: existing_method,
625
+ defs: original_method.defs.map do |defn|
626
+ defn.update(defined_in: defined_in, implemented_in: implemented_in)
627
+ end,
628
+ accessibility: original_method.accessibility,
629
+ alias_of: original_method
630
+ )
631
+ when AST::Members::MethodDefinition
632
+ if duplicated_method = methods[method.name]
633
+ raise DuplicatedMethodDefinitionError.new(
634
+ type: definition.self_type,
635
+ method_name: method.name,
636
+ members: [original, *duplicated_method.members]
637
+ )
638
+ end
742
639
 
743
- if !super_interface_method && existing_method.defs.any? {|defn| defn.defined_in.interface? }
744
- super_method = existing_method.super_method
745
- else
746
- super_method = existing_method
747
- end
640
+ defs = original.overloads.map do |overload|
641
+ Definition::Method::TypeDef.new(
642
+ type: subst.empty? ? overload.method_type : overload.method_type.sub(subst),
643
+ member: original,
644
+ defined_in: defined_in,
645
+ implemented_in: implemented_in,
646
+ overload_annotations: overload.annotations
647
+ )
648
+ end
748
649
 
749
- method = Definition::Method.new(
750
- super_method: super_method,
751
- defs: existing_method.defs.map do |defn|
752
- defn.update(implemented_in: definition.type_name)
753
- end,
754
- accessibility: existing_method.accessibility,
755
- alias_of: existing_method.alias_of
756
- )
650
+ # @type var accessibility: RBS::Definition::accessibility
651
+ accessibility =
652
+ if original.instance? && [:initialize, :initialize_copy, :initialize_clone, :initialize_dup, :respond_to_missing?].include?(method.name)
653
+ :private
654
+ else
655
+ method.accessibility
757
656
  end
657
+ # Skip setting up `super_method` if `implemented_in` is `nil`, that means the type doesn't have implementation.
658
+ # This typically happens if the type is an interface.
659
+ if implemented_in
660
+ super_method = existing_method
758
661
  end
759
662
 
760
- method_def.overloads.each do |overload|
761
- type_defs = overload.types.map do |method_type|
762
- Definition::Method::TypeDef.new(
763
- type: method_type,
764
- member: overload,
765
- defined_in: definition.type_name,
766
- implemented_in: definition.type_name
663
+ method_definition = Definition::Method.new(
664
+ super_method: super_method,
665
+ defs: defs,
666
+ accessibility: accessibility,
667
+ alias_of: nil
668
+ )
669
+ when AST::Members::AttrReader, AST::Members::AttrWriter, AST::Members::AttrAccessor
670
+ if duplicated_method = methods[method.name]
671
+ raise DuplicatedMethodDefinitionError.new(
672
+ type: definition.self_type,
673
+ method_name: method.name,
674
+ members: [*duplicated_method.members, original]
675
+ )
676
+ end
677
+
678
+ attr_type = original.type.sub(subst)
679
+ method_type =
680
+ if method.name.to_s.end_with?("=")
681
+ # setter
682
+ MethodType.new(
683
+ type_params: [],
684
+ type: Types::Function.empty(attr_type).update(
685
+ required_positionals: [
686
+ Types::Function::Param.new(type: attr_type, name: original.name)
687
+ ]
688
+ ),
689
+ block: nil,
690
+ location: original.location
691
+ )
692
+ else
693
+ # getter
694
+ MethodType.new(
695
+ type_params: [],
696
+ type: Types::Function.empty(attr_type),
697
+ block: nil,
698
+ location: original.location
767
699
  )
768
700
  end
769
701
 
770
- method.defs.unshift(*type_defs)
702
+ if implemented_in
703
+ super_method = existing_method
771
704
  end
772
705
 
773
- definition.methods[method_name] = method
774
- end
775
-
776
- interface_methods.each do |name, method|
777
- unless methods.methods.key?(name)
778
- merge_method(definition.type_name, definition.methods, name, method, Substitution.new)
706
+ method_definition = Definition::Method.new(
707
+ super_method: super_method,
708
+ defs: [
709
+ Definition::Method::TypeDef.new(
710
+ type: method_type,
711
+ member: original,
712
+ defined_in: defined_in,
713
+ implemented_in: implemented_in
714
+ )
715
+ ],
716
+ accessibility: method.accessibility,
717
+ alias_of: nil
718
+ )
719
+ when nil
720
+ # Overloading method definition only
721
+
722
+ case
723
+ when methods.key?(method.name)
724
+ # The method is defined in an interface
725
+ super_method = methods[method.name].super_method
726
+ when definition.methods.key?(method.name)
727
+ # The method is defined in the super class
728
+ super_method = existing_method
729
+ else
730
+ # Cannot find any non-overloading method
731
+ raise InvalidOverloadMethodError.new(
732
+ type_name: definition.type_name,
733
+ method_name: method.name,
734
+ kind: :instance,
735
+ members: method.overloads
736
+ )
779
737
  end
780
- end
781
- end
782
-
783
- def merge_definition(src:, dest:, subst:, implemented_in: :keep, keep_super: false)
784
- src.methods.each do |name, method|
785
- merge_method(dest.type_name, dest.methods, name, method, subst, implemented_in: implemented_in, keep_super: keep_super)
786
- end
787
738
 
788
- src.instance_variables.each do |name, variable|
789
- merge_variable(dest.instance_variables, name, variable, subst, keep_super: keep_super)
790
- end
791
-
792
- src.class_variables.each do |name, variable|
793
- merge_variable(dest.class_variables, name, variable, subst, keep_super: keep_super)
739
+ method_definition = Definition::Method.new(
740
+ super_method: super_method,
741
+ defs: existing_method.defs.map do |defn|
742
+ defn.update(implemented_in: implemented_in)
743
+ end,
744
+ accessibility: existing_method.accessibility,
745
+ alias_of: existing_method.alias_of
746
+ )
794
747
  end
795
- end
796
-
797
- def merge_variable(variables, name, variable, sub, keep_super: false)
798
- super_variable = variables[name]
799
748
 
800
- variables[name] = Definition::Variable.new(
801
- parent_variable: keep_super ? variable.parent_variable : super_variable,
802
- type: sub.empty? ? variable.type : variable.type.sub(sub),
803
- declared_in: variable.declared_in
804
- )
805
- end
806
-
807
- def merge_method(type_name, methods, name, method, sub, implemented_in: :keep, keep_super: false)
808
- if sub.empty? && implemented_in == :keep && keep_super
809
- methods[name] = method
810
- else
811
- if sub.empty? && implemented_in == :keep
812
- defs = method.defs
813
- else
814
- defs = method.defs.map do |defn|
815
- defn.update(
816
- type: sub.empty? ? defn.type : defn.type.sub(sub),
817
- implemented_in: case implemented_in
818
- when :keep
819
- defn.implemented_in
820
- when nil
821
- nil
822
- else
823
- implemented_in
824
- end
825
- )
826
- end
749
+ method.overloads.each do |overloading_def|
750
+ overloading_def.overloads.reverse_each do |overload|
751
+ type_def = Definition::Method::TypeDef.new(
752
+ type: subst.empty? ? overload.method_type : overload.method_type.sub(subst),
753
+ member: overloading_def,
754
+ defined_in: defined_in,
755
+ implemented_in: implemented_in,
756
+ overload_annotations: overload.annotations
757
+ )
827
758
 
828
- defs = method.defs.map do |defn|
829
- defn.update(
830
- type: sub.empty? ? defn.type : defn.type.sub(sub),
831
- implemented_in: case implemented_in
832
- when :keep
833
- defn.implemented_in
834
- when nil
835
- nil
836
- else
837
- implemented_in
838
- end
839
- )
840
- end
759
+ method_definition.defs.unshift(type_def)
841
760
  end
842
-
843
- super_method = methods[name]
844
-
845
- methods[name] = Definition::Method.new(
846
- super_method: keep_super ? method.super_method : super_method,
847
- accessibility: method.accessibility,
848
- defs: defs,
849
- alias_of: method.alias_of
850
- )
851
761
  end
852
- end
853
762
 
854
- def try_cache(type_name, cache:, key: nil)
855
- # @type var cc: Hash[untyped, Definition | nil]
856
- # @type var key: untyped
857
- key ||= type_name
858
- cc = _ = cache
763
+ methods[method.name] = method_definition
764
+ end
859
765
 
860
- cc[key] ||= yield
766
+ def try_cache(type_name, cache:)
767
+ cache[type_name] ||= yield
861
768
  end
862
769
 
863
770
  def expand_alias(type_name)
@@ -865,13 +772,15 @@ module RBS
865
772
  end
866
773
 
867
774
  def expand_alias1(type_name)
868
- entry = env.alias_decls[type_name] or raise "Unknown alias name: #{type_name}"
775
+ type_name = env.normalize_type_name(type_name)
776
+ entry = env.type_alias_decls[type_name] or raise "Unknown alias name: #{type_name}"
869
777
  as = entry.decl.type_params.each.map { Types::Bases::Any.new(location: nil) }
870
778
  expand_alias2(type_name, as)
871
779
  end
872
780
 
873
781
  def expand_alias2(type_name, args)
874
- entry = env.alias_decls[type_name] or raise "Unknown alias name: #{type_name}"
782
+ type_name = env.normalize_type_name(type_name)
783
+ entry = env.type_alias_decls[type_name] or raise "Unknown alias name: #{type_name}"
875
784
 
876
785
  ensure_namespace!(type_name.namespace, location: entry.decl.location)
877
786
  params = entry.decl.type_params.each.map(&:name)
@@ -903,8 +812,7 @@ module RBS
903
812
  builder.interface_cache.merge!(interface_cache)
904
813
 
905
814
  except.each do |name|
906
- builder.instance_cache.delete([name, true])
907
- builder.instance_cache.delete([name, false])
815
+ builder.instance_cache.delete(name)
908
816
  builder.singleton_cache.delete(name)
909
817
  builder.singleton0_cache.delete(name)
910
818
  builder.interface_cache.delete(name)
@@ -924,11 +832,8 @@ module RBS
924
832
  end
925
833
 
926
834
  def validate_type_name(name, location)
927
- name = name.absolute!
928
-
929
- return if name.class? && env.class_decls.key?(name)
930
- return if name.interface? && env.interface_decls.key?(name)
931
- return if name.alias? && env.alias_decls.key?(name)
835
+ name = name.absolute! unless name.absolute?
836
+ return if env.type_name?(env.normalize_type_name(name))
932
837
 
933
838
  raise NoTypeFoundError.new(type_name: name, location: location)
934
839
  end