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/trace_point.rbs CHANGED
@@ -1,107 +1,121 @@
1
1
  # <!-- rdoc-file=trace_point.rb -->
2
- # Document-class: TracePoint
3
- #
4
- # A class that provides the functionality of Kernel#set_trace_func in a nice
5
- # Object-Oriented API.
2
+ # A class that provides the functionality of Kernel#set_trace_func in a
3
+ # well-structured Object-Oriented API.
6
4
  #
7
5
  # ## Example
8
6
  #
9
- # We can use TracePoint to gather information specifically for exceptions:
7
+ # Use TracePoint to gather information specifically for exceptions:
10
8
  #
11
9
  # trace = TracePoint.new(:raise) do |tp|
12
- # p [tp.lineno, tp.event, tp.raised_exception]
10
+ # p [tp.lineno, tp.event, tp.raised_exception]
13
11
  # end
14
12
  # #=> #<TracePoint:disabled>
15
13
  #
16
- # trace.enable
17
- # #=> false
14
+ # trace.enable #=> false
18
15
  #
19
16
  # 0 / 0
20
17
  # #=> [5, :raise, #<ZeroDivisionError: divided by 0>]
21
18
  #
22
19
  # ## Events
23
20
  #
24
- # If you don't specify the type of events you want to listen for, TracePoint
21
+ # If you don't specify the types of events you want to listen for, TracePoint
25
22
  # will include all available events.
26
23
  #
27
- # **Note** do not depend on current event set, as this list is subject to
28
- # change. Instead, it is recommended you specify the type of events you want to
24
+ # **Note:** Do not depend on the current event set, as this list is subject to
25
+ # change. Instead, it is recommended to specify the types of events you want to
29
26
  # use.
30
27
  #
31
28
  # To filter what is traced, you can pass any of the following as `events`:
32
29
  #
33
30
  # `:line`
34
- # : execute an expression or statement on a new line
31
+ # : Execute an expression or statement on a new line.
32
+ #
35
33
  # `:class`
36
- # : start a class or module definition
34
+ # : Start a class or module definition.
35
+ #
37
36
  # `:end`
38
- # : finish a class or module definition
37
+ # : Finish a class or module definition.
38
+ #
39
39
  # `:call`
40
- # : call a Ruby method
40
+ # : Call a Ruby method.
41
+ #
41
42
  # `:return`
42
- # : return from a Ruby method
43
+ # : Return from a Ruby method.
44
+ #
43
45
  # `:c_call`
44
- # : call a C-language routine
46
+ # : Call a C-language routine.
47
+ #
45
48
  # `:c_return`
46
- # : return from a C-language routine
49
+ # : Return from a C-language routine.
50
+ #
47
51
  # `:raise`
48
- # : raise an exception
52
+ # : Raise an exception.
53
+ #
54
+ # `:rescue`
55
+ # : Rescue an exception.
56
+ #
49
57
  # `:b_call`
50
- # : event hook at block entry
58
+ # : Event hook at block entry.
59
+ #
51
60
  # `:b_return`
52
- # : event hook at block ending
61
+ # : Event hook at block ending.
62
+ #
53
63
  # `:a_call`
54
- # : event hook at all calls (`call`, `b_call`, and `c_call`)
64
+ # : Event hook at all calls (`call`, `b_call`, and `c_call`).
65
+ #
55
66
  # `:a_return`
56
- # : event hook at all returns (`return`, `b_return`, and `c_return`)
67
+ # : Event hook at all returns (`return`, `b_return`, and `c_return`).
68
+ #
57
69
  # `:thread_begin`
58
- # : event hook at thread beginning
70
+ # : Event hook at thread beginning.
71
+ #
59
72
  # `:thread_end`
60
- # : event hook at thread ending
73
+ # : Event hook at thread ending.
74
+ #
61
75
  # `:fiber_switch`
62
- # : event hook at fiber switch
76
+ # : Event hook at fiber switch.
77
+ #
63
78
  # `:script_compiled`
64
- # : new Ruby code compiled (with `eval`, `load` or `require`)
79
+ # : New Ruby code compiled (with `eval`, `load`, or `require`).
65
80
  #
66
- class TracePoint < Object
81
+ class TracePoint
67
82
  # <!--
68
83
  # rdoc-file=trace_point.rb
69
- # - TracePoint.new(*events) { |obj| block } -> obj
84
+ # - TracePoint.new(*events) { |tp| block } -> tp
70
85
  # -->
71
86
  # Returns a new TracePoint object, not enabled by default.
72
87
  #
73
- # Next, in order to activate the trace, you must use TracePoint#enable
88
+ # To activate the TracePoint object, use TracePoint#enable:
74
89
  #
75
90
  # trace = TracePoint.new(:call) do |tp|
76
- # p [tp.lineno, tp.defined_class, tp.method_id, tp.event]
91
+ # p [tp.lineno, tp.defined_class, tp.method_id, tp.event]
77
92
  # end
78
93
  # #=> #<TracePoint:disabled>
79
94
  #
80
- # trace.enable
81
- # #=> false
95
+ # trace.enable #=> false
82
96
  #
83
97
  # puts "Hello, TracePoint!"
84
98
  # # ...
85
99
  # # [48, IRB::Notifier::AbstractNotifier, :printf, :call]
86
100
  # # ...
87
101
  #
88
- # When you want to deactivate the trace, you must use TracePoint#disable
102
+ # To deactivate the trace, use TracePoint#disable.
89
103
  #
90
104
  # trace.disable
91
105
  #
92
106
  # See TracePoint@Events for possible events and more information.
93
107
  #
94
- # A block must be given, otherwise an ArgumentError is raised.
108
+ # A block must be given; otherwise, an ArgumentError is raised.
95
109
  #
96
110
  # If the trace method isn't included in the given events filter, a RuntimeError
97
111
  # is raised.
98
112
  #
99
113
  # TracePoint.trace(:line) do |tp|
100
- # p tp.raised_exception
114
+ # p tp.raised_exception
101
115
  # end
102
116
  # #=> RuntimeError: 'raised_exception' not supported by this event
103
117
  #
104
- # If the trace method is called outside block, a RuntimeError is raised.
118
+ # If the trace method is called outside a block, a RuntimeError is raised.
105
119
  #
106
120
  # TracePoint.trace(:line) do |tp|
107
121
  # $tp = tp
@@ -110,21 +124,68 @@ class TracePoint < Object
110
124
  #
111
125
  # Access from other threads is also forbidden.
112
126
  #
113
- def initialize: (*Symbol events) { (TracePoint tp) -> void } -> void
127
+ def self.new: (*_ToSym events) { (instance tp) -> void } -> instance
114
128
 
115
129
  # <!--
116
130
  # rdoc-file=trace_point.rb
117
- # - TracePoint.allow_reentry
131
+ # - TracePoint.allow_reentry { block }
118
132
  # -->
119
- # In general, while a TracePoint callback is running, other registered callbacks
120
- # are not called to avoid confusion by reentrance. This method allows the
121
- # reentrance in a given block. This method should be used carefully, otherwise
122
- # the callback can be easily called infinitely.
133
+ # Generally, while a TracePoint callback is running, other registered callbacks
134
+ # are not called to avoid confusion from reentrance. This method allows
135
+ # reentrance within a given block. Use this method carefully to avoid infinite
136
+ # callback invocation.
137
+ #
138
+ # If called when reentrance is already allowed, it raises a RuntimeError.
139
+ #
140
+ # **Example:**
141
+ #
142
+ # # Without reentry
143
+ # # ---------------
123
144
  #
124
- # If this method is called when the reentrance is already allowed, it raises a
125
- # RuntimeError.
145
+ # line_handler = TracePoint.new(:line) do |tp|
146
+ # next if tp.path != __FILE__ # Only works in this file
147
+ # puts "Line handler"
148
+ # binding.eval("class C; end")
149
+ # end.enable
126
150
  #
127
- def self.allow_reentry: () { () -> void } -> void
151
+ # class_handler = TracePoint.new(:class) do |tp|
152
+ # puts "Class handler"
153
+ # end.enable
154
+ #
155
+ # class B
156
+ # end
157
+ #
158
+ # # This script will print "Class handler" only once: when inside the :line
159
+ # # handler, all other handlers are ignored.
160
+ #
161
+ # # With reentry
162
+ # # ------------
163
+ #
164
+ # line_handler = TracePoint.new(:line) do |tp|
165
+ # next if tp.path != __FILE__ # Only works in this file
166
+ # next if (__LINE__..__LINE__+3).cover?(tp.lineno) # Prevent infinite calls
167
+ # puts "Line handler"
168
+ # TracePoint.allow_reentry { binding.eval("class C; end") }
169
+ # end.enable
170
+ #
171
+ # class_handler = TracePoint.new(:class) do |tp|
172
+ # puts "Class handler"
173
+ # end.enable
174
+ #
175
+ # class B
176
+ # end
177
+ #
178
+ # # This will print "Class handler" twice: inside the allow_reentry block in the :line
179
+ # # handler, other handlers are enabled.
180
+ #
181
+ # Note that the example shows the principal effect of the method, but its
182
+ # practical usage is for debugging libraries that sometimes require other
183
+ # libraries' hooks to not be affected by the debugger being inside trace point
184
+ # handling. Precautions should be taken against infinite recursion in this case
185
+ # (note that we needed to filter out calls by itself from the :line handler,
186
+ # otherwise it would call itself infinitely).
187
+ #
188
+ def self.allow_reentry: [T] () { (nil) -> T } -> T
128
189
 
129
190
  # <!--
130
191
  # rdoc-file=trace_point.rb
@@ -132,8 +193,8 @@ class TracePoint < Object
132
193
  # -->
133
194
  # Returns internal information of TracePoint.
134
195
  #
135
- # The contents of the returned value are implementation specific. It may be
136
- # changed in future.
196
+ # The contents of the returned value are implementation-specific and may change
197
+ # in the future.
137
198
  #
138
199
  # This method is only for debugging TracePoint itself.
139
200
  #
@@ -141,43 +202,42 @@ class TracePoint < Object
141
202
 
142
203
  # <!--
143
204
  # rdoc-file=trace_point.rb
144
- # - TracePoint.trace(*events) { |obj| block } -> obj
205
+ # - TracePoint.trace(*events) { |tp| block } -> obj
145
206
  # -->
146
- # A convenience method for TracePoint.new, that activates the trace
207
+ # A convenience method for TracePoint.new that activates the trace
147
208
  # automatically.
148
209
  #
149
210
  # trace = TracePoint.trace(:call) { |tp| [tp.lineno, tp.event] }
150
211
  # #=> #<TracePoint:enabled>
151
212
  #
152
- # trace.enabled? #=> true
213
+ # trace.enabled? #=> true
153
214
  #
154
- def self.trace: (*Symbol events) { (TracePoint tp) -> void } -> TracePoint
215
+ def self.trace: (*_ToSym events) { (instance tp) -> void } -> instance
155
216
 
156
217
  # <!--
157
218
  # rdoc-file=trace_point.rb
158
219
  # - binding()
159
220
  # -->
160
- # Return the generated binding object from event.
221
+ # Returns the generated binding object from the event.
161
222
  #
162
- # Note that for `c_call` and `c_return` events, the binding returned is the
163
- # binding of the nearest Ruby method calling the C method, since C methods
164
- # themselves do not have bindings.
223
+ # Note that for `:c_call` and `:c_return` events, the method returns `nil`,
224
+ # since C methods themselves do not have bindings.
165
225
  #
166
- def binding: () -> Binding
226
+ def binding: () -> Binding?
167
227
 
168
228
  # <!--
169
229
  # rdoc-file=trace_point.rb
170
230
  # - callee_id()
171
231
  # -->
172
- # Return the called name of the method being called
232
+ # Returns the called name of the method being called.
173
233
  #
174
- def callee_id: () -> Symbol
234
+ def callee_id: () -> Symbol?
175
235
 
176
236
  # <!--
177
237
  # rdoc-file=trace_point.rb
178
238
  # - defined_class()
179
239
  # -->
180
- # Return class or module of the method being called.
240
+ # Returns the class or module of the method being called.
181
241
  #
182
242
  # class C; def foo; end; end
183
243
  # trace = TracePoint.new(:call) do |tp|
@@ -186,20 +246,20 @@ class TracePoint < Object
186
246
  # C.new.foo
187
247
  # end
188
248
  #
189
- # If method is defined by a module, then that module is returned.
249
+ # If the method is defined by a module, then that module is returned.
190
250
  #
191
251
  # module M; def foo; end; end
192
- # class C; include M; end;
252
+ # class C; include M; end
193
253
  # trace = TracePoint.new(:call) do |tp|
194
254
  # p tp.defined_class #=> M
195
255
  # end.enable do
196
256
  # C.new.foo
197
257
  # end
198
258
  #
199
- # **Note:** #defined_class returns singleton class.
259
+ # **Note:** #defined_class returns the singleton class.
200
260
  #
201
- # 6th block parameter of Kernel#set_trace_func passes original class of attached
202
- # by singleton class.
261
+ # The 6th block parameter of Kernel#set_trace_func passes the original class
262
+ # attached by the singleton class.
203
263
  #
204
264
  # **This is a difference between Kernel#set_trace_func and TracePoint.**
205
265
  #
@@ -210,35 +270,34 @@ class TracePoint < Object
210
270
  # C.foo
211
271
  # end
212
272
  #
213
- def defined_class: () -> Module
273
+ def defined_class: () -> (Class | Module)?
214
274
 
215
275
  # <!--
216
276
  # rdoc-file=trace_point.rb
217
- # - trace.disable -> true or false
277
+ # - trace.disable -> true or false
218
278
  # - trace.disable { block } -> obj
219
279
  # -->
220
- # Deactivates the trace
280
+ # Deactivates the trace.
221
281
  #
222
- # Return true if trace was enabled. Return false if trace was disabled.
282
+ # Returns `true` if the trace was enabled. Returns `false` if the trace was
283
+ # disabled.
223
284
  #
224
- # trace.enabled? #=> true
225
- # trace.disable #=> true (previous status)
226
- # trace.enabled? #=> false
227
- # trace.disable #=> false
285
+ # trace.enabled? #=> true
286
+ # trace.disable #=> true (previous status)
287
+ # trace.enabled? #=> false
288
+ # trace.disable #=> false
228
289
  #
229
- # If a block is given, the trace will only be disable within the scope of the
290
+ # If a block is given, the trace will only be disabled within the scope of the
230
291
  # block.
231
292
  #
232
- # trace.enabled?
233
- # #=> true
293
+ # trace.enabled? #=> true
234
294
  #
235
295
  # trace.disable do
236
- # trace.enabled?
237
- # # only disabled for this block
296
+ # trace.enabled?
297
+ # # Only disabled for this block
238
298
  # end
239
299
  #
240
- # trace.enabled?
241
- # #=> true
300
+ # trace.enabled? #=> true
242
301
  #
243
302
  # Note: You cannot access event hooks within the block.
244
303
  #
@@ -246,16 +305,17 @@ class TracePoint < Object
246
305
  # #=> RuntimeError: access from outside
247
306
  #
248
307
  def disable: () -> bool
249
- | () { () -> void } -> void
308
+ | [T] () { () -> T } -> T
250
309
 
251
310
  # <!--
252
311
  # rdoc-file=trace_point.rb
253
- # - trace.enable(target: nil, target_line: nil, target_thread: nil) -> true or false
254
- # - trace.enable(target: nil, target_line: nil, target_thread: nil) { block } -> obj
312
+ # - trace.enable(target: nil, target_line: nil, target_thread: nil) -> true or false
313
+ # - trace.enable(target: nil, target_line: nil, target_thread: :default) { block } -> obj
255
314
  # -->
256
315
  # Activates the trace.
257
316
  #
258
- # Returns `true` if trace was enabled. Returns `false` if trace was disabled.
317
+ # Returns `true` if the trace was enabled. Returns `false` if the trace was
318
+ # disabled.
259
319
  #
260
320
  # trace.enabled? #=> false
261
321
  # trace.enable #=> false (previous state)
@@ -264,23 +324,22 @@ class TracePoint < Object
264
324
  # trace.enable #=> true (previous state)
265
325
  # # trace is still enabled
266
326
  #
267
- # If a block is given, the trace will only be enabled within the scope of the
268
- # block.
327
+ # If a block is given, the trace will only be enabled during the block
328
+ # execution. If target and target_line are both nil, then target_thread will
329
+ # default to the current thread if a block is given.
269
330
  #
270
- # trace.enabled?
271
- # #=> false
331
+ # trace.enabled? #=> false
272
332
  #
273
333
  # trace.enable do
274
334
  # trace.enabled?
275
- # # only enabled for this block
335
+ # # Only enabled for this block and thread
276
336
  # end
277
337
  #
278
- # trace.enabled?
279
- # #=> false
338
+ # trace.enabled? #=> false
280
339
  #
281
- # `target`, `target_line` and `target_thread` parameters are used to limit
282
- # tracing only to specified code objects. `target` should be a code object for
283
- # which RubyVM::InstructionSequence.of will return an instruction sequence.
340
+ # The `target`, `target_line`, and `target_thread` parameters are used to limit
341
+ # tracing to specified code objects. `target` should be a code object for which
342
+ # RubyVM::InstructionSequence.of will return an instruction sequence.
284
343
  #
285
344
  # t = TracePoint.new(:line) { |tp| p tp }
286
345
  #
@@ -295,23 +354,23 @@ class TracePoint < Object
295
354
  # t.enable(target: method(:m1))
296
355
  #
297
356
  # m1
298
- # # prints #<TracePoint:line test.rb:4 in `m1'>
357
+ # # Prints #<TracePoint:line test.rb:4 in `m1'>
299
358
  # m2
300
- # # prints nothing
359
+ # # Prints nothing
301
360
  #
302
361
  # Note: You cannot access event hooks within the `enable` block.
303
362
  #
304
363
  # trace.enable { p tp.lineno }
305
364
  # #=> RuntimeError: access from outside
306
365
  #
307
- def enable: (?target: (Method | UnboundMethod | Proc)?, ?target_line: Integer?, ?target_thread: Thread?) -> bool
308
- | [R] (?target: (Method | UnboundMethod | Proc)?, ?target_line: Integer?, ?target_thread: Thread?) { () -> R } -> R
366
+ def enable: (?target: Method | UnboundMethod | RubyVM::InstructionSequence | Proc | nil, ?target_line: int?, ?target_thread: Thread | :default | nil) -> bool
367
+ | [T] (?target: Method | UnboundMethod | RubyVM::InstructionSequence | Proc | nil, ?target_line: int?, ?target_thread: Thread | :default | nil) { () -> T } -> T
309
368
 
310
369
  # <!--
311
370
  # rdoc-file=trace_point.rb
312
- # - trace.enabled? -> true or false
371
+ # - trace.enabled? -> true or false
313
372
  # -->
314
- # The current status of the trace
373
+ # Returns the current status of the trace.
315
374
  #
316
375
  def enabled?: () -> bool
317
376
 
@@ -319,7 +378,7 @@ class TracePoint < Object
319
378
  # rdoc-file=trace_point.rb
320
379
  # - event()
321
380
  # -->
322
- # Type of event
381
+ # Returns the type of event.
323
382
  #
324
383
  # See TracePoint@Events for more information.
325
384
  #
@@ -327,9 +386,9 @@ class TracePoint < Object
327
386
 
328
387
  # <!--
329
388
  # rdoc-file=trace_point.rb
330
- # - trace.inspect -> string
389
+ # - trace.inspect -> string
331
390
  # -->
332
- # Return a string containing a human-readable TracePoint status.
391
+ # Returns a string containing a human-readable TracePoint status.
333
392
  #
334
393
  def inspect: () -> String
335
394
 
@@ -337,7 +396,7 @@ class TracePoint < Object
337
396
  # rdoc-file=trace_point.rb
338
397
  # - lineno()
339
398
  # -->
340
- # Line number of the event
399
+ # Returns the line number of the event.
341
400
  #
342
401
  def lineno: () -> Integer
343
402
 
@@ -345,15 +404,15 @@ class TracePoint < Object
345
404
  # rdoc-file=trace_point.rb
346
405
  # - method_id()
347
406
  # -->
348
- # Return the name at the definition of the method being called
407
+ # Returns the name at the definition of the method being called.
349
408
  #
350
- def method_id: () -> Symbol
409
+ def method_id: () -> Symbol?
351
410
 
352
411
  # <!--
353
412
  # rdoc-file=trace_point.rb
354
413
  # - path()
355
414
  # -->
356
- # Path of the file being run
415
+ # Returns the path of the file being executed.
357
416
  #
358
417
  def path: () -> String
359
418
 
@@ -361,24 +420,25 @@ class TracePoint < Object
361
420
  # rdoc-file=trace_point.rb
362
421
  # - parameters()
363
422
  # -->
364
- # Return the parameters definition of the method or block that the current hook
365
- # belongs to. Format is the same as for Method#parameters
423
+ # Returns the parameter definitions of the method or block that the current hook
424
+ # belongs to. The format is the same as for Method#parameters.
366
425
  #
367
- def parameters: () -> ::Array[[ :req | :opt | :rest | :keyreq | :key | :keyrest | :block, Symbol ] | [ :rest | :keyrest ]]
426
+ def parameters: () -> Method::param_types?
368
427
 
369
428
  # <!--
370
429
  # rdoc-file=trace_point.rb
371
430
  # - raised_exception()
372
431
  # -->
373
- # Value from exception raised on the `:raise` event
432
+ # Returns the exception raised on the `:raise` event or rescued on the `:rescue`
433
+ # event.
374
434
  #
375
- def raised_exception: () -> untyped
435
+ def raised_exception: () -> Exception
376
436
 
377
437
  # <!--
378
438
  # rdoc-file=trace_point.rb
379
439
  # - return_value()
380
440
  # -->
381
- # Return value from `:return`, `c_return`, and `b_return` event
441
+ # Returns the return value from `:return`, `:c_return`, and `:b_return` events.
382
442
  #
383
443
  def return_value: () -> untyped
384
444
 
@@ -386,10 +446,10 @@ class TracePoint < Object
386
446
  # rdoc-file=trace_point.rb
387
447
  # - self()
388
448
  # -->
389
- # Return the trace object during event
449
+ # Returns the trace object during the event.
390
450
  #
391
- # Same as the following, except it returns the correct object (the method
392
- # receiver) for `c_call` and `c_return` events:
451
+ # Similar to the following, but it returns the correct object (the method
452
+ # receiver) for `:c_call` and `:c_return` events:
393
453
  #
394
454
  # trace.binding.eval('self')
395
455
  #
@@ -399,8 +459,8 @@ class TracePoint < Object
399
459
  # rdoc-file=trace_point.rb
400
460
  # - eval_script()
401
461
  # -->
402
- # Compiled source code (String) on *eval methods on the `:script_compiled`
403
- # event. If loaded from a file, it will return nil.
462
+ # Returns the compiled source code (String) from eval methods on the
463
+ # `:script_compiled` event. If loaded from a file, it returns `nil`.
404
464
  #
405
465
  def eval_script: () -> String?
406
466
 
@@ -408,10 +468,10 @@ class TracePoint < Object
408
468
  # rdoc-file=trace_point.rb
409
469
  # - instruction_sequence()
410
470
  # -->
411
- # Compiled instruction sequence represented by a RubyVM::InstructionSequence
412
- # instance on the `:script_compiled` event.
471
+ # Returns the compiled instruction sequence represented by a
472
+ # RubyVM::InstructionSequence instance on the `:script_compiled` event.
413
473
  #
414
- # Note that this method is MRI specific.
474
+ # Note that this method is CRuby-specific.
415
475
  #
416
476
  def instruction_sequence: () -> RubyVM::InstructionSequence
417
477
  end