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/exception.rbs CHANGED
@@ -1,269 +1,485 @@
1
1
  # <!-- rdoc-file=error.c -->
2
- # Class Exception and its subclasses are used to communicate between
3
- # Kernel#raise and `rescue` statements in `begin ... end` blocks.
2
+ # Class `Exception` and its subclasses are used to indicate that an error or
3
+ # other problem has occurred, and may need to be handled. See
4
+ # [Exceptions](rdoc-ref:exceptions.md).
4
5
  #
5
- # An Exception object carries information about an exception:
6
- # * Its type (the exception's class).
7
- # * An optional descriptive message.
8
- # * Optional backtrace information.
6
+ # An `Exception` object carries certain information:
9
7
  #
8
+ # * The type (the exception's class), commonly StandardError, RuntimeError, or
9
+ # a subclass of one or the other; see [Built-In Exception Class
10
+ # Hierarchy](rdoc-ref:Exception@Built-In+Exception+Class+Hierarchy).
11
+ # * An optional descriptive message; see methods ::new, #message.
12
+ # * Optional backtrace information; see methods #backtrace,
13
+ # #backtrace_locations, #set_backtrace.
14
+ # * An optional cause; see method #cause.
10
15
  #
11
- # Some built-in subclasses of Exception have additional methods: e.g.,
12
- # NameError#name.
16
+ # ## Built-In Exception Class Hierarchy
13
17
  #
14
- # ## Defaults
15
- #
16
- # Two Ruby statements have default exception classes:
17
- # * `raise`: defaults to RuntimeError.
18
- # * `rescue`: defaults to StandardError.
19
- #
20
- #
21
- # ## Global Variables
22
- #
23
- # When an exception has been raised but not yet handled (in `rescue`, `ensure`,
24
- # `at_exit` and `END` blocks), two global variables are set:
25
- # * `$!` contains the current exception.
26
- # * `$@` contains its backtrace.
27
- #
28
- #
29
- # ## Custom Exceptions
30
- #
31
- # To provide additional or alternate information, a program may create custom
32
- # exception classes that derive from the built-in exception classes.
33
- #
34
- # A good practice is for a library to create a single "generic" exception class
35
- # (typically a subclass of StandardError or RuntimeError) and have its other
36
- # exception classes derive from that class. This allows the user to rescue the
37
- # generic exception, thus catching all exceptions the library may raise even if
38
- # future versions of the library add new exception subclasses.
39
- #
40
- # For example:
41
- #
42
- # class MyLibrary
43
- # class Error < ::StandardError
44
- # end
45
- #
46
- # class WidgetError < Error
47
- # end
48
- #
49
- # class FrobError < Error
50
- # end
51
- #
52
- # end
53
- #
54
- # To handle both MyLibrary::WidgetError and MyLibrary::FrobError the library
55
- # user can rescue MyLibrary::Error.
56
- #
57
- # ## Built-In Exception Classes
58
- #
59
- # The built-in subclasses of Exception are:
18
+ # The hierarchy of built-in subclasses of class `Exception`:
60
19
  #
61
20
  # * NoMemoryError
62
21
  # * ScriptError
63
22
  # * LoadError
64
23
  # * NotImplementedError
65
24
  # * SyntaxError
66
- #
67
25
  # * SecurityError
68
26
  # * SignalException
69
27
  # * Interrupt
70
- #
71
28
  # * StandardError
72
29
  # * ArgumentError
73
30
  # * UncaughtThrowError
74
- #
75
31
  # * EncodingError
76
32
  # * FiberError
77
33
  # * IOError
78
34
  # * EOFError
79
- #
80
35
  # * IndexError
81
36
  # * KeyError
82
37
  # * StopIteration
83
38
  # * ClosedQueueError
84
- #
85
- #
86
39
  # * LocalJumpError
87
40
  # * NameError
88
41
  # * NoMethodError
89
- #
90
42
  # * RangeError
91
43
  # * FloatDomainError
92
- #
93
44
  # * RegexpError
94
45
  # * RuntimeError
95
46
  # * FrozenError
96
- #
97
47
  # * SystemCallError
98
- # * Errno::*
99
- #
48
+ # * Errno (and its subclasses, representing system errors)
100
49
  # * ThreadError
101
50
  # * TypeError
102
51
  # * ZeroDivisionError
103
- #
104
52
  # * SystemExit
105
53
  # * SystemStackError
106
- # * fatal
54
+ # * [fatal](rdoc-ref:fatal)
107
55
  #
108
- class Exception < Object
56
+ class Exception
109
57
  # <!--
110
58
  # rdoc-file=error.c
111
- # - Exception.to_tty? -> true or false
59
+ # - Exception.to_tty? -> true or false
112
60
  # -->
113
- # Returns `true` if exception messages will be sent to a tty.
61
+ # Returns `true` if exception messages will be sent to a terminal device.
114
62
  #
115
63
  def self.to_tty?: () -> bool
116
64
 
117
65
  # <!--
118
66
  # rdoc-file=error.c
119
- # - exc.exception([string]) -> an_exception or exc
67
+ # - exception(message = nil) -> self or new_exception
120
68
  # -->
121
- # With no argument, or if the argument is the same as the receiver, return the
122
- # receiver. Otherwise, create a new exception object of the same class as the
123
- # receiver, but with a message equal to `string.to_str`.
69
+ # Returns an exception object of the same class as `self`; useful for creating a
70
+ # similar exception, but with a different message.
71
+ #
72
+ # With `message` `nil`, returns `self`:
73
+ #
74
+ # x0 = StandardError.new('Boom') # => #<StandardError: Boom>
75
+ # x1 = x0.exception # => #<StandardError: Boom>
76
+ # x0.__id__ == x1.__id__ # => true
77
+ #
78
+ # With [string-convertible
79
+ # object](rdoc-ref:implicit_conversion.rdoc@String-Convertible+Objects)
80
+ # `message` (even the same as the original message), returns a new exception
81
+ # object whose class is the same as `self`, and whose message is the given
82
+ # `message`:
124
83
  #
125
- def self.exception: (?String msg) -> Exception
84
+ # x1 = x0.exception('Boom') # => #<StandardError: Boom>
85
+ # x0..equal?(x1) # => false
86
+ #
87
+ def self.exception: (?string | _ToS msg) -> instance
126
88
 
127
89
  # <!--
128
90
  # rdoc-file=error.c
129
- # - exc == obj -> true or false
91
+ # - self == object -> true or false
130
92
  # -->
131
- # Equality---If *obj* is not an Exception, returns `false`. Otherwise, returns
132
- # `true` if *exc* and *obj* share same class, messages, and backtrace.
93
+ # Returns whether `object` is the same class as `self` and its #message and
94
+ # #backtrace are equal to those of `self`.
133
95
  #
134
- def ==: (untyped arg0) -> bool
96
+ def ==: (untyped obj) -> bool
135
97
 
136
98
  # <!--
137
99
  # rdoc-file=error.c
138
- # - exception.backtrace -> array or nil
100
+ # - backtrace -> array or nil
139
101
  # -->
140
- # Returns any backtrace associated with the exception. The backtrace is an array
141
- # of strings, each containing either ``filename:lineNo: in `method''' or
142
- # ``filename:lineNo.''
102
+ # Returns the backtrace (the list of code locations that led to the exception),
103
+ # as an array of strings.
143
104
  #
144
- # def a
145
- # raise "boom"
146
- # end
105
+ # Example (assuming the code is stored in the file named `t.rb`):
147
106
  #
148
- # def b
149
- # a()
107
+ # def division(numerator, denominator)
108
+ # numerator / denominator
150
109
  # end
151
110
  #
152
111
  # begin
153
- # b()
154
- # rescue => detail
155
- # print detail.backtrace.join("\n")
112
+ # division(1, 0)
113
+ # rescue => ex
114
+ # p ex.backtrace
115
+ # # ["t.rb:2:in 'Integer#/'", "t.rb:2:in 'Object#division'", "t.rb:6:in '<main>'"]
116
+ # loc = ex.backtrace.first
117
+ # p loc.class
118
+ # # String
156
119
  # end
157
120
  #
158
- # *produces:*
159
- #
160
- # prog.rb:2:in `a'
161
- # prog.rb:6:in `b'
162
- # prog.rb:10
121
+ # The value returned by this method migth be adjusted when raising (see
122
+ # Kernel#raise), or during intermediate handling by #set_backtrace.
163
123
  #
164
- # In the case no backtrace has been set, `nil` is returned
124
+ # See also #backtrace_locations that provide the same value, as structured
125
+ # objects. (Note though that two values might not be consistent with each other
126
+ # when backtraces are manually adjusted.)
165
127
  #
166
- # ex = StandardError.new
167
- # ex.backtrace
168
- # #=> nil
128
+ # see [Backtraces](rdoc-ref:exceptions.md@Backtraces).
169
129
  #
170
- def backtrace: () -> ::Array[String]?
130
+ def backtrace: () -> Array[String]?
171
131
 
172
132
  # <!--
173
133
  # rdoc-file=error.c
174
- # - exception.backtrace_locations -> array or nil
134
+ # - backtrace_locations -> array or nil
175
135
  # -->
176
- # Returns any backtrace associated with the exception. This method is similar to
177
- # Exception#backtrace, but the backtrace is an array of
178
- # Thread::Backtrace::Location.
136
+ # Returns the backtrace (the list of code locations that led to the exception),
137
+ # as an array of Thread::Backtrace::Location instances.
138
+ #
139
+ # Example (assuming the code is stored in the file named `t.rb`):
140
+ #
141
+ # def division(numerator, denominator)
142
+ # numerator / denominator
143
+ # end
144
+ #
145
+ # begin
146
+ # division(1, 0)
147
+ # rescue => ex
148
+ # p ex.backtrace_locations
149
+ # # ["t.rb:2:in 'Integer#/'", "t.rb:2:in 'Object#division'", "t.rb:6:in '<main>'"]
150
+ # loc = ex.backtrace_locations.first
151
+ # p loc.class
152
+ # # Thread::Backtrace::Location
153
+ # p loc.path
154
+ # # "t.rb"
155
+ # p loc.lineno
156
+ # # 2
157
+ # p loc.label
158
+ # # "Integer#/"
159
+ # end
179
160
  #
180
- # This method is not affected by Exception#set_backtrace().
161
+ # The value returned by this method might be adjusted when raising (see
162
+ # Kernel#raise), or during intermediate handling by #set_backtrace.
181
163
  #
182
- def backtrace_locations: () -> ::Array[Thread::Backtrace::Location]?
164
+ # See also #backtrace that provide the same value as an array of strings. (Note
165
+ # though that two values might not be consistent with each other when backtraces
166
+ # are manually adjusted.)
167
+ #
168
+ # See [Backtraces](rdoc-ref:exceptions.md@Backtraces).
169
+ #
170
+ def backtrace_locations: () -> Array[Thread::Backtrace::Location]?
183
171
 
184
172
  # <!--
185
173
  # rdoc-file=error.c
186
- # - exception.cause -> an_exception or nil
174
+ # - cause -> exception or nil
187
175
  # -->
188
- # Returns the previous exception ($!) at the time this exception was raised.
189
- # This is useful for wrapping exceptions and retaining the original exception
190
- # information.
176
+ # Returns the previous value of global variable `$!`, which may be `nil` (see
177
+ # [Global Variables](rdoc-ref:exceptions.md@Global+Variables)):
178
+ #
179
+ # begin
180
+ # raise('Boom 0')
181
+ # rescue => x0
182
+ # puts "Exception: #{x0}; $!: #{$!}; cause: #{x0.cause.inspect}."
183
+ # begin
184
+ # raise('Boom 1')
185
+ # rescue => x1
186
+ # puts "Exception: #{x1}; $!: #{$!}; cause: #{x1.cause}."
187
+ # begin
188
+ # raise('Boom 2')
189
+ # rescue => x2
190
+ # puts "Exception: #{x2}; $!: #{$!}; cause: #{x2.cause}."
191
+ # end
192
+ # end
193
+ # end
194
+ #
195
+ # Output:
196
+ #
197
+ # Exception: Boom 0; $!: Boom 0; cause: nil.
198
+ # Exception: Boom 1; $!: Boom 1; cause: Boom 0.
199
+ # Exception: Boom 2; $!: Boom 2; cause: Boom 1.
191
200
  #
192
201
  def cause: () -> Exception?
193
202
 
194
203
  # <!--
195
204
  # rdoc-file=error.c
196
- # - exc.exception([string]) -> an_exception or exc
205
+ # - detailed_message(highlight: false, **kwargs) -> string
206
+ # -->
207
+ # Returns the message string with enhancements:
208
+ #
209
+ # * Includes the exception class name in the first line.
210
+ # * If the value of keyword `highlight` is `true`, includes bolding and
211
+ # underlining ANSI codes (see below) to enhance the appearance of the
212
+ # message.
213
+ #
214
+ # Examples:
215
+ #
216
+ # begin
217
+ # 1 / 0
218
+ # rescue => x
219
+ # p x.message
220
+ # p x.detailed_message # Class name added.
221
+ # p x.detailed_message(highlight: true) # Class name, bolding, and underlining added.
222
+ # end
223
+ #
224
+ # Output:
225
+ #
226
+ # "divided by 0"
227
+ # "divided by 0 (ZeroDivisionError)"
228
+ # "\e[1mdivided by 0 (\e[1;4mZeroDivisionError\e[m\e[1m)\e[m"
229
+ #
230
+ # This method is overridden by some gems in the Ruby standard library to add
231
+ # information:
232
+ #
233
+ # * DidYouMean::Correctable#detailed_message.
234
+ # * ErrorHighlight::CoreExt#detailed_message.
235
+ # * SyntaxSuggest#detailed_message.
236
+ #
237
+ # An overriding method must be tolerant of passed keyword arguments, which may
238
+ # include (but may not be limited to):
239
+ #
240
+ # * `:highlight`.
241
+ # * `:did_you_mean`.
242
+ # * `:error_highlight`.
243
+ # * `:syntax_suggest`.
244
+ #
245
+ # An overriding method should also be careful with ANSI code enhancements; see
246
+ # [Messages](rdoc-ref:exceptions.md@Messages).
247
+ #
248
+ def detailed_message: (?highlight: bool?, **untyped ignored) -> String
249
+
250
+ # <!--
251
+ # rdoc-file=error.c
252
+ # - exception(message = nil) -> self or new_exception
197
253
  # -->
198
- # With no argument, or if the argument is the same as the receiver, return the
199
- # receiver. Otherwise, create a new exception object of the same class as the
200
- # receiver, but with a message equal to `string.to_str`.
254
+ # Returns an exception object of the same class as `self`; useful for creating a
255
+ # similar exception, but with a different message.
256
+ #
257
+ # With `message` `nil`, returns `self`:
258
+ #
259
+ # x0 = StandardError.new('Boom') # => #<StandardError: Boom>
260
+ # x1 = x0.exception # => #<StandardError: Boom>
261
+ # x0.__id__ == x1.__id__ # => true
201
262
  #
202
- def exception: () -> self
203
- | (String arg0) -> Exception
263
+ # With [string-convertible
264
+ # object](rdoc-ref:implicit_conversion.rdoc@String-Convertible+Objects)
265
+ # `message` (even the same as the original message), returns a new exception
266
+ # object whose class is the same as `self`, and whose message is the given
267
+ # `message`:
268
+ #
269
+ # x1 = x0.exception('Boom') # => #<StandardError: Boom>
270
+ # x0..equal?(x1) # => false
271
+ #
272
+ def exception: (?self) -> self
273
+ | (string | _ToS message) -> instance
204
274
 
205
275
  # <!--
206
276
  # rdoc-file=error.c
207
- # - Exception.new(msg = nil) -> exception
208
- # - Exception.exception(msg = nil) -> exception
277
+ # - Exception.new(message = nil) -> exception
209
278
  # -->
210
- # Construct a new Exception object, optionally passing in a message.
279
+ # Returns a new exception object.
280
+ #
281
+ # The given `message` should be a [string-convertible
282
+ # object](rdoc-ref:implicit_conversion.rdoc@String-Convertible+Objects); see
283
+ # method #message; if not given, the message is the class name of the new
284
+ # instance (which may be the name of a subclass):
285
+ #
286
+ # Examples:
211
287
  #
212
- def initialize: (?String arg0) -> void
288
+ # Exception.new # => #<Exception: Exception>
289
+ # LoadError.new # => #<LoadError: LoadError> # Subclass of Exception.
290
+ # Exception.new('Boom') # => #<Exception: Boom>
291
+ #
292
+ def initialize: (?string | _ToS message) -> void
213
293
 
214
294
  # <!--
215
295
  # rdoc-file=error.c
216
- # - exception.inspect -> string
296
+ # - inspect -> string
217
297
  # -->
218
- # Return this exception's class name and message.
298
+ # Returns a string representation of `self`:
299
+ #
300
+ # x = RuntimeError.new('Boom')
301
+ # x.inspect # => "#<RuntimeError: Boom>"
302
+ # x = RuntimeError.new
303
+ # x.inspect # => "#<RuntimeError: RuntimeError>"
219
304
  #
220
305
  def inspect: () -> String
221
306
 
222
307
  # <!--
223
308
  # rdoc-file=error.c
224
- # - exception.message -> string
309
+ # - message -> string
225
310
  # -->
226
- # Returns the result of invoking `exception.to_s`. Normally this returns the
227
- # exception's message or name.
311
+ # Returns #to_s.
312
+ #
313
+ # See [Messages](rdoc-ref:exceptions.md@Messages).
228
314
  #
229
315
  def message: () -> String
230
316
 
231
317
  # <!--
232
318
  # rdoc-file=error.c
233
- # - exc.set_backtrace(backtrace) -> array
319
+ # - set_backtrace(value) -> value
234
320
  # -->
235
- # Sets the backtrace information associated with `exc`. The `backtrace` must be
236
- # an array of String objects or a single String in the format described in
237
- # Exception#backtrace.
321
+ # Sets the backtrace value for `self`; returns the given `value`.
322
+ #
323
+ # The `value` might be:
324
+ #
325
+ # * an array of Thread::Backtrace::Location;
326
+ # * an array of String instances;
327
+ # * a single String instance; or
328
+ # * `nil`.
329
+ #
330
+ # Using array of Thread::Backtrace::Location is the most consistent option: it
331
+ # sets both #backtrace and #backtrace_locations. It should be preferred when
332
+ # possible. The suitable array of locations can be obtained from
333
+ # Kernel#caller_locations, copied from another error, or just set to the
334
+ # adjusted result of the current error's #backtrace_locations:
335
+ #
336
+ # require 'json'
337
+ #
338
+ # def parse_payload(text)
339
+ # JSON.parse(text) # test.rb, line 4
340
+ # rescue JSON::ParserError => ex
341
+ # ex.set_backtrace(ex.backtrace_locations[2...])
342
+ # raise
343
+ # end
238
344
  #
239
- def set_backtrace: (String | ::Array[String] arg0) -> ::Array[String]
345
+ # parse_payload('{"wrong: "json"')
346
+ # # test.rb:4:in 'Object#parse_payload': unexpected token at '{"wrong: "json"' (JSON::ParserError)
347
+ # #
348
+ # # An error points to the body of parse_payload method,
349
+ # # hiding the parts of the backtrace related to the internals
350
+ # # of the "json" library
351
+ #
352
+ # # The error has both #backtace and #backtrace_locations set
353
+ # # consistently:
354
+ # begin
355
+ # parse_payload('{"wrong: "json"')
356
+ # rescue => ex
357
+ # p ex.backtrace
358
+ # # ["test.rb:4:in 'Object#parse_payload'", "test.rb:20:in '<main>'"]
359
+ # p ex.backtrace_locations
360
+ # # ["test.rb:4:in 'Object#parse_payload'", "test.rb:20:in '<main>'"]
361
+ # end
362
+ #
363
+ # When the desired stack of locations is not available and should be constructed
364
+ # from scratch, an array of strings or a singular string can be used. In this
365
+ # case, only #backtrace is affected:
366
+ #
367
+ # def parse_payload(text)
368
+ # JSON.parse(text)
369
+ # rescue JSON::ParserError => ex
370
+ # ex.set_backtrace(["dsl.rb:34", "framework.rb:1"])
371
+ # # The error have the new value in #backtrace:
372
+ # p ex.backtrace
373
+ # # ["dsl.rb:34", "framework.rb:1"]
374
+ #
375
+ # # but the original one in #backtrace_locations
376
+ # p ex.backtrace_locations
377
+ # # [".../json/common.rb:221:in 'JSON::Ext::Parser.parse'", ...]
378
+ # end
379
+ #
380
+ # parse_payload('{"wrong: "json"')
381
+ #
382
+ # Calling #set_backtrace with `nil` clears up #backtrace but doesn't affect
383
+ # #backtrace_locations:
384
+ #
385
+ # def parse_payload(text)
386
+ # JSON.parse(text)
387
+ # rescue JSON::ParserError => ex
388
+ # ex.set_backtrace(nil)
389
+ # p ex.backtrace
390
+ # # nil
391
+ # p ex.backtrace_locations
392
+ # # [".../json/common.rb:221:in 'JSON::Ext::Parser.parse'", ...]
393
+ # end
394
+ #
395
+ # parse_payload('{"wrong: "json"')
396
+ #
397
+ # On reraising of such an exception, both #backtrace and #backtrace_locations is
398
+ # set to the place of reraising:
399
+ #
400
+ # def parse_payload(text)
401
+ # JSON.parse(text)
402
+ # rescue JSON::ParserError => ex
403
+ # ex.set_backtrace(nil)
404
+ # raise # test.rb, line 7
405
+ # end
406
+ #
407
+ # begin
408
+ # parse_payload('{"wrong: "json"')
409
+ # rescue => ex
410
+ # p ex.backtrace
411
+ # # ["test.rb:7:in 'Object#parse_payload'", "test.rb:11:in '<main>'"]
412
+ # p ex.backtrace_locations
413
+ # # ["test.rb:7:in 'Object#parse_payload'", "test.rb:11:in '<main>'"]
414
+ # end
415
+ #
416
+ # See [Backtraces](rdoc-ref:exceptions.md@Backtraces).
417
+ #
418
+ def set_backtrace: (String | Array[String]) -> Array[String]
419
+ | (Array[Thread::Backtrace::Location]) -> Array[Thread::Backtrace::Location]
240
420
  | (nil) -> nil
241
421
 
242
422
  # <!--
243
423
  # rdoc-file=error.c
244
- # - exception.to_s -> string
424
+ # - to_s -> string
245
425
  # -->
246
- # Returns exception's message (or the name of the exception if no message is
247
- # set).
426
+ # Returns a string representation of `self`:
427
+ #
428
+ # x = RuntimeError.new('Boom')
429
+ # x.to_s # => "Boom"
430
+ # x = RuntimeError.new
431
+ # x.to_s # => "RuntimeError"
248
432
  #
249
433
  def to_s: () -> String
250
434
 
251
435
  # <!--
252
436
  # rdoc-file=error.c
253
- # - exception.full_message(highlight: bool, order: [:top or :bottom]) -> string
437
+ # - full_message(highlight: true, order: :top) -> string
254
438
  # -->
255
- # Returns formatted string of *exception*. The returned string is formatted
256
- # using the same format that Ruby uses when printing an uncaught exceptions to
257
- # stderr.
439
+ # Returns an enhanced message string:
440
+ #
441
+ # * Includes the exception class name.
442
+ # * If the value of keyword `highlight` is true (not `nil` or `false`),
443
+ # includes bolding ANSI codes (see below) to enhance the appearance of the
444
+ # message.
445
+ # * Includes the [backtrace](rdoc-ref:exceptions.md@Backtraces):
446
+ #
447
+ # * If the value of keyword `order` is `:top` (the default), lists the
448
+ # error message and the innermost backtrace entry first.
449
+ # * If the value of keyword `order` is `:bottom`, lists the error message
450
+ # the the innermost entry last.
451
+ #
452
+ # Example:
453
+ #
454
+ # def baz
455
+ # begin
456
+ # 1 / 0
457
+ # rescue => x
458
+ # pp x.message
459
+ # pp x.full_message(highlight: false).split("\n")
460
+ # pp x.full_message.split("\n")
461
+ # end
462
+ # end
463
+ # def bar; baz; end
464
+ # def foo; bar; end
465
+ # foo
258
466
  #
259
- # If *highlight* is `true` the default error handler will send the messages to a
260
- # tty.
467
+ # Output:
261
468
  #
262
- # *order* must be either of `:top` or `:bottom`, and places the error message
263
- # and the innermost backtrace come at the top or the bottom.
469
+ # "divided by 0"
470
+ # ["t.rb:3:in 'Integer#/': divided by 0 (ZeroDivisionError)",
471
+ # "\tfrom t.rb:3:in 'Object#baz'",
472
+ # "\tfrom t.rb:10:in 'Object#bar'",
473
+ # "\tfrom t.rb:11:in 'Object#foo'",
474
+ # "\tfrom t.rb:12:in '<main>'"]
475
+ # ["t.rb:3:in 'Integer#/': \e[1mdivided by 0 (\e[1;4mZeroDivisionError\e[m\e[1m)\e[m",
476
+ # "\tfrom t.rb:3:in 'Object#baz'",
477
+ # "\tfrom t.rb:10:in 'Object#bar'",
478
+ # "\tfrom t.rb:11:in 'Object#foo'",
479
+ # "\tfrom t.rb:12:in '<main>'"]
264
480
  #
265
- # The default values of these options depend on `$stderr` and its `tty?` at the
266
- # timing of a call.
481
+ # An overriding method should be careful with ANSI code enhancements; see
482
+ # [Messages](rdoc-ref:exceptions.md@Messages).
267
483
  #
268
- def full_message: (?highlight: bool, ?order: :top | :bottom) -> String
484
+ def full_message: (?highlight: bool?, ?order: (:top | :bottom | string)?) -> String
269
485
  end