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
data/core/struct.rbs CHANGED
@@ -42,99 +42,80 @@
42
42
  #
43
43
  # First, what's elsewhere. Class Struct:
44
44
  #
45
- # * Inherits from [class
46
- # Object](Object.html#class-Object-label-What-27s+Here).
47
- # * Includes [module
48
- # Enumerable](Enumerable.html#module-Enumerable-label-What-27s+Here), which
45
+ # * Inherits from [class Object](rdoc-ref:Object@What-27s+Here).
46
+ # * Includes [module Enumerable](rdoc-ref:Enumerable@What-27s+Here), which
49
47
  # provides dozens of additional methods.
50
48
  #
49
+ # See also Data, which is a somewhat similar, but stricter concept for defining
50
+ # immutable value objects.
51
51
  #
52
52
  # Here, class Struct provides methods that are useful for:
53
53
  #
54
54
  # * [Creating a Struct
55
- # Subclass](#class-Struct-label-Methods+for+Creating+a+Struct+Subclass)
56
- # * [Querying](#class-Struct-label-Methods+for+Querying)
57
- # * [Comparing](#class-Struct-label-Methods+for+Comparing)
58
- # * [Fetching](#class-Struct-label-Methods+for+Fetching)
59
- # * [Assigning](#class-Struct-label-Methods+for+Assigning)
60
- # * [Iterating](#class-Struct-label-Methods+for+Iterating)
61
- # * [Converting](#class-Struct-label-Methods+for+Converting)
62
- #
55
+ # Subclass](rdoc-ref:Struct@Methods+for+Creating+a+Struct+Subclass)
56
+ # * [Querying](rdoc-ref:Struct@Methods+for+Querying)
57
+ # * [Comparing](rdoc-ref:Struct@Methods+for+Comparing)
58
+ # * [Fetching](rdoc-ref:Struct@Methods+for+Fetching)
59
+ # * [Assigning](rdoc-ref:Struct@Methods+for+Assigning)
60
+ # * [Iterating](rdoc-ref:Struct@Methods+for+Iterating)
61
+ # * [Converting](rdoc-ref:Struct@Methods+for+Converting)
63
62
  #
64
63
  # ### Methods for Creating a Struct Subclass
65
64
  #
66
- # ::new
67
- # : Returns a new subclass of Struct.
68
- #
65
+ # * ::new: Returns a new subclass of Struct.
69
66
  #
70
67
  # ### Methods for Querying
71
68
  #
72
- # #hash
73
- # : Returns the integer hash code.
74
- # #length, #size
75
- # : Returns the number of members.
76
- #
69
+ # * #hash: Returns the integer hash code.
70
+ # * #size (aliased as #length): Returns the number of members.
77
71
  #
78
72
  # ### Methods for Comparing
79
73
  #
80
- # [#==](#method-i-3D-3D)
81
- # : Returns whether a given object is equal to `self`, using `==` to compare
82
- # member values.
83
- # #eql?
84
- # : Returns whether a given object is equal to `self`, using `eql?` to compare
85
- # member values.
86
- #
74
+ # * #==: Returns whether a given object is equal to `self`, using `==` to
75
+ # compare member values.
76
+ # * #eql?: Returns whether a given object is equal to `self`, using `eql?` to
77
+ # compare member values.
87
78
  #
88
79
  # ### Methods for Fetching
89
80
  #
90
- # #[]
91
- # : Returns the value associated with a given member name.
92
- # #to_a, #values, #deconstruct
93
- # : Returns the member values in `self` as an array.
94
- # #deconstruct_keys
95
- # : Returns a hash of the name/value pairs for given member names.
96
- # #dig
97
- # : Returns the object in nested objects that is specified by a given member
98
- # name and additional arguments.
99
- # #members
100
- # : Returns an array of the member names.
101
- # #select, #filter
102
- # : Returns an array of member values from `self`, as selected by the given
103
- # block.
104
- # #values_at
105
- # : Returns an array containing values for given member names.
106
- #
81
+ # * #[]: Returns the value associated with a given member name.
82
+ # * #to_a (aliased as #values, #deconstruct): Returns the member values in
83
+ # `self` as an array.
84
+ # * #deconstruct_keys: Returns a hash of the name/value pairs for given member
85
+ # names.
86
+ # * #dig: Returns the object in nested objects that is specified by a given
87
+ # member name and additional arguments.
88
+ # * #members: Returns an array of the member names.
89
+ # * #select (aliased as #filter): Returns an array of member values from
90
+ # `self`, as selected by the given block.
91
+ # * #values_at: Returns an array containing values for given member names.
107
92
  #
108
93
  # ### Methods for Assigning
109
94
  #
110
- # #[]=
111
- # : Assigns a given value to a given member name.
112
- #
95
+ # * #[]=: Assigns a given value to a given member name.
113
96
  #
114
97
  # ### Methods for Iterating
115
98
  #
116
- # #each
117
- # : Calls a given block with each member name.
118
- # #each_pair
119
- # : Calls a given block with each member name/value pair.
120
- #
99
+ # * #each: Calls a given block with each member name.
100
+ # * #each_pair: Calls a given block with each member name/value pair.
121
101
  #
122
102
  # ### Methods for Converting
123
103
  #
124
- # #inspect, #to_s
125
- # : Returns a string representation of `self`.
126
- # #to_h
127
- # : Returns a hash of the member name/value pairs in `self`.
104
+ # * #inspect (aliased as #to_s): Returns a string representation of `self`.
105
+ # * #to_h: Returns a hash of the member name/value pairs in `self`.
128
106
  #
129
- class Struct[Elem] < Object
130
- include Enumerable[Elem?]
107
+ class Struct[Elem]
108
+ include Enumerable[Elem]
131
109
 
132
- type attribute_name = Symbol | String
110
+ # The types that can be used when "indexing" into a `Struct` via `[]`, `[]=`, `dig`, and
111
+ # `deconstruct_keys`.
112
+ #
113
+ type index = String | Symbol | int
133
114
 
134
115
  # <!--
135
116
  # rdoc-file=struct.c
136
- # - Struct.new(*member_names, keyword_init: false){|Struct_subclass| ... } -> Struct_subclass
137
- # - Struct.new(class_name, *member_names, keyword_init: false){|Struct_subclass| ... } -> Struct_subclass
117
+ # - Struct.new(*member_names, keyword_init: nil){|Struct_subclass| ... } -> Struct_subclass
118
+ # - Struct.new(class_name, *member_names, keyword_init: nil){|Struct_subclass| ... } -> Struct_subclass
138
119
  # - Struct_subclass.new(*member_names) -> Struct_subclass_instance
139
120
  # - Struct_subclass.new(**member_names) -> Struct_subclass_instance
140
121
  # -->
@@ -142,9 +123,7 @@ class Struct[Elem] < Object
142
123
  #
143
124
  # * May be anonymous, or may have the name given by `class_name`.
144
125
  # * May have members as given by `member_names`.
145
- # * May have initialization via ordinary arguments (the default) or via
146
- # keyword arguments (if `keyword_init: true` is given).
147
- #
126
+ # * May have initialization via ordinary arguments, or via keyword arguments
148
127
  #
149
128
  # The new subclass has its own method `::new`; thus:
150
129
  #
@@ -212,7 +191,11 @@ class Struct[Elem] < Object
212
191
  # Foo.new(0, 1) # => #<struct Struct::Foo foo=0, bar=1>
213
192
  # Foo.new(0, 1, 2) # Raises ArgumentError: struct size differs
214
193
  #
215
- # Method `::[]` is an alias for method `::new`.
194
+ # # Initialization with keyword arguments:
195
+ # Foo.new(foo: 0) # => #<struct Struct::Foo foo=0, bar=nil>
196
+ # Foo.new(foo: 0, bar: 1) # => #<struct Struct::Foo foo=0, bar=1>
197
+ # Foo.new(foo: 0, bar: 1, baz: 2)
198
+ # # Raises ArgumentError: unknown keywords: baz
216
199
  #
217
200
  # * Method `:inspect` returns a string representation of the subclass:
218
201
  #
@@ -223,23 +206,218 @@ class Struct[Elem] < Object
223
206
  #
224
207
  # Foo.members # => [:foo, :bar]
225
208
  #
226
- #
227
209
  # **Keyword Argument**
228
210
  #
229
- # By default, the arguments for initializing an instance of the new subclass are
230
- # ordinary arguments (not keyword arguments). With optional keyword argument
231
- # `keyword_init: true`, the new subclass is initialized with keyword arguments:
211
+ # By default, the arguments for initializing an instance of the new subclass can
212
+ # be both positional and keyword arguments.
213
+ #
214
+ # Optional keyword argument `keyword_init:` allows to force only one type of
215
+ # arguments to be accepted:
216
+ #
217
+ # KeywordsOnly = Struct.new(:foo, :bar, keyword_init: true)
218
+ # KeywordsOnly.new(bar: 1, foo: 0)
219
+ # # => #<struct KeywordsOnly foo=0, bar=1>
220
+ # KeywordsOnly.new(0, 1)
221
+ # # Raises ArgumentError: wrong number of arguments
222
+ #
223
+ # PositionalOnly = Struct.new(:foo, :bar, keyword_init: false)
224
+ # PositionalOnly.new(0, 1)
225
+ # # => #<struct PositionalOnly foo=0, bar=1>
226
+ # PositionalOnly.new(bar: 1, foo: 0)
227
+ # # => #<struct PositionalOnly foo={:foo=>1, :bar=>2}, bar=nil>
228
+ # # Note that no error is raised, but arguments treated as one hash value
229
+ #
230
+ # # Same as not providing keyword_init:
231
+ # Any = Struct.new(:foo, :bar, keyword_init: nil)
232
+ # Any.new(foo: 1, bar: 2)
233
+ # # => #<struct Any foo=1, bar=2>
234
+ # Any.new(1, 2)
235
+ # # => #<struct Any foo=1, bar=2>
236
+ #
237
+ def self.new: (string? classname, *interned fields, ?keyword_init: boolish?) ?{ (singleton(Struct)) [self: singleton(Struct)] -> void } -> untyped
238
+ | (Symbol field1, *interned fields, ?keyword_init: boolish?) ?{ (singleton(Struct)) [self: singleton(Struct)] -> void } -> untyped
239
+
240
+ # <!--
241
+ # rdoc-file=struct.c
242
+ # - StructClass::members -> array_of_symbols
243
+ # -->
244
+ # Returns the member names of the Struct descendant as an array:
232
245
  #
233
- # # Without keyword_init: true.
234
- # Foo = Struct.new('Foo', :foo, :bar)
235
- # Foo # => Struct::Foo
236
- # Foo.new(0, 1) # => #<struct Struct::Foo foo=0, bar=1>
237
- # # With keyword_init: true.
238
- # Bar = Struct.new(:foo, :bar, keyword_init: true)
239
- # Bar # => # => Bar(keyword_init: true)
240
- # Bar.new(bar: 1, foo: 0) # => #<struct Bar foo=0, bar=1>
241
- #
242
- def initialize: (attribute_name, *attribute_name, ?keyword_init: boolish) ?{ () -> void } -> void
246
+ # Customer = Struct.new(:name, :address, :zip)
247
+ # Customer.members # => [:name, :address, :zip]
248
+ #
249
+ def self.members: () -> Array[Symbol]
250
+
251
+ # <!--
252
+ # rdoc-file=struct.c
253
+ # - StructClass::keyword_init? -> true or falsy value
254
+ # -->
255
+ # Returns `true` if the class was initialized with `keyword_init: true`.
256
+ # Otherwise returns `nil` or `false`.
257
+ #
258
+ # Examples:
259
+ # Foo = Struct.new(:a)
260
+ # Foo.keyword_init? # => nil
261
+ # Bar = Struct.new(:a, keyword_init: true)
262
+ # Bar.keyword_init? # => true
263
+ # Baz = Struct.new(:a, keyword_init: false)
264
+ # Baz.keyword_init? # => false
265
+ #
266
+ def self.keyword_init?: () -> bool?
267
+
268
+ # <!--
269
+ # rdoc-file=struct.c
270
+ # - self == other -> true or false
271
+ # -->
272
+ # Returns `true` if and only if the following are true; otherwise returns
273
+ # `false`:
274
+ #
275
+ # * `other.class == self.class`.
276
+ # * For each member name `name`, `other.name == self.name`.
277
+ #
278
+ # Examples:
279
+ #
280
+ # Customer = Struct.new(:name, :address, :zip)
281
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
282
+ # joe_jr = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
283
+ # joe_jr == joe # => true
284
+ # joe_jr[:name] = 'Joe Smith, Jr.'
285
+ # # => "Joe Smith, Jr."
286
+ # joe_jr == joe # => false
287
+ #
288
+ def ==: (untyped other) -> bool
289
+
290
+ # <!--
291
+ # rdoc-file=struct.c
292
+ # - eql?(other) -> true or false
293
+ # -->
294
+ # Returns `true` if and only if the following are true; otherwise returns
295
+ # `false`:
296
+ #
297
+ # * `other.class == self.class`.
298
+ # * For each member name `name`, `other.name.eql?(self.name)`.
299
+ #
300
+ # Customer = Struct.new(:name, :address, :zip)
301
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
302
+ # joe_jr = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
303
+ # joe_jr.eql?(joe) # => true
304
+ # joe_jr[:name] = 'Joe Smith, Jr.'
305
+ # joe_jr.eql?(joe) # => false
306
+ #
307
+ # Related: Object#==.
308
+ #
309
+ def eql?: (untyped other) -> bool
310
+
311
+ # <!--
312
+ # rdoc-file=struct.c
313
+ # - hash -> integer
314
+ # -->
315
+ # Returns the integer hash value for `self`.
316
+ #
317
+ # Two structs of the same class and with the same content will have the same
318
+ # hash code (and will compare using Struct#eql?):
319
+ #
320
+ # Customer = Struct.new(:name, :address, :zip)
321
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
322
+ # joe_jr = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
323
+ # joe.hash == joe_jr.hash # => true
324
+ # joe_jr[:name] = 'Joe Smith, Jr.'
325
+ # joe.hash == joe_jr.hash # => false
326
+ #
327
+ # Related: Object#hash.
328
+ #
329
+ def hash: () -> Integer
330
+
331
+ # <!--
332
+ # rdoc-file=struct.c
333
+ # - inspect -> string
334
+ # -->
335
+ # Returns a string representation of `self`:
336
+ #
337
+ # Customer = Struct.new(:name, :address, :zip) # => Customer
338
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
339
+ # joe.inspect # => "#<struct Customer name=\"Joe Smith\", address=\"123 Maple, Anytown NC\", zip=12345>"
340
+ #
341
+ def inspect: () -> String
342
+
343
+ # <!-- rdoc-file=struct.c -->
344
+ # Returns a string representation of `self`:
345
+ #
346
+ # Customer = Struct.new(:name, :address, :zip) # => Customer
347
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
348
+ # joe.inspect # => "#<struct Customer name=\"Joe Smith\", address=\"123 Maple, Anytown NC\", zip=12345>"
349
+ #
350
+ alias to_s inspect
351
+
352
+ # <!--
353
+ # rdoc-file=struct.c
354
+ # - to_a -> array
355
+ # -->
356
+ # Returns the values in `self` as an array:
357
+ #
358
+ # Customer = Struct.new(:name, :address, :zip)
359
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
360
+ # joe.to_a # => ["Joe Smith", "123 Maple, Anytown NC", 12345]
361
+ #
362
+ # Related: #members.
363
+ #
364
+ def to_a: () -> Array[Elem]
365
+
366
+ # <!--
367
+ # rdoc-file=struct.c
368
+ # - to_h -> hash
369
+ # - to_h {|name, value| ... } -> hash
370
+ # -->
371
+ # Returns a hash containing the name and value for each member:
372
+ #
373
+ # Customer = Struct.new(:name, :address, :zip)
374
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
375
+ # h = joe.to_h
376
+ # h # => {:name=>"Joe Smith", :address=>"123 Maple, Anytown NC", :zip=>12345}
377
+ #
378
+ # If a block is given, it is called with each name/value pair; the block should
379
+ # return a 2-element array whose elements will become a key/value pair in the
380
+ # returned hash:
381
+ #
382
+ # h = joe.to_h{|name, value| [name.upcase, value.to_s.upcase]}
383
+ # h # => {:NAME=>"JOE SMITH", :ADDRESS=>"123 MAPLE, ANYTOWN NC", :ZIP=>"12345"}
384
+ #
385
+ # Raises ArgumentError if the block returns an inappropriate value.
386
+ #
387
+ def to_h: () -> Hash[Symbol, Elem]
388
+ | [K, V] () { (Symbol key, Elem value) -> [K, V] } -> Hash[K, V]
389
+
390
+ # <!-- rdoc-file=struct.c -->
391
+ # Returns the values in `self` as an array:
392
+ #
393
+ # Customer = Struct.new(:name, :address, :zip)
394
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
395
+ # joe.to_a # => ["Joe Smith", "123 Maple, Anytown NC", 12345]
396
+ #
397
+ # Related: #members.
398
+ #
399
+ alias values to_a
400
+
401
+ # <!--
402
+ # rdoc-file=struct.c
403
+ # - size -> integer
404
+ # -->
405
+ # Returns the number of members.
406
+ #
407
+ # Customer = Struct.new(:name, :address, :zip)
408
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
409
+ # joe.size #=> 3
410
+ #
411
+ def size: () -> Integer
412
+
413
+ # <!-- rdoc-file=struct.c -->
414
+ # Returns the number of members.
415
+ #
416
+ # Customer = Struct.new(:name, :address, :zip)
417
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
418
+ # joe.size #=> 3
419
+ #
420
+ alias length size
243
421
 
244
422
  # <!--
245
423
  # rdoc-file=struct.c
@@ -262,34 +440,228 @@ class Struct[Elem] < Object
262
440
  #
263
441
  # Related: #each_pair.
264
442
  #
265
- def each: () -> ::Enumerator[Elem?, self]
266
- | () { (Elem? item) -> void } -> self
443
+ def each: () -> Enumerator[Elem, self]
444
+ | () { (Elem value) -> void } -> self
267
445
 
268
446
  # <!--
269
447
  # rdoc-file=struct.c
270
- # - StructClass::members -> array_of_symbols
448
+ # - each_pair {|(name, value)| ... } -> self
449
+ # - each_pair -> enumerator
271
450
  # -->
272
- # Returns the member names of the Struct descendant as an array:
451
+ # Calls the given block with each member name/value pair; returns `self`:
452
+ #
453
+ # Customer = Struct.new(:name, :address, :zip) # => Customer
454
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
455
+ # joe.each_pair {|(name, value)| p "#{name} => #{value}" }
456
+ #
457
+ # Output:
458
+ #
459
+ # "name => Joe Smith"
460
+ # "address => 123 Maple, Anytown NC"
461
+ # "zip => 12345"
462
+ #
463
+ # Returns an Enumerator if no block is given.
464
+ #
465
+ # Related: #each.
466
+ #
467
+ def each_pair: () -> Enumerator[[Symbol, Elem], self]
468
+ | () { ([Symbol, Elem] key_value) -> void } -> self
469
+
470
+ # <!--
471
+ # rdoc-file=struct.c
472
+ # - struct[name] -> object
473
+ # - struct[n] -> object
474
+ # -->
475
+ # Returns a value from `self`.
476
+ #
477
+ # With symbol or string argument `name` given, returns the value for the named
478
+ # member:
273
479
  #
274
480
  # Customer = Struct.new(:name, :address, :zip)
275
- # Customer.members # => [:name, :address, :zip]
481
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
482
+ # joe[:zip] # => 12345
483
+ #
484
+ # Raises NameError if `name` is not the name of a member.
276
485
  #
277
- def self.members: () -> ::Array[Symbol]
486
+ # With integer argument `n` given, returns `self.values[n]` if `n` is in range;
487
+ # see Array@Array+Indexes:
488
+ #
489
+ # joe[2] # => 12345
490
+ # joe[-2] # => "123 Maple, Anytown NC"
491
+ #
492
+ # Raises IndexError if `n` is out of range.
493
+ #
494
+ def []: (index name_or_position) -> Elem
278
495
 
279
496
  # <!--
280
497
  # rdoc-file=struct.c
281
- # - StructClass::keyword_init? -> true or falsy value
498
+ # - struct[name] = value -> value
499
+ # - struct[n] = value -> value
282
500
  # -->
283
- # Returns `true` if the class was initialized with `keyword_init: true`.
284
- # Otherwise returns `nil` or `false`.
501
+ # Assigns a value to a member.
502
+ #
503
+ # With symbol or string argument `name` given, assigns the given `value` to the
504
+ # named member; returns `value`:
505
+ #
506
+ # Customer = Struct.new(:name, :address, :zip)
507
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
508
+ # joe[:zip] = 54321 # => 54321
509
+ # joe # => #<struct Customer name="Joe Smith", address="123 Maple, Anytown NC", zip=54321>
510
+ #
511
+ # Raises NameError if `name` is not the name of a member.
512
+ #
513
+ # With integer argument `n` given, assigns the given `value` to the `n`-th
514
+ # member if `n` is in range; see Array@Array+Indexes:
515
+ #
516
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
517
+ # joe[2] = 54321 # => 54321
518
+ # joe[-3] = 'Joseph Smith' # => "Joseph Smith"
519
+ # joe # => #<struct Customer name="Joseph Smith", address="123 Maple, Anytown NC", zip=54321>
520
+ #
521
+ # Raises IndexError if `n` is out of range.
522
+ #
523
+ def []=: (index name_or_position, Elem value) -> Elem
524
+
525
+ # <!--
526
+ # rdoc-file=struct.c
527
+ # - select {|value| ... } -> array
528
+ # - select -> enumerator
529
+ # -->
530
+ # With a block given, returns an array of values from `self` for which the block
531
+ # returns a truthy value:
532
+ #
533
+ # Customer = Struct.new(:name, :address, :zip)
534
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
535
+ # a = joe.select {|value| value.is_a?(String) }
536
+ # a # => ["Joe Smith", "123 Maple, Anytown NC"]
537
+ # a = joe.select {|value| value.is_a?(Integer) }
538
+ # a # => [12345]
539
+ #
540
+ # With no block given, returns an Enumerator.
541
+ #
542
+ def select: () -> Enumerator[Elem, Array[Elem]]
543
+ | () { (Elem value) -> boolish } -> Array[Elem]
544
+
545
+ # <!-- rdoc-file=struct.c -->
546
+ # With a block given, returns an array of values from `self` for which the block
547
+ # returns a truthy value:
548
+ #
549
+ # Customer = Struct.new(:name, :address, :zip)
550
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
551
+ # a = joe.select {|value| value.is_a?(String) }
552
+ # a # => ["Joe Smith", "123 Maple, Anytown NC"]
553
+ # a = joe.select {|value| value.is_a?(Integer) }
554
+ # a # => [12345]
555
+ #
556
+ # With no block given, returns an Enumerator.
557
+ #
558
+ alias filter select
559
+
560
+ # <!--
561
+ # rdoc-file=struct.c
562
+ # - values_at(*integers) -> array
563
+ # - values_at(integer_range) -> array
564
+ # -->
565
+ # Returns an array of values from `self`.
566
+ #
567
+ # With integer arguments `integers` given, returns an array containing each
568
+ # value given by one of `integers`:
569
+ #
570
+ # Customer = Struct.new(:name, :address, :zip)
571
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
572
+ # joe.values_at(0, 2) # => ["Joe Smith", 12345]
573
+ # joe.values_at(2, 0) # => [12345, "Joe Smith"]
574
+ # joe.values_at(2, 1, 0) # => [12345, "123 Maple, Anytown NC", "Joe Smith"]
575
+ # joe.values_at(0, -3) # => ["Joe Smith", "Joe Smith"]
576
+ #
577
+ # Raises IndexError if any of `integers` is out of range; see
578
+ # Array@Array+Indexes.
579
+ #
580
+ # With integer range argument `integer_range` given, returns an array containing
581
+ # each value given by the elements of the range; fills with `nil` values for
582
+ # range elements larger than the structure:
583
+ #
584
+ # joe.values_at(0..2)
585
+ # # => ["Joe Smith", "123 Maple, Anytown NC", 12345]
586
+ # joe.values_at(-3..-1)
587
+ # # => ["Joe Smith", "123 Maple, Anytown NC", 12345]
588
+ # joe.values_at(1..4) # => ["123 Maple, Anytown NC", 12345, nil, nil]
589
+ #
590
+ # Raises RangeError if any element of the range is negative and out of range;
591
+ # see Array@Array+Indexes.
592
+ #
593
+ def values_at: (*int | range[int?] positions) -> Array[Elem]
594
+
595
+ # <!--
596
+ # rdoc-file=struct.c
597
+ # - members -> array_of_symbols
598
+ # -->
599
+ # Returns the member names from `self` as an array:
600
+ #
601
+ # Customer = Struct.new(:name, :address, :zip)
602
+ # Customer.new.members # => [:name, :address, :zip]
603
+ #
604
+ # Related: #to_a.
605
+ #
606
+ def members: () -> Array[Symbol]
607
+
608
+ # <!--
609
+ # rdoc-file=struct.c
610
+ # - dig(name, *identifiers) -> object
611
+ # - dig(n, *identifiers) -> object
612
+ # -->
613
+ # Finds and returns an object among nested objects. The nested objects may be
614
+ # instances of various classes. See [Dig Methods](rdoc-ref:dig_methods.rdoc).
615
+ #
616
+ # Given symbol or string argument `name`, returns the object that is specified
617
+ # by `name` and `identifiers`:
285
618
  #
286
- # Examples:
287
619
  # Foo = Struct.new(:a)
288
- # Foo.keyword_init? # => nil
289
- # Bar = Struct.new(:a, keyword_init: true)
290
- # Bar.keyword_init? # => true
291
- # Baz = Struct.new(:a, keyword_init: false)
292
- # Baz.keyword_init? # => false
620
+ # f = Foo.new(Foo.new({b: [1, 2, 3]}))
621
+ # f.dig(:a) # => #<struct Foo a={:b=>[1, 2, 3]}>
622
+ # f.dig(:a, :a) # => {:b=>[1, 2, 3]}
623
+ # f.dig(:a, :a, :b) # => [1, 2, 3]
624
+ # f.dig(:a, :a, :b, 0) # => 1
625
+ # f.dig(:b, 0) # => nil
626
+ #
627
+ # Given integer argument `n`, returns the object that is specified by `n` and
628
+ # `identifiers`:
629
+ #
630
+ # f.dig(0) # => #<struct Foo a={:b=>[1, 2, 3]}>
631
+ # f.dig(0, 0) # => {:b=>[1, 2, 3]}
632
+ # f.dig(0, 0, :b) # => [1, 2, 3]
633
+ # f.dig(0, 0, :b, 0) # => 1
634
+ # f.dig(:b, 0) # => nil
635
+ #
636
+ def dig: (index name_or_position) -> Elem
637
+ | (index name_or_position, untyped, *untyped) -> untyped
638
+
639
+ # <!-- rdoc-file=struct.c -->
640
+ # Returns the values in `self` as an array:
641
+ #
642
+ # Customer = Struct.new(:name, :address, :zip)
643
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
644
+ # joe.to_a # => ["Joe Smith", "123 Maple, Anytown NC", 12345]
645
+ #
646
+ # Related: #members.
647
+ #
648
+ alias deconstruct to_a
649
+
650
+ # <!--
651
+ # rdoc-file=struct.c
652
+ # - deconstruct_keys(array_of_names) -> hash
653
+ # -->
654
+ # Returns a hash of the name/value pairs for the given member names.
655
+ #
656
+ # Customer = Struct.new(:name, :address, :zip)
657
+ # joe = Customer.new("Joe Smith", "123 Maple, Anytown NC", 12345)
658
+ # h = joe.deconstruct_keys([:zip, :address])
659
+ # h # => {:zip=>12345, :address=>"123 Maple, Anytown NC"}
660
+ #
661
+ # Returns all names and values if `array_of_names` is `nil`:
662
+ #
663
+ # h = joe.deconstruct_keys(nil)
664
+ # h # => {:name=>"Joseph Smith, Jr.", :address=>"123 Maple, Anytown NC", :zip=>12345}
293
665
  #
294
- def self.keyword_init?: () -> (true | false | nil)
666
+ def deconstruct_keys: (Array[index & Hash::_Key]? indices) -> Hash[index & Hash::_Key, Elem]
295
667
  end