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/match_data.rbs CHANGED
@@ -41,113 +41,288 @@
41
41
  # * `$'` is Regexp.last_match`.post_match`;
42
42
  # * `$+` is Regexp.last_match`[ -1 ]` (the last capture).
43
43
  #
44
- #
45
44
  # See also "Special global variables" section in Regexp documentation.
46
45
  #
47
46
  class MatchData
48
- public
47
+ type capture = String | Symbol | int
48
+
49
+ def initialize_copy: (MatchData instance) -> self
49
50
 
50
51
  # <!-- rdoc-file=re.c -->
51
- # Equality---Two matchdata are equal if their target strings, patterns, and
52
- # matched positions are identical.
52
+ # Returns `true` if `object` is another MatchData object whose target string,
53
+ # regexp, match, and captures are the same as `self`, `false` otherwise.
53
54
  #
54
- def ==: (untyped other) -> bool
55
+ def ==: (MatchData other) -> bool
56
+ | (untyped) -> false
55
57
 
56
58
  # <!--
57
59
  # rdoc-file=re.c
58
- # - mtch[i] -> str or nil
59
- # - mtch[start, length] -> array
60
- # - mtch[range] -> array
61
- # - mtch[name] -> str or nil
60
+ # - matchdata[index] -> string or nil
61
+ # - matchdata[start, length] -> array
62
+ # - matchdata[range] -> array
63
+ # - matchdata[name] -> string or nil
62
64
  # -->
63
- # Match Reference -- MatchData acts as an array, and may be accessed using the
64
- # normal array indexing techniques. `mtch[0]` is equivalent to the special
65
- # variable `$&`, and returns the entire matched string. `mtch[1]`, `mtch[2]`,
66
- # and so on return the values of the matched backreferences (portions of the
67
- # pattern between parentheses).
65
+ # When arguments `index`, +start and `length`, or `range` are given, returns
66
+ # match and captures in the style of Array#[]:
68
67
  #
69
68
  # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
70
- # m #=> #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
71
- # m[0] #=> "HX1138"
72
- # m[1, 2] #=> ["H", "X"]
73
- # m[1..3] #=> ["H", "X", "113"]
74
- # m[-3, 2] #=> ["X", "113"]
75
- #
76
- # m = /(?<foo>a+)b/.match("ccaaab")
77
- # m #=> #<MatchData "aaab" foo:"aaa">
78
- # m["foo"] #=> "aaa"
79
- # m[:foo] #=> "aaa"
80
- #
81
- def []: (Integer idx) -> String?
82
- | (Integer start, Integer length) -> ::Array[String?]
83
- | (::Range[Integer] range) -> ::Array[String?]
84
- | (String | Symbol name) -> String?
69
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
70
+ # m[0] # => "HX1138"
71
+ # m[1, 2] # => ["H", "X"]
72
+ # m[1..3] # => ["H", "X", "113"]
73
+ # m[-3, 2] # => ["X", "113"]
74
+ #
75
+ # When string or symbol argument `name` is given, returns the matched substring
76
+ # for the given name:
77
+ #
78
+ # m = /(?<foo>.)(.)(?<bar>.+)/.match("hoge")
79
+ # # => #<MatchData "hoge" foo:"h" bar:"ge">
80
+ # m['foo'] # => "h"
81
+ # m[:bar] # => "ge"
82
+ #
83
+ # If multiple captures have the same name, returns the last matched substring.
84
+ #
85
+ # m = /(?<foo>.)(?<foo>.+)/.match("hoge")
86
+ # # => #<MatchData "hoge" foo:"h" foo:"oge">
87
+ # m[:foo] #=> "oge"
88
+ #
89
+ # m = /\W(?<foo>.+)|\w(?<foo>.+)|(?<foo>.+)/.match("hoge")
90
+ # #<MatchData "hoge" foo:nil foo:"oge" foo:nil>
91
+ # m[:foo] #=> "oge"
92
+ #
93
+ def []: (capture backref, ?nil) -> String?
94
+ | (int start, int length) -> Array[String?]
95
+ | (range[int?] range) -> Array[String?]
85
96
 
86
97
  # <!--
87
98
  # rdoc-file=re.c
88
- # - mtch.begin(n) -> integer
99
+ # - begin(n) -> integer
100
+ # - begin(name) -> integer
89
101
  # -->
90
- # Returns the offset of the start of the *n*th element of the match array in the
91
- # string. *n* can be a string or symbol to reference a named capture.
102
+ # Returns the offset (in characters) of the beginning of the specified match.
103
+ #
104
+ # When non-negative integer argument `n` is given, returns the offset of the
105
+ # beginning of the `n`th match:
92
106
  #
93
107
  # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
94
- # m.begin(0) #=> 1
95
- # m.begin(2) #=> 2
108
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
109
+ # m[0] # => "HX1138"
110
+ # m.begin(0) # => 1
111
+ # m[3] # => "113"
112
+ # m.begin(3) # => 3
113
+ #
114
+ # m = /(т)(е)(с)/.match('тест')
115
+ # # => #<MatchData "тес" 1:"т" 2:"е" 3:"с">
116
+ # m[0] # => "тес"
117
+ # m.begin(0) # => 0
118
+ # m[3] # => "с"
119
+ # m.begin(3) # => 2
120
+ #
121
+ # When string or symbol argument `name` is given, returns the offset of the
122
+ # beginning for the named match:
96
123
  #
97
124
  # m = /(?<foo>.)(.)(?<bar>.)/.match("hoge")
98
- # p m.begin(:foo) #=> 0
99
- # p m.begin(:bar) #=> 2
125
+ # # => #<MatchData "hog" foo:"h" bar:"g">
126
+ # m[:foo] # => "h"
127
+ # m.begin('foo') # => 0
128
+ # m[:bar] # => "g"
129
+ # m.begin(:bar) # => 2
130
+ #
131
+ # Related: MatchData#end, MatchData#offset, MatchData#byteoffset.
100
132
  #
101
- def begin: (Integer | String | Symbol n_or_name) -> Integer?
133
+ def begin: (capture backref) -> Integer?
102
134
 
103
135
  # <!--
104
136
  # rdoc-file=re.c
105
- # - mtch.captures -> array
137
+ # - bytebegin(n) -> integer
138
+ # - bytebegin(name) -> integer
106
139
  # -->
107
- # Returns the array of captures; equivalent to `mtch.to_a[1..-1]`.
140
+ # Returns the offset (in bytes) of the beginning of the specified match.
108
141
  #
109
- # f1,f2,f3,f4 = /(.)(.)(\d+)(\d)/.match("THX1138.").captures
110
- # f1 #=> "H"
111
- # f2 #=> "X"
112
- # f3 #=> "113"
113
- # f4 #=> "8"
142
+ # When non-negative integer argument `n` is given, returns the offset of the
143
+ # beginning of the `n`th match:
114
144
  #
115
- def captures: () -> ::Array[String?]
145
+ # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
146
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
147
+ # m[0] # => "HX1138"
148
+ # m.bytebegin(0) # => 1
149
+ # m[3] # => "113"
150
+ # m.bytebegin(3) # => 3
151
+ #
152
+ # m = /(т)(е)(с)/.match('тест')
153
+ # # => #<MatchData "тес" 1:"т" 2:"е" 3:"с">
154
+ # m[0] # => "тес"
155
+ # m.bytebegin(0) # => 0
156
+ # m[3] # => "с"
157
+ # m.bytebegin(3) # => 4
158
+ #
159
+ # When string or symbol argument `name` is given, returns the offset of the
160
+ # beginning for the named match:
161
+ #
162
+ # m = /(?<foo>.)(.)(?<bar>.)/.match("hoge")
163
+ # # => #<MatchData "hog" foo:"h" bar:"g">
164
+ # m[:foo] # => "h"
165
+ # m.bytebegin('foo') # => 0
166
+ # m[:bar] # => "g"
167
+ # m.bytebegin(:bar) # => 2
168
+ #
169
+ # Related: MatchData#byteend, MatchData#byteoffset.
170
+ #
171
+ def bytebegin: (capture backref) -> Integer?
116
172
 
117
173
  # <!--
118
174
  # rdoc-file=re.c
119
- # - mtch.end(n) -> integer
175
+ # - byteend(n) -> integer
176
+ # - byteend(name) -> integer
120
177
  # -->
121
- # Returns the offset of the character immediately following the end of the *n*th
122
- # element of the match array in the string. *n* can be a string or symbol to
123
- # reference a named capture.
178
+ # Returns the offset (in bytes) of the end of the specified match.
179
+ #
180
+ # When non-negative integer argument `n` is given, returns the offset of the end
181
+ # of the `n`th match:
124
182
  #
125
183
  # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
126
- # m.end(0) #=> 7
127
- # m.end(2) #=> 3
184
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
185
+ # m[0] # => "HX1138"
186
+ # m.byteend(0) # => 7
187
+ # m[3] # => "113"
188
+ # m.byteend(3) # => 6
189
+ #
190
+ # m = /(т)(е)(с)/.match('тест')
191
+ # # => #<MatchData "тес" 1:"т" 2:"е" 3:"с">
192
+ # m[0] # => "тес"
193
+ # m.byteend(0) # => 6
194
+ # m[3] # => "с"
195
+ # m.byteend(3) # => 6
196
+ #
197
+ # When string or symbol argument `name` is given, returns the offset of the end
198
+ # for the named match:
128
199
  #
129
200
  # m = /(?<foo>.)(.)(?<bar>.)/.match("hoge")
130
- # p m.end(:foo) #=> 1
131
- # p m.end(:bar) #=> 3
201
+ # # => #<MatchData "hog" foo:"h" bar:"g">
202
+ # m[:foo] # => "h"
203
+ # m.byteend('foo') # => 1
204
+ # m[:bar] # => "g"
205
+ # m.byteend(:bar) # => 3
206
+ #
207
+ # Related: MatchData#bytebegin, MatchData#byteoffset.
132
208
  #
133
- def end: (Integer | String | Symbol n_or_name) -> Integer?
209
+ def byteend: (capture backref) -> Integer?
134
210
 
135
211
  # <!--
136
212
  # rdoc-file=re.c
137
- # - mtch == mtch2 -> true or false
138
- # - mtch.eql?(mtch2) -> true or false
213
+ # - mtch.byteoffset(n) -> array
139
214
  # -->
140
- # Equality---Two matchdata are equal if their target strings, patterns, and
141
- # matched positions are identical.
215
+ # Returns a two-element array containing the beginning and ending byte-based
216
+ # offsets of the *n*th match. *n* can be a string or symbol to reference a named
217
+ # capture.
142
218
  #
143
- def eql?: (untyped other) -> bool
219
+ # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
220
+ # m.byteoffset(0) #=> [1, 7]
221
+ # m.byteoffset(4) #=> [6, 7]
222
+ #
223
+ # m = /(?<foo>.)(.)(?<bar>.)/.match("hoge")
224
+ # p m.byteoffset(:foo) #=> [0, 1]
225
+ # p m.byteoffset(:bar) #=> [2, 3]
226
+ #
227
+ def byteoffset: (capture backref) -> ([Integer, Integer] | [nil, nil])
228
+
229
+ # <!--
230
+ # rdoc-file=re.c
231
+ # - captures -> array
232
+ # -->
233
+ # Returns the array of captures, which are all matches except `m[0]`:
234
+ #
235
+ # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
236
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
237
+ # m[0] # => "HX1138"
238
+ # m.captures # => ["H", "X", "113", "8"]
239
+ #
240
+ # Related: MatchData.to_a.
241
+ #
242
+ def captures: () -> Array[String?]
243
+
244
+ # <!-- rdoc-file=re.c -->
245
+ # Returns the array of captures, which are all matches except `m[0]`:
246
+ #
247
+ # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
248
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
249
+ # m[0] # => "HX1138"
250
+ # m.captures # => ["H", "X", "113", "8"]
251
+ #
252
+ # Related: MatchData.to_a.
253
+ #
254
+ alias deconstruct captures
144
255
 
145
256
  # <!--
146
257
  # rdoc-file=re.c
147
- # - mtch.hash -> integer
258
+ # - deconstruct_keys(array_of_names) -> hash
148
259
  # -->
149
- # Produce a hash based on the target string, regexp and matched positions of
150
- # this matchdata.
260
+ # Returns a hash of the named captures for the given names.
261
+ #
262
+ # m = /(?<hours>\d{2}):(?<minutes>\d{2}):(?<seconds>\d{2})/.match("18:37:22")
263
+ # m.deconstruct_keys([:hours, :minutes]) # => {:hours => "18", :minutes => "37"}
264
+ # m.deconstruct_keys(nil) # => {:hours => "18", :minutes => "37", :seconds => "22"}
265
+ #
266
+ # Returns an empty hash if no named captures were defined:
267
+ #
268
+ # m = /(\d{2}):(\d{2}):(\d{2})/.match("18:37:22")
269
+ # m.deconstruct_keys(nil) # => {}
270
+ #
271
+ def deconstruct_keys: (Array[Symbol]? array_of_names) -> Hash[Symbol, String?]
272
+
273
+ # <!--
274
+ # rdoc-file=re.c
275
+ # - end(n) -> integer
276
+ # - end(name) -> integer
277
+ # -->
278
+ # Returns the offset (in characters) of the end of the specified match.
279
+ #
280
+ # When non-negative integer argument `n` is given, returns the offset of the end
281
+ # of the `n`th match:
282
+ #
283
+ # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
284
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
285
+ # m[0] # => "HX1138"
286
+ # m.end(0) # => 7
287
+ # m[3] # => "113"
288
+ # m.end(3) # => 6
289
+ #
290
+ # m = /(т)(е)(с)/.match('тест')
291
+ # # => #<MatchData "тес" 1:"т" 2:"е" 3:"с">
292
+ # m[0] # => "тес"
293
+ # m.end(0) # => 3
294
+ # m[3] # => "с"
295
+ # m.end(3) # => 3
296
+ #
297
+ # When string or symbol argument `name` is given, returns the offset of the end
298
+ # for the named match:
299
+ #
300
+ # m = /(?<foo>.)(.)(?<bar>.)/.match("hoge")
301
+ # # => #<MatchData "hog" foo:"h" bar:"g">
302
+ # m[:foo] # => "h"
303
+ # m.end('foo') # => 1
304
+ # m[:bar] # => "g"
305
+ # m.end(:bar) # => 3
306
+ #
307
+ # Related: MatchData#begin, MatchData#offset, MatchData#byteoffset.
308
+ #
309
+ def end: (capture backref) -> Integer?
310
+
311
+ # <!--
312
+ # rdoc-file=re.c
313
+ # - matchdata == object -> true or false
314
+ # -->
315
+ # Returns `true` if `object` is another MatchData object whose target string,
316
+ # regexp, match, and captures are the same as `self`, `false` otherwise.
317
+ #
318
+ alias eql? ==
319
+
320
+ # <!--
321
+ # rdoc-file=re.c
322
+ # - hash -> integer
323
+ # -->
324
+ # Returns the integer hash value for `self`, based on the target string, regexp,
325
+ # match, and captures.
151
326
  #
152
327
  # See also Object#hash.
153
328
  #
@@ -155,234 +330,306 @@ class MatchData
155
330
 
156
331
  # <!--
157
332
  # rdoc-file=re.c
158
- # - mtch.inspect -> str
333
+ # - inspect -> string
159
334
  # -->
160
- # Returns a printable version of *mtch*.
335
+ # Returns a string representation of `self`:
161
336
  #
162
- # puts /.$/.match("foo").inspect
163
- # #=> #<MatchData "o">
337
+ # m = /.$/.match("foo")
338
+ # # => #<MatchData "o">
339
+ # m.inspect # => "#<MatchData \"o\">"
164
340
  #
165
- # puts /(.)(.)(.)/.match("foo").inspect
166
- # #=> #<MatchData "foo" 1:"f" 2:"o" 3:"o">
341
+ # m = /(.)(.)(.)/.match("foo")
342
+ # # => #<MatchData "foo" 1:"f" 2:"o" 3:"o">
343
+ # m.inspect # => "#<MatchData \"foo\" 1:\"f\" 2:\"o\
167
344
  #
168
- # puts /(.)(.)?(.)/.match("fo").inspect
169
- # #=> #<MatchData "fo" 1:"f" 2:nil 3:"o">
345
+ # m = /(.)(.)?(.)/.match("fo")
346
+ # # => #<MatchData "fo" 1:"f" 2:nil 3:"o">
347
+ # m.inspect # => "#<MatchData \"fo\" 1:\"f\" 2:nil 3:\"o\">"
170
348
  #
171
- # puts /(?<foo>.)(?<bar>.)(?<baz>.)/.match("hoge").inspect
172
- # #=> #<MatchData "hog" foo:"h" bar:"o" baz:"g">
349
+ # Related: MatchData#to_s.
173
350
  #
174
351
  def inspect: () -> String
175
352
 
176
353
  # <!-- rdoc-file=re.c -->
177
- # Returns the number of elements in the match array.
354
+ # Returns size of the match array:
178
355
  #
179
356
  # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
180
- # m.length #=> 5
181
- # m.size #=> 5
357
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
358
+ # m.size # => 5
182
359
  #
183
- def length: () -> Integer
360
+ alias length size
184
361
 
185
362
  # <!--
186
363
  # rdoc-file=re.c
187
- # - mtch.named_captures -> hash
364
+ # - named_captures(symbolize_names: false) -> hash
188
365
  # -->
189
- # Returns a Hash using named capture.
366
+ # Returns a hash of the named captures; each key is a capture name; each value
367
+ # is its captured string or `nil`:
190
368
  #
191
- # A key of the hash is a name of the named captures. A value of the hash is a
192
- # string of last successful capture of corresponding group.
369
+ # m = /(?<foo>.)(.)(?<bar>.+)/.match("hoge")
370
+ # # => #<MatchData "hoge" foo:"h" bar:"ge">
371
+ # m.named_captures # => {"foo"=>"h", "bar"=>"ge"}
193
372
  #
194
373
  # m = /(?<a>.)(?<b>.)/.match("01")
374
+ # # => #<MatchData "01" a:"0" b:"1">
195
375
  # m.named_captures #=> {"a" => "0", "b" => "1"}
196
376
  #
197
377
  # m = /(?<a>.)(?<b>.)?/.match("0")
378
+ # # => #<MatchData "0" a:"0" b:nil>
198
379
  # m.named_captures #=> {"a" => "0", "b" => nil}
199
380
  #
200
381
  # m = /(?<a>.)(?<a>.)/.match("01")
382
+ # # => #<MatchData "01" a:"0" a:"1">
201
383
  # m.named_captures #=> {"a" => "1"}
202
384
  #
203
- # m = /(?<a>x)|(?<a>y)/.match("x")
204
- # m.named_captures #=> {"a" => "x"}
385
+ # If keyword argument `symbolize_names` is given a true value, the keys in the
386
+ # resulting hash are Symbols:
205
387
  #
206
- def named_captures: () -> ::Hash[String, String?]
388
+ # m = /(?<a>.)(?<a>.)/.match("01")
389
+ # # => #<MatchData "01" a:"0" a:"1">
390
+ # m.named_captures(symbolize_names: true) #=> {:a => "1"}
391
+ #
392
+ def named_captures: () -> Hash[String, String?]
393
+ | (symbolize_names: true) -> Hash[Symbol, String?]
394
+ | (symbolize_names: boolish) -> Hash[String | Symbol, String?]
207
395
 
208
396
  # <!--
209
397
  # rdoc-file=re.c
210
- # - mtch.names -> [name1, name2, ...]
398
+ # - names -> array_of_names
211
399
  # -->
212
- # Returns a list of names of captures as an array of strings. This is the same
213
- # as mtch.regexp.names.
400
+ # Returns an array of the capture names (see [Named
401
+ # Captures](rdoc-ref:Regexp@Named+Captures)):
402
+ #
403
+ # m = /(?<foo>.)(?<bar>.)(?<baz>.)/.match("hoge")
404
+ # # => #<MatchData "hog" foo:"h" bar:"o" baz:"g">
405
+ # m.names # => ["foo", "bar", "baz"]
214
406
  #
215
- # /(?<foo>.)(?<bar>.)(?<baz>.)/.match("hoge").names
216
- # #=> ["foo", "bar", "baz"]
407
+ # m = /foo/.match('foo') # => #<MatchData "foo">
408
+ # m.names # => [] # No named captures.
217
409
  #
218
- # m = /(?<x>.)(?<y>.)?/.match("a") #=> #<MatchData "a" x:"a" y:nil>
219
- # m.names #=> ["x", "y"]
410
+ # Equivalent to:
220
411
  #
221
- def names: () -> ::Array[String]
412
+ # m = /(?<foo>.)(?<bar>.)(?<baz>.)/.match("hoge")
413
+ # m.regexp.names # => ["foo", "bar", "baz"]
414
+ #
415
+ def names: () -> Array[String]
222
416
 
223
417
  # <!--
224
418
  # rdoc-file=re.c
225
- # - mtch.match(n) -> string or nil
419
+ # - match(n) -> string or nil
420
+ # - match(name) -> string or nil
226
421
  # -->
227
- # Returns the captured substring corresponding to the argument. *n* can be a
228
- # string or symbol to reference a named capture.
422
+ # Returns the matched substring corresponding to the given argument.
423
+ #
424
+ # When non-negative argument `n` is given, returns the matched substring for the
425
+ # `n`th match:
229
426
  #
230
427
  # m = /(.)(.)(\d+)(\d)(\w)?/.match("THX1138.")
231
- # m.match(0) #=> "HX1138"
232
- # m.match(4) #=> "8"
233
- # m.match(5) #=> nil
428
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8" 5:nil>
429
+ # m.match(0) # => "HX1138"
430
+ # m.match(4) # => "8"
431
+ # m.match(5) # => nil
432
+ #
433
+ # When string or symbol argument `name` is given, returns the matched substring
434
+ # for the given name:
234
435
  #
235
436
  # m = /(?<foo>.)(.)(?<bar>.+)/.match("hoge")
236
- # m.match(:foo) #=> "h"
237
- # m.match(:bar) #=> "ge"
437
+ # # => #<MatchData "hoge" foo:"h" bar:"ge">
438
+ # m.match('foo') # => "h"
439
+ # m.match(:bar) # => "ge"
238
440
  #
239
- def match: (int | String | Symbol) -> String?
441
+ def match: (capture backref) -> String?
240
442
 
241
443
  # <!--
242
444
  # rdoc-file=re.c
243
- # - mtch.match_length(n) -> array
445
+ # - match_length(n) -> integer or nil
446
+ # - match_length(name) -> integer or nil
244
447
  # -->
245
- # Returns the length of the captured substring corresponding to the argument.
246
- # *n* can be a string or symbol to reference a named capture.
448
+ # Returns the length (in characters) of the matched substring corresponding to
449
+ # the given argument.
450
+ #
451
+ # When non-negative argument `n` is given, returns the length of the matched
452
+ # substring for the `n`th match:
247
453
  #
248
454
  # m = /(.)(.)(\d+)(\d)(\w)?/.match("THX1138.")
249
- # m.match_length(0) #=> 6
250
- # m.match_length(4) #=> 1
251
- # m.match_length(5) #=> nil
455
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8" 5:nil>
456
+ # m.match_length(0) # => 6
457
+ # m.match_length(4) # => 1
458
+ # m.match_length(5) # => nil
459
+ #
460
+ # When string or symbol argument `name` is given, returns the length of the
461
+ # matched substring for the named match:
252
462
  #
253
463
  # m = /(?<foo>.)(.)(?<bar>.+)/.match("hoge")
254
- # m.match_length(:foo) #=> 1
255
- # m.match_length(:bar) #=> 2
464
+ # # => #<MatchData "hoge" foo:"h" bar:"ge">
465
+ # m.match_length('foo') # => 1
466
+ # m.match_length(:bar) # => 2
256
467
  #
257
- def match_length: (int | String | Symbol) -> Integer?
468
+ def match_length: (capture backref) -> Integer?
258
469
 
259
470
  # <!--
260
471
  # rdoc-file=re.c
261
- # - mtch.offset(n) -> array
472
+ # - offset(n) -> [start_offset, end_offset]
473
+ # - offset(name) -> [start_offset, end_offset]
262
474
  # -->
263
- # Returns a two-element array containing the beginning and ending offsets of the
264
- # *n*th match. *n* can be a string or symbol to reference a named capture.
475
+ # Returns a 2-element array containing the beginning and ending offsets (in
476
+ # characters) of the specified match.
477
+ #
478
+ # When non-negative integer argument `n` is given, returns the starting and
479
+ # ending offsets of the `n`th match:
265
480
  #
266
481
  # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
267
- # m.offset(0) #=> [1, 7]
268
- # m.offset(4) #=> [6, 7]
482
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
483
+ # m[0] # => "HX1138"
484
+ # m.offset(0) # => [1, 7]
485
+ # m[3] # => "113"
486
+ # m.offset(3) # => [3, 6]
487
+ #
488
+ # m = /(т)(е)(с)/.match('тест')
489
+ # # => #<MatchData "тес" 1:"т" 2:"е" 3:"с">
490
+ # m[0] # => "тес"
491
+ # m.offset(0) # => [0, 3]
492
+ # m[3] # => "с"
493
+ # m.offset(3) # => [2, 3]
494
+ #
495
+ # When string or symbol argument `name` is given, returns the starting and
496
+ # ending offsets for the named match:
269
497
  #
270
498
  # m = /(?<foo>.)(.)(?<bar>.)/.match("hoge")
271
- # p m.offset(:foo) #=> [0, 1]
272
- # p m.offset(:bar) #=> [2, 3]
499
+ # # => #<MatchData "hog" foo:"h" bar:"g">
500
+ # m[:foo] # => "h"
501
+ # m.offset('foo') # => [0, 1]
502
+ # m[:bar] # => "g"
503
+ # m.offset(:bar) # => [2, 3]
504
+ #
505
+ # Related: MatchData#byteoffset, MatchData#begin, MatchData#end.
273
506
  #
274
- def offset: (Integer | Symbol | String n_or_name) -> ([ Integer, Integer ] | [ nil, nil ])
507
+ def offset: (capture backref) -> ([Integer, Integer] | [nil, nil])
275
508
 
276
509
  # <!--
277
510
  # rdoc-file=re.c
278
- # - mtch.post_match -> str
511
+ # - post_match -> str
279
512
  # -->
280
- # Returns the portion of the original string after the current match. Equivalent
281
- # to the special variable `$'`.
513
+ # Returns the substring of the target string from the end of the first match in
514
+ # `self` (that is, `self[0]`) to the end of the string; equivalent to regexp
515
+ # global variable `$'`:
282
516
  #
283
517
  # m = /(.)(.)(\d+)(\d)/.match("THX1138: The Movie")
284
- # m.post_match #=> ": The Movie"
518
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
519
+ # m[0] # => "HX1138"
520
+ # m.post_match # => ": The Movie"\
521
+ #
522
+ # Related: MatchData.pre_match.
285
523
  #
286
524
  def post_match: () -> String
287
525
 
288
526
  # <!--
289
527
  # rdoc-file=re.c
290
- # - mtch.pre_match -> str
528
+ # - pre_match -> string
291
529
  # -->
292
- # Returns the portion of the original string before the current match.
293
- # Equivalent to the special variable `$``.
530
+ # Returns the substring of the target string from its beginning up to the first
531
+ # match in `self` (that is, `self[0]`); equivalent to regexp global variable
532
+ # `$``:
294
533
  #
295
534
  # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
296
- # m.pre_match #=> "T"
535
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
536
+ # m[0] # => "HX1138"
537
+ # m.pre_match # => "T"
538
+ #
539
+ # Related: MatchData#post_match.
297
540
  #
298
541
  def pre_match: () -> String
299
542
 
300
543
  # <!--
301
544
  # rdoc-file=re.c
302
- # - mtch.regexp -> regexp
545
+ # - regexp -> regexp
303
546
  # -->
304
- # Returns the regexp.
547
+ # Returns the regexp that produced the match:
305
548
  #
306
- # m = /a.*b/.match("abc")
307
- # m.regexp #=> /a.*b/
549
+ # m = /a.*b/.match("abc") # => #<MatchData "ab">
550
+ # m.regexp # => /a.*b/
308
551
  #
309
552
  def regexp: () -> Regexp
310
553
 
311
554
  # <!--
312
555
  # rdoc-file=re.c
313
- # - mtch.length -> integer
314
- # - mtch.size -> integer
556
+ # - size -> integer
315
557
  # -->
316
- # Returns the number of elements in the match array.
558
+ # Returns size of the match array:
317
559
  #
318
560
  # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
319
- # m.length #=> 5
320
- # m.size #=> 5
561
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
562
+ # m.size # => 5
321
563
  #
322
564
  def size: () -> Integer
323
565
 
324
566
  # <!--
325
567
  # rdoc-file=re.c
326
- # - mtch.string -> str
568
+ # - string -> string
327
569
  # -->
328
- # Returns a frozen copy of the string passed in to `match`.
570
+ # Returns the target string if it was frozen; otherwise, returns a frozen copy
571
+ # of the target string:
329
572
  #
330
573
  # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
331
- # m.string #=> "THX1138."
574
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
575
+ # m.string # => "THX1138."
332
576
  #
333
577
  def string: () -> String
334
578
 
335
579
  # <!--
336
580
  # rdoc-file=re.c
337
- # - mtch.to_a -> anArray
581
+ # - to_a -> array
338
582
  # -->
339
- # Returns the array of matches.
583
+ # Returns the array of matches:
340
584
  #
341
585
  # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
342
- # m.to_a #=> ["HX1138", "H", "X", "113", "8"]
343
- #
344
- # Because `to_a` is called when expanding `*`*variable*, there's a useful
345
- # assignment shortcut for extracting matched fields. This is slightly slower
346
- # than accessing the fields directly (as an intermediate array is generated).
586
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
587
+ # m.to_a # => ["HX1138", "H", "X", "113", "8"]
347
588
  #
348
- # all,f1,f2,f3 = * /(.)(.)(\d+)(\d)/.match("THX1138.")
349
- # all #=> "HX1138"
350
- # f1 #=> "H"
351
- # f2 #=> "X"
352
- # f3 #=> "113"
589
+ # Related: MatchData#captures.
353
590
  #
354
- def to_a: () -> ::Array[String?]
591
+ def to_a: () -> Array[String?]
355
592
 
356
593
  # <!--
357
594
  # rdoc-file=re.c
358
- # - mtch.to_s -> str
595
+ # - to_s -> string
359
596
  # -->
360
- # Returns the entire matched string.
597
+ # Returns the matched string:
361
598
  #
362
599
  # m = /(.)(.)(\d+)(\d)/.match("THX1138.")
363
- # m.to_s #=> "HX1138"
600
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
601
+ # m.to_s # => "HX1138"
602
+ #
603
+ # m = /(?<foo>.)(.)(?<bar>.+)/.match("hoge")
604
+ # # => #<MatchData "hoge" foo:"h" bar:"ge">
605
+ # m.to_s # => "hoge"
606
+ #
607
+ # Related: MatchData.inspect.
364
608
  #
365
609
  def to_s: () -> String
366
610
 
367
611
  # <!--
368
612
  # rdoc-file=re.c
369
- # - mtch.values_at(index, ...) -> array
613
+ # - values_at(*indexes) -> array
370
614
  # -->
371
- # Uses each *index* to access the matching values, returning an array of the
372
- # corresponding matches.
615
+ # Returns match and captures at the given `indexes`, which may include any
616
+ # mixture of:
617
+ #
618
+ # * Integers.
619
+ # * Ranges.
620
+ # * Names (strings and symbols).
621
+ #
622
+ # Examples:
373
623
  #
374
624
  # m = /(.)(.)(\d+)(\d)/.match("THX1138: The Movie")
375
- # m.to_a #=> ["HX1138", "H", "X", "113", "8"]
376
- # m.values_at(0, 2, -2) #=> ["HX1138", "X", "113"]
377
- # m.values_at(1..2, -1) #=> ["H", "X", "8"]
625
+ # # => #<MatchData "HX1138" 1:"H" 2:"X" 3:"113" 4:"8">
626
+ # m.values_at(0, 2, -2) # => ["HX1138", "X", "113"]
627
+ # m.values_at(1..2, -1) # => ["H", "X", "8"]
378
628
  #
379
629
  # m = /(?<a>\d+) *(?<op>[+\-*\/]) *(?<b>\d+)/.match("1 + 2")
380
- # m.to_a #=> ["1 + 2", "1", "+", "2"]
381
- # m.values_at(:a, :b, :op) #=> ["1", "2", "+"]
630
+ # # => #<MatchData "1 + 2" a:"1" op:"+" b:"2">
631
+ # m.values_at(0, 1..2, :a, :b, :op)
632
+ # # => ["1 + 2", "1", "+", "1", "2", "+"]
382
633
  #
383
- def values_at: (*Integer | Symbol | String n_or_name) -> ::Array[String?]
384
-
385
- private
386
-
387
- def initialize_copy: (self object) -> void
634
+ def values_at: (*capture | range[int?] backrefs) -> Array[String?]
388
635
  end