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/float.rbs CHANGED
@@ -6,138 +6,75 @@
6
6
  # should know its esoteric system. See following:
7
7
  #
8
8
  # * https://docs.oracle.com/cd/E19957-01/806-3568/ncg_goldberg.html
9
- # * https://github.com/rdp/ruby_tutorials_core/wiki/Ruby-Talk-FAQ#floats_impre
10
- # cise
9
+ # * https://github.com/rdp/ruby_tutorials_core/wiki/Ruby-Talk-FAQ#-why-are-rub
10
+ # ys-floats-imprecise
11
11
  # * https://en.wikipedia.org/wiki/Floating_point#Accuracy_problems
12
12
  #
13
- #
14
13
  # You can create a Float object explicitly with:
15
14
  #
16
- # * A [floating-point
17
- # literal](doc/syntax/literals_rdoc.html#label-Float+Literals).
18
- #
15
+ # * A [floating-point literal](rdoc-ref:syntax/literals.rdoc@Float+Literals).
19
16
  #
20
17
  # You can convert certain objects to Floats with:
21
18
  #
22
- # * Method [Float](Kernel.html#method-i-Float).
23
- #
19
+ # * Method #Float.
24
20
  #
25
21
  # ## What's Here
26
22
  #
27
23
  # First, what's elsewhere. Class Float:
28
24
  #
29
- # * Inherits from [class
30
- # Numeric](Numeric.html#class-Numeric-label-What-27s+Here).
31
- #
25
+ # * Inherits from [class Numeric](rdoc-ref:Numeric@What-27s+Here) and [class
26
+ # Object](rdoc-ref:Object@What-27s+Here).
27
+ # * Includes [module Comparable](rdoc-ref:Comparable@What-27s+Here).
32
28
  #
33
29
  # Here, class Float provides methods for:
34
30
  #
35
- # * [Querying](#class-Float-label-Querying)
36
- # * [Comparing](#class-Float-label-Comparing)
37
- # * [Converting](#class-Float-label-Converting)
38
- #
31
+ # * [Querying](rdoc-ref:Float@Querying)
32
+ # * [Comparing](rdoc-ref:Float@Comparing)
33
+ # * [Converting](rdoc-ref:Float@Converting)
39
34
  #
40
35
  # ### Querying
41
36
  #
42
- # #finite?
43
- # : Returns whether `self` is finite.
44
- #
45
- # #hash
46
- # : Returns the integer hash code for `self`.
47
- #
48
- # #infinite?
49
- # : Returns whether `self` is infinite.
50
- #
51
- # #nan?
52
- # : Returns whether `self` is a NaN (not-a-number).
53
- #
54
- #
37
+ # * #finite?: Returns whether `self` is finite.
38
+ # * #hash: Returns the integer hash code for `self`.
39
+ # * #infinite?: Returns whether `self` is infinite.
40
+ # * #nan?: Returns whether `self` is a NaN (not-a-number).
55
41
  #
56
42
  # ### Comparing
57
43
  #
58
- # [<](#method-i-3C)
59
- # : Returns whether `self` is less than the given value.
60
- #
61
- # [<=](#method-i-3C-3D)
62
- # : Returns whether `self` is less than or equal to the given value.
63
- #
64
- # [<=>](#method-i-3C-3D-3E)
65
- # : Returns a number indicating whether `self` is less than, equal to, or
66
- # greater than the given value.
67
- #
68
- # [==](#method-i-3D-3D) (aliased as #=== and #eql>)
69
- # : Returns whether `self` is equal to the given value.
70
- #
71
- # [>](#method-i-3E)
72
- # : Returns whether `self` is greater than the given value.
73
- #
74
- # [>=](#method-i-3E-3D)
75
- # : Returns whether `self` is greater than or equal to the given value.
76
- #
77
- #
44
+ # * #<: Returns whether `self` is less than the given value.
45
+ # * #<=: Returns whether `self` is less than or equal to the given value.
46
+ # * #<=>: Returns a number indicating whether `self` is less than, equal to,
47
+ # or greater than the given value.
48
+ # * #== (aliased as #=== and #eql?): Returns whether `self` is equal to the
49
+ # given value.
50
+ # * #>: Returns whether `self` is greater than the given value.
51
+ # * #>=: Returns whether `self` is greater than or equal to the given value.
78
52
  #
79
53
  # ### Converting
80
54
  #
81
- # #% (aliased as #modulo)
82
- # : Returns `self` modulo the given value.
83
- #
84
- # #*
85
- # : Returns the product of `self` and the given value.
86
- #
87
- # [**](#method-i-2A-2A)
88
- # : Returns the value of `self` raised to the power of the given value.
89
- #
90
- # #+
91
- # : Returns the sum of `self` and the given value.
92
- #
93
- # #-
94
- # : Returns the difference of `self` and the given value.
95
- #
96
- # [/](#method-i-2F)
97
- # : Returns the quotient of `self` and the given value.
98
- #
99
- # #ceil
100
- # : Returns the smallest number greater than or equal to `self`.
101
- #
102
- # #coerce
103
- # : Returns a 2-element array containing the given value converted to a
104
- # Float and `self`
105
- #
106
- # #divmod
107
- # : Returns a 2-element array containing the quotient and remainder
108
- # results of dividing `self` by the given value.
109
- #
110
- # #fdiv
111
- # : Returns the Float result of dividing `self` by the given value.
112
- #
113
- # #floor
114
- # : Returns the greatest number smaller than or equal to `self`.
115
- #
116
- # #next_float
117
- # : Returns the next-larger representable Float.
118
- #
119
- # #prev_float
120
- # : Returns the next-smaller representable Float.
121
- #
122
- # #quo
123
- # : Returns the quotient from dividing `self` by the given value.
124
- #
125
- # #round
126
- # : Returns `self` rounded to the nearest value, to a given precision.
127
- #
128
- # #to_i (aliased as #to_int)
129
- # : Returns `self` truncated to an Integer.
130
- #
131
- # #to_s (aliased as #inspect)
132
- # : Returns a string containing the place-value representation of `self`
133
- # in the given radix.
134
- #
135
- # #truncate
136
- # : Returns `self` truncated to a given precision.
55
+ # * #% (aliased as #modulo): Returns `self` modulo the given value.
56
+ # * #*: Returns the product of `self` and the given value.
57
+ # * #**: Returns the value of `self` raised to the power of the given value.
58
+ # * #+: Returns the sum of `self` and the given value.
59
+ # * #-: Returns the difference of `self` and the given value.
60
+ # * #/: Returns the quotient of `self` and the given value.
61
+ # * #ceil: Returns the smallest number greater than or equal to `self`.
62
+ # * #coerce: Returns a 2-element array containing the given value converted to
63
+ # a Float and `self`
64
+ # * #divmod: Returns a 2-element array containing the quotient and remainder
65
+ # results of dividing `self` by the given value.
66
+ # * #fdiv: Returns the Float result of dividing `self` by the given value.
67
+ # * #floor: Returns the greatest number smaller than or equal to `self`.
68
+ # * #next_float: Returns the next-larger representable Float.
69
+ # * #prev_float: Returns the next-smaller representable Float.
70
+ # * #quo: Returns the quotient from dividing `self` by the given value.
71
+ # * #round: Returns `self` rounded to the nearest value, to a given precision.
72
+ # * #to_i (aliased as #to_int): Returns `self` truncated to an Integer.
73
+ # * #to_s (aliased as #inspect): Returns a string containing the place-value
74
+ # representation of `self` in the given radix.
75
+ # * #truncate: Returns `self` truncated to a given precision.
137
76
  #
138
77
  class Float < Numeric
139
- public
140
-
141
78
  # <!--
142
79
  # rdoc-file=numeric.c
143
80
  # - self % other -> float
@@ -165,8 +102,6 @@ class Float < Numeric
165
102
  # 10.0 % 4.0 # => 2.0
166
103
  # 10.0 % Rational(4, 1) # => 2.0
167
104
  #
168
- # Float#modulo is an alias for Float#%.
169
- #
170
105
  def %: (Integer) -> Float
171
106
  | (Float) -> Float
172
107
  | (Rational) -> Float
@@ -237,9 +172,9 @@ class Float < Numeric
237
172
 
238
173
  # <!--
239
174
  # rdoc-file=numeric.rb
240
- # - -float -> float
175
+ # - -float -> float
241
176
  # -->
242
- # Returns `float`, negated.
177
+ # Returns `self`, negated.
243
178
  #
244
179
  def -@: () -> Float
245
180
 
@@ -301,7 +236,6 @@ class Float < Numeric
301
236
  # * 1, if `self` is greater than `other`.
302
237
  # * `nil`, if the two values are incommensurate.
303
238
  #
304
- #
305
239
  # Examples:
306
240
  #
307
241
  # 2.0 <=> 2 # => 0
@@ -382,33 +316,28 @@ class Float < Numeric
382
316
 
383
317
  # <!--
384
318
  # rdoc-file=numeric.rb
385
- # - float.abs -> float
386
- # - float.magnitude -> float
319
+ # - float.abs -> float
387
320
  # -->
388
- # Returns the absolute value of `float`.
321
+ # Returns the absolute value of `self`:
389
322
  #
390
- # (-34.56).abs #=> 34.56
391
- # -34.56.abs #=> 34.56
392
- # 34.56.abs #=> 34.56
393
- #
394
- # Float#magnitude is an alias for Float#abs.
323
+ # (-34.56).abs # => 34.56
324
+ # -34.56.abs # => 34.56
325
+ # 34.56.abs # => 34.56
395
326
  #
396
327
  def abs: () -> Float
397
328
 
398
329
  def abs2: () -> Float
399
330
 
400
331
  # <!-- rdoc-file=complex.c -->
401
- # Returns 0 if the value is positive, pi otherwise.
332
+ # Returns 0 if `self` is positive, Math::PI otherwise.
402
333
  #
403
334
  def angle: () -> (Integer | Float)
404
335
 
405
336
  # <!--
406
337
  # rdoc-file=complex.c
407
- # - flo.arg -> 0 or float
408
- # - flo.angle -> 0 or float
409
- # - flo.phase -> 0 or float
338
+ # - arg -> 0 or Math::PI
410
339
  # -->
411
- # Returns 0 if the value is positive, pi otherwise.
340
+ # Returns 0 if `self` is positive, Math::PI otherwise.
412
341
  #
413
342
  alias arg angle
414
343
 
@@ -416,33 +345,58 @@ class Float < Numeric
416
345
  # rdoc-file=numeric.c
417
346
  # - ceil(ndigits = 0) -> float or integer
418
347
  # -->
419
- # Returns the smallest number greater than or equal to `self` with a precision
420
- # of `ndigits` decimal digits.
421
- #
422
- # When `ndigits` is positive, returns a float with `ndigits` digits after the
423
- # decimal point (as available):
424
- #
348
+ # Returns a numeric that is a "ceiling" value for `self`,
349
+ # as specified by the given `ndigits`,
350
+ # which must be an
351
+ # [integer-convertible
352
+ # object](rdoc-ref:implicit_conversion.rdoc@Integer-Convertible+Objects).
353
+ # When `ndigits` is positive, returns a Float with `ndigits`
354
+ # decimal digits after the decimal point
355
+ # (as available, but no fewer than 1):
425
356
  # f = 12345.6789
426
- # f.ceil(1) # => 12345.7
427
- # f.ceil(3) # => 12345.679
428
- # f = -12345.6789
429
- # f.ceil(1) # => -12345.6
430
- # f.ceil(3) # => -12345.678
431
- #
432
- # When `ndigits` is non-positive, returns an integer with at least `ndigits.abs`
433
- # trailing zeros:
434
- #
435
- # f = 12345.6789
436
- # f.ceil(0) # => 12346
437
- # f.ceil(-3) # => 13000
438
- # f = -12345.6789
439
- # f.ceil(0) # => -12345
440
- # f.ceil(-3) # => -12000
441
- #
442
- # Note that the limited precision of floating-point arithmetic may lead to
443
- # surprising results:
444
- #
445
- # (2.1 / 0.7).ceil #=> 4 (!)
357
+ # f.ceil(1) # => 12345.7
358
+ # f.ceil(3) # => 12345.679
359
+ # f.ceil(30) # => 12345.6789
360
+ # f = -12345.6789
361
+ # f.ceil(1) # => -12345.6
362
+ # f.ceil(3) # => -12345.678
363
+ # f.ceil(30) # => -12345.6789
364
+ # f = 0.0
365
+ # f.ceil(1) # => 0.0
366
+ # f.ceil(100) # => 0.0
367
+ #
368
+ # When `ndigits` is non-positive,
369
+ # returns an Integer based on a computed granularity:
370
+ # * The granularity is `10 ** ndigits.abs`.
371
+ # * The returned value is the largest multiple of the granularity
372
+ # that is less than or equal to `self`.
373
+ # Examples with positive `self`:
374
+ # ndigits|Granularity|12345.6789.ceil(ndigits)
375
+ # -------|-----------|------------------------
376
+ # 0| 1| 12346
377
+ # -1| 10| 12350
378
+ # -2| 100| 12400
379
+ # -3| 1000| 13000
380
+ # -4| 10000| 20000
381
+ # -5| 100000| 100000
382
+ # Examples with negative `self`:
383
+ # ndigits|Granularity|-12345.6789.ceil(ndigits)
384
+ # -------|-----------|-------------------------
385
+ # 0| 1| -12345
386
+ # -1| 10| -12340
387
+ # -2| 100| -12300
388
+ # -3| 1000| -12000
389
+ # -4| 10000| -10000
390
+ # -5| 100000| 0
391
+ # When `self` is zero and `ndigits` is non-positive,
392
+ # returns Integer zero:
393
+ # 0.0.ceil(0) # => 0
394
+ # 0.0.ceil(-1) # => 0
395
+ # 0.0.ceil(-2) # => 0
396
+ #
397
+ # Note that the limited precision of floating-point arithmetic
398
+ # may lead to surprising results:
399
+ # (2.1 / 0.7).ceil #=> 4 # Not 3 (because 2.1 / 0.7 # => 3.0000000000000004, not 3.0)
446
400
  #
447
401
  # Related: Float#floor.
448
402
  #
@@ -505,7 +459,8 @@ class Float < Numeric
505
459
  # 13.0.divmod(4.0) # => [3, 1.0]
506
460
  # 13.0.divmod(Rational(4, 1)) # => [3, 1.0]
507
461
  #
508
- def divmod: (Numeric) -> [ Numeric, Numeric ]
462
+ def divmod: (Integer | Float | Rational) -> [ Integer, Float ]
463
+ | (Numeric) -> [ Numeric, Numeric ]
509
464
 
510
465
  def dup: () -> self
511
466
 
@@ -537,8 +492,6 @@ class Float < Numeric
537
492
  # f.quo(Rational(2, 1)) # => 1.57
538
493
  # f.quo(Complex(2, 0)) # => (1.57+0.0i)
539
494
  #
540
- # Float#fdiv is an alias for Float#quo.
541
- #
542
495
  def fdiv: (Complex) -> Complex
543
496
  | (Numeric) -> Float
544
497
 
@@ -546,7 +499,7 @@ class Float < Numeric
546
499
  # rdoc-file=numeric.c
547
500
  # - finite? -> true or false
548
501
  # -->
549
- # Returns `true` if `self` is not `Infinity`, `-Infinity`, or `Nan`, `false`
502
+ # Returns `true` if `self` is not `Infinity`, `-Infinity`, or `NaN`, `false`
550
503
  # otherwise:
551
504
  #
552
505
  # f = 2.0 # => 2.0
@@ -564,33 +517,59 @@ class Float < Numeric
564
517
  # rdoc-file=numeric.c
565
518
  # - floor(ndigits = 0) -> float or integer
566
519
  # -->
567
- # Returns the largest number less than or equal to `self` with a precision of
568
- # `ndigits` decimal digits.
569
- #
570
- # When `ndigits` is positive, returns a float with `ndigits` digits after the
571
- # decimal point (as available):
572
- #
573
- # f = 12345.6789
574
- # f.floor(1) # => 12345.6
575
- # f.floor(3) # => 12345.678
576
- # f = -12345.6789
577
- # f.floor(1) # => -12345.7
578
- # f.floor(3) # => -12345.679
579
- #
580
- # When `ndigits` is non-positive, returns an integer with at least `ndigits.abs`
581
- # trailing zeros:
582
- #
520
+ # Returns a float or integer that is a "floor" value for `self`,
521
+ # as specified by `ndigits`,
522
+ # which must be an
523
+ # [integer-convertible
524
+ # object](rdoc-ref:implicit_conversion.rdoc@Integer-Convertible+Objects).
525
+ # When `self` is zero,
526
+ # returns a zero value:
527
+ # a float if `ndigits` is positive,
528
+ # an integer otherwise:
529
+ # f = 0.0 # => 0.0
530
+ # f.floor(20) # => 0.0
531
+ # f.floor(0) # => 0
532
+ # f.floor(-20) # => 0
533
+ #
534
+ # When `self` is non-zero and `ndigits` is positive, returns a float with
535
+ # `ndigits`
536
+ # digits after the decimal point (as available):
583
537
  # f = 12345.6789
584
- # f.floor(0) # => 12345
585
- # f.floor(-3) # => 12000
586
- # f = -12345.6789
587
- # f.floor(0) # => -12346
588
- # f.floor(-3) # => -13000
589
- #
590
- # Note that the limited precision of floating-point arithmetic may lead to
591
- # surprising results:
592
- #
593
- # (0.3 / 0.1).floor #=> 2 (!)
538
+ # f.floor(1) # => 12345.6
539
+ # f.floor(3) # => 12345.678
540
+ # f.floor(30) # => 12345.6789
541
+ # f = -12345.6789
542
+ # f.floor(1) # => -12345.7
543
+ # f.floor(3) # => -12345.679
544
+ # f.floor(30) # => -12345.6789
545
+ #
546
+ # When `self` is non-zero and `ndigits` is non-positive,
547
+ # returns an integer value based on a computed granularity:
548
+ # * The granularity is `10 ** ndigits.abs`.
549
+ # * The returned value is the largest multiple of the granularity
550
+ # that is less than or equal to `self`.
551
+ # Examples with positive `self`:
552
+ # ndigits|Granularity|12345.6789.floor(ndigits)
553
+ # -------|-----------|-------------------------
554
+ # 0| 1| 12345
555
+ # -1| 10| 12340
556
+ # -2| 100| 12300
557
+ # -3| 1000| 12000
558
+ # -4| 10000| 10000
559
+ # -5| 100000| 0
560
+ # Examples with negative `self`:
561
+ # ndigits|Granularity|-12345.6789.floor(ndigits)
562
+ # -------|-----------|--------------------------
563
+ # 0| 1| -12346
564
+ # -1| 10| -12350
565
+ # -2| 100| -12400
566
+ # -3| 1000| -13000
567
+ # -4| 10000| -20000
568
+ # -5| 100000| -100000
569
+ # -6| 1000000| -1000000
570
+ # Note that the limited precision of floating-point arithmetic
571
+ # may lead to surprising results:
572
+ # (0.3 / 0.1).floor # => 2 # Not 3, (because (0.3 / 0.1) # => 2.9999999999999996, not 3.0)
594
573
  #
595
574
  # Related: Float#ceil.
596
575
  #
@@ -623,7 +602,6 @@ class Float < Numeric
623
602
  # * -1 if `self` is `-Infinity`.
624
603
  # * `nil`, otherwise.
625
604
  #
626
- #
627
605
  # Examples:
628
606
  #
629
607
  # f = 1.0/0.0 # => Infinity
@@ -642,14 +620,19 @@ class Float < Numeric
642
620
  # of `self`, the string representation may contain:
643
621
  #
644
622
  # * A fixed-point number.
623
+ # 3.14.to_s # => "3.14"
624
+ #
645
625
  # * A number in "scientific notation" (containing an exponent).
626
+ # (10.1**50).to_s # => "1.644631821843879e+50"
627
+ #
646
628
  # * 'Infinity'.
629
+ # (10.1**500).to_s # => "Infinity"
630
+ #
647
631
  # * '-Infinity'.
648
- # * 'NaN' (indicating not-a-number).
632
+ # (-10.1**500).to_s # => "-Infinity"
649
633
  #
650
- # 3.14.to_s # => "3.14" (10.1**50).to_s # =>
651
- # "1.644631821843879e+50" (10.1**500).to_s # => "Infinity"
652
- # (-10.1**500).to_s # => "-Infinity" (0.0/0.0).to_s # => "NaN"
634
+ # * 'NaN' (indicating not-a-number).
635
+ # (0.0/0.0).to_s # => "NaN"
653
636
  #
654
637
  alias inspect to_s
655
638
 
@@ -686,8 +669,6 @@ class Float < Numeric
686
669
  # 10.0 % 4.0 # => 2.0
687
670
  # 10.0 % Rational(4, 1) # => 2.0
688
671
  #
689
- # Float#modulo is an alias for Float#%.
690
- #
691
672
  def modulo: (Numeric) -> Float
692
673
 
693
674
  # <!--
@@ -705,9 +686,9 @@ class Float < Numeric
705
686
 
706
687
  # <!--
707
688
  # rdoc-file=numeric.rb
708
- # - float.negative? -> true or false
689
+ # - negative? -> true or false
709
690
  # -->
710
- # Returns `true` if `float` is less than 0.
691
+ # Returns `true` if `self` is less than 0, `false` otherwise.
711
692
  #
712
693
  def negative?: () -> bool
713
694
 
@@ -773,7 +754,7 @@ class Float < Numeric
773
754
  def numerator: () -> Integer
774
755
 
775
756
  # <!-- rdoc-file=complex.c -->
776
- # Returns 0 if the value is positive, pi otherwise.
757
+ # Returns 0 if `self` is positive, Math::PI otherwise.
777
758
  #
778
759
  alias phase angle
779
760
 
@@ -781,9 +762,9 @@ class Float < Numeric
781
762
 
782
763
  # <!--
783
764
  # rdoc-file=numeric.rb
784
- # - float.positive? -> true or false
765
+ # - positive? -> true or false
785
766
  # -->
786
- # Returns `true` if `float` is greater than 0.
767
+ # Returns `true` if `self` is greater than 0, `false` otherwise.
787
768
  #
788
769
  def positive?: () -> bool
789
770
 
@@ -835,8 +816,6 @@ class Float < Numeric
835
816
  # f.quo(Rational(2, 1)) # => 1.57
836
817
  # f.quo(Complex(2, 0)) # => (1.57+0.0i)
837
818
  #
838
- # Float#fdiv is an alias for Float#quo.
839
- #
840
819
  def quo: (Complex) -> Complex
841
820
  | (Numeric) -> Float
842
821
 
@@ -868,7 +847,7 @@ class Float < Numeric
868
847
 
869
848
  # <!--
870
849
  # rdoc-file=numeric.c
871
- # - round(ndigits = 0, half: :up]) -> integer or float
850
+ # - round(ndigits = 0, half: :up) -> integer or float
872
851
  # -->
873
852
  # Returns `self` rounded to the nearest value with a precision of `ndigits`
874
853
  # decimal digits.
@@ -914,7 +893,6 @@ class Float < Numeric
914
893
  # 3.5.round(half: :even) # => 4
915
894
  # (-2.5).round(half: :even) # => -2
916
895
  #
917
- #
918
896
  # Raises and exception if the value for `half` is invalid.
919
897
  #
920
898
  # Related: Float#truncate.
@@ -931,9 +909,9 @@ class Float < Numeric
931
909
 
932
910
  # <!--
933
911
  # rdoc-file=numeric.rb
934
- # - float.to_f -> self
912
+ # - to_f -> self
935
913
  # -->
936
- # Since `float` is already a Float, returns `self`.
914
+ # Returns `self` (which is already a Float).
937
915
  #
938
916
  def to_f: () -> Float
939
917
 
@@ -951,8 +929,6 @@ class Float < Numeric
951
929
  #
952
930
  # (0.3 / 0.1).to_i # => 2 (!)
953
931
  #
954
- # Float#to_int is an alias for Float#to_i.
955
- #
956
932
  def to_i: () -> Integer
957
933
 
958
934
  # <!-- rdoc-file=numeric.c -->
@@ -966,8 +942,6 @@ class Float < Numeric
966
942
  #
967
943
  # (0.3 / 0.1).to_i # => 2 (!)
968
944
  #
969
- # Float#to_int is an alias for Float#to_i.
970
- #
971
945
  alias to_int to_i
972
946
 
973
947
  # <!--
@@ -1000,14 +974,19 @@ class Float < Numeric
1000
974
  # of `self`, the string representation may contain:
1001
975
  #
1002
976
  # * A fixed-point number.
977
+ # 3.14.to_s # => "3.14"
978
+ #
1003
979
  # * A number in "scientific notation" (containing an exponent).
980
+ # (10.1**50).to_s # => "1.644631821843879e+50"
981
+ #
1004
982
  # * 'Infinity'.
983
+ # (10.1**500).to_s # => "Infinity"
984
+ #
1005
985
  # * '-Infinity'.
1006
- # * 'NaN' (indicating not-a-number).
986
+ # (-10.1**500).to_s # => "-Infinity"
1007
987
  #
1008
- # 3.14.to_s # => "3.14" (10.1**50).to_s # =>
1009
- # "1.644631821843879e+50" (10.1**500).to_s # => "Infinity"
1010
- # (-10.1**500).to_s # => "-Infinity" (0.0/0.0).to_s # => "NaN"
988
+ # * 'NaN' (indicating not-a-number).
989
+ # (0.0/0.0).to_s # => "NaN"
1011
990
  #
1012
991
  def to_s: () -> String
1013
992
 
@@ -1050,9 +1029,9 @@ class Float < Numeric
1050
1029
 
1051
1030
  # <!--
1052
1031
  # rdoc-file=numeric.rb
1053
- # - float.zero? -> true or false
1032
+ # - zero? -> true or false
1054
1033
  # -->
1055
- # Returns `true` if `float` is 0.0.
1034
+ # Returns `true` if `self` is 0.0, `false` otherwise.
1056
1035
  #
1057
1036
  def zero?: () -> bool
1058
1037
  end