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
@@ -1,9 +1,3 @@
1
- # <!-- rdoc-file=lib/rdoc/rubygems_hook.rb -->
2
- # Gem::RDoc provides methods to generate RDoc and ri data for installed gems
3
- # upon gem installation.
4
- #
5
- # This file is automatically required by RubyGems 1.9 and newer.
6
- #
7
1
  # <!-- rdoc-file=lib/rdoc.rb -->
8
2
  # RDoc produces documentation for Ruby source files by parsing the source and
9
3
  # extracting the definition for classes, modules, methods, includes and
@@ -21,8 +15,7 @@
21
15
  # If you want to use RDoc to create documentation for your Ruby source files,
22
16
  # see RDoc::Markup and refer to `rdoc --help` for command line usage.
23
17
  #
24
- # If you want to set the default markup format see
25
- # RDoc::Markup@Supported+Formats
18
+ # If you want to set the default markup format see RDoc::Markup@Markup+Formats
26
19
  #
27
20
  # If you want to store rdoc configuration in your gem (such as the default
28
21
  # markup format) see RDoc::Options@Saved+Options
@@ -56,340 +49,19 @@
56
49
  # of Keiju ISHITSUKA of Nippon Rational Inc, who produced the Ruby parser
57
50
  # for irb and the rtags package.
58
51
  #
52
+ # <!-- rdoc-file=lib/rdoc/rubygems_hook.rb -->
53
+ # This class is referenced by RubyGems to create documents. All implementations
54
+ # are moved to the above RubyGemsHook.
55
+ #
56
+ # This class does nothing when this RDoc is installed as a normal gem or a
57
+ # bundled gem.
58
+ #
59
+ # This class does generate/remove documents for compatibility when this RDoc is
60
+ # installed as a default gem.
61
+ #
62
+ # We can remove this when all maintained RubyGems remove `rubygems/rdoc.rb`.
63
+ #
59
64
  module RDoc
60
- # <!-- rdoc-file=lib/rdoc/parser.rb -->
61
- # A parser is simple a class that subclasses RDoc::Parser and implements #scan
62
- # to fill in an RDoc::TopLevel with parsed data.
63
- #
64
- # The initialize method takes an RDoc::TopLevel to fill with parsed content, the
65
- # name of the file to be parsed, the content of the file, an RDoc::Options
66
- # object and an RDoc::Stats object to inform the user of parsed items. The scan
67
- # method is then called to parse the file and must return the RDoc::TopLevel
68
- # object. By calling super these items will be set for you.
69
- #
70
- # In order to be used by RDoc the parser needs to register the file extensions
71
- # it can parse. Use ::parse_files_matching to register extensions.
72
- #
73
- # require 'rdoc'
74
- #
75
- # class RDoc::Parser::Xyz < RDoc::Parser
76
- # parse_files_matching /\.xyz$/
77
- #
78
- # def initialize top_level, file_name, content, options, stats
79
- # super
80
- #
81
- # # extra initialization if needed
82
- # end
83
- #
84
- # def scan
85
- # # parse file and fill in @top_level
86
- # end
87
- # end
88
- #
89
- class Parser
90
- # <!--
91
- # rdoc-file=lib/rdoc/parser.rb
92
- # - parse_files_matching(regexp)
93
- # -->
94
- # Record which file types this parser can understand.
95
- #
96
- # It is ok to call this multiple times.
97
- #
98
- def self?.parse_files_matching: (Regexp path) -> void
99
-
100
- # <!--
101
- # rdoc-file=lib/rdoc/parser.rb
102
- # - new(top_level, file_name, content, options, stats)
103
- # -->
104
- # Creates a new Parser storing `top_level`, `file_name`, `content`, `options`
105
- # and `stats` in instance variables. In +@preprocess+ an
106
- # RDoc::Markup::PreProcess object is created which allows processing of
107
- # directives.
108
- #
109
- def initialize: (RDoc::TopLevel top_level, String filename, String content, Hash[untyped, untyped] options, RDoc::Stats stats) -> void
110
-
111
- def scan: () -> RDoc::TopLevel
112
- end
113
-
114
- # <!-- rdoc-file=lib/rdoc/code_object.rb -->
115
- # Base class for the RDoc code tree.
116
- #
117
- # We contain the common stuff for contexts (which are containers) and other
118
- # elements (methods, attributes and so on)
119
- #
120
- # Here's the tree of the CodeObject subclasses:
121
- #
122
- # * RDoc::Context
123
- # * RDoc::TopLevel
124
- # * RDoc::ClassModule
125
- # * RDoc::AnonClass (never used so far)
126
- # * RDoc::NormalClass
127
- # * RDoc::NormalModule
128
- # * RDoc::SingleClass
129
- #
130
- #
131
- # * RDoc::MethodAttr
132
- # * RDoc::Attr
133
- # * RDoc::AnyMethod
134
- # * RDoc::GhostMethod
135
- # * RDoc::MetaMethod
136
- #
137
- #
138
- # * RDoc::Alias
139
- # * RDoc::Constant
140
- # * RDoc::Mixin
141
- # * RDoc::Require
142
- # * RDoc::Include
143
- #
144
- class CodeObject
145
- # <!-- rdoc-file=lib/rdoc/code_object.rb -->
146
- # Our comment
147
- #
148
- attr_reader comment: RDoc::Comment
149
-
150
- # <!--
151
- # rdoc-file=lib/rdoc/code_object.rb
152
- # - new()
153
- # -->
154
- # Creates a new CodeObject that will document itself and its children
155
- #
156
- def initialize: () -> void
157
-
158
- # <!--
159
- # rdoc-file=lib/rdoc/code_object.rb
160
- # - comment=(comment)
161
- # -->
162
- # Replaces our comment with `comment`, unless it is empty.
163
- #
164
- def comment=: (RDoc::Comment | String) -> RDoc::Comment
165
- end
166
-
167
- # <!-- rdoc-file=lib/rdoc/context.rb -->
168
- # A Context is something that can hold modules, classes, methods, attributes,
169
- # aliases, requires, and includes. Classes, modules, and files are all Contexts.
170
- #
171
- class Context < CodeObject
172
- include Comparable
173
-
174
- # <!-- rdoc-file=lib/rdoc/context.rb -->
175
- # Types of methods
176
- #
177
- TYPES: ::Array["class" | "instance"]
178
-
179
- TOMDOC_TITLES: ::Array[nil | "Public" | "Internal" | "Deprecated"]
180
-
181
- type class_types = singleton(RDoc::NormalClass) | singleton(RDoc::SingleClass)
182
-
183
- # <!--
184
- # rdoc-file=lib/rdoc/context.rb
185
- # - new()
186
- # -->
187
- # Creates an unnamed empty context with public current visibility
188
- #
189
- def initialize: () -> void
190
-
191
- # <!--
192
- # rdoc-file=lib/rdoc/context.rb
193
- # - add_alias(an_alias)
194
- # -->
195
- # Adds `an_alias` that is automatically resolved
196
- #
197
- def add_alias: (RDoc::Alias an_alias) -> RDoc::Alias
198
-
199
- # <!--
200
- # rdoc-file=lib/rdoc/context.rb
201
- # - add_attribute(attribute)
202
- # -->
203
- # Adds `attribute` if not already there. If it is (as method(s) or attribute),
204
- # updates the comment if it was empty.
205
- #
206
- # The attribute is registered only if it defines a new method. For instance,
207
- # `attr_reader :foo` will not be registered if method `foo` exists, but
208
- # `attr_accessor :foo` will be registered if method `foo` exists, but `foo=`
209
- # does not.
210
- #
211
- def add_attribute: (RDoc::Attr attribute) -> RDoc::Attr
212
-
213
- # <!--
214
- # rdoc-file=lib/rdoc/context.rb
215
- # - add_class(class_type, given_name, superclass = '::Object')
216
- # -->
217
- # Adds a class named `given_name` with `superclass`.
218
- #
219
- # Both `given_name` and `superclass` may contain '::', and are interpreted
220
- # relative to the `self` context. This allows handling correctly examples like
221
- # these:
222
- # class RDoc::Gauntlet < Gauntlet
223
- # module Mod
224
- # class Object # implies < ::Object
225
- # class SubObject < Object # this is _not_ ::Object
226
- #
227
- # Given `class Container::Item` RDoc assumes `Container` is a module unless it
228
- # later sees `class Container`. `add_class` automatically upgrades `given_name`
229
- # to a class in this case.
230
- #
231
- def add_class: (class_types class_type, ::String given_name, ?::String superclass) -> (RDoc::NormalClass | RDoc::SingleClass)
232
-
233
- # <!--
234
- # rdoc-file=lib/rdoc/context.rb
235
- # - add_constant(constant)
236
- # -->
237
- # Adds `constant` if not already there. If it is, updates the comment, value
238
- # and/or is_alias_for of the known constant if they were empty/nil.
239
- #
240
- def add_constant: (RDoc::Constant constant) -> RDoc::Constant
241
-
242
- # <!--
243
- # rdoc-file=lib/rdoc/context.rb
244
- # - add_include(include)
245
- # -->
246
- # Adds included module `include` which should be an RDoc::Include
247
- #
248
- def add_include: (RDoc::Include `include`) -> RDoc::Include
249
-
250
- # <!--
251
- # rdoc-file=lib/rdoc/context.rb
252
- # - add_extend(ext)
253
- # -->
254
- # Adds extension module `ext` which should be an RDoc::Extend
255
- #
256
- def add_extend: (RDoc::Extend ext) -> RDoc::Extend
257
-
258
- # <!--
259
- # rdoc-file=lib/rdoc/context.rb
260
- # - add_method(method)
261
- # -->
262
- # Adds `method` if not already there. If it is (as method or attribute), updates
263
- # the comment if it was empty.
264
- #
265
- def add_method: (RDoc::AnyMethod method) -> RDoc::AnyMethod
266
-
267
- # <!--
268
- # rdoc-file=lib/rdoc/context.rb
269
- # - add_module(class_type, name)
270
- # -->
271
- # Adds a module named `name`. If RDoc already knows `name` is a class then that
272
- # class is returned instead. See also #add_class.
273
- #
274
- def add_module: (singleton(RDoc::NormalModule) class_type, String name) -> RDoc::NormalModule
275
-
276
- # <!--
277
- # rdoc-file=lib/rdoc/context.rb
278
- # - find_module_named(name)
279
- # -->
280
- # Find a module with `name` using ruby's scoping rules
281
- #
282
- def find_module_named: (untyped name) -> (untyped | self)
283
-
284
- # <!--
285
- # rdoc-file=lib/rdoc/context.rb
286
- # - full_name()
287
- # -->
288
- # The full name for this context. This method is overridden by subclasses.
289
- #
290
- def full_name: () -> "(unknown)"
291
-
292
- def to_s: () -> ::String
293
-
294
- # <!--
295
- # rdoc-file=lib/rdoc/context.rb
296
- # - top_level()
297
- # -->
298
- # Return the TopLevel that owns us
299
- #
300
- def top_level: () -> RDoc::TopLevel
301
- end
302
-
303
- # <!-- rdoc-file=lib/rdoc/top_level.rb -->
304
- # A TopLevel context is a representation of the contents of a single file
305
- #
306
- class TopLevel < Context
307
- MARSHAL_VERSION: 0
308
-
309
- # <!--
310
- # rdoc-file=lib/rdoc/top_level.rb
311
- # - new(absolute_name, relative_name = absolute_name)
312
- # -->
313
- # Creates a new TopLevel for the file at `absolute_name`. If documentation is
314
- # being generated outside the source dir `relative_name` is relative to the
315
- # source directory.
316
- #
317
- def initialize: (String absolute_name, ?String relative_name) -> void
318
-
319
- # <!--
320
- # rdoc-file=lib/rdoc/top_level.rb
321
- # - ==(other)
322
- # -->
323
- # An RDoc::TopLevel is equal to another with the same relative_name
324
- #
325
- def ==: (untyped other) -> bool
326
-
327
- # <!--
328
- # rdoc-file=lib/rdoc/top_level.rb
329
- # - eql?(other)
330
- # -->
331
- #
332
- alias eql? ==
333
-
334
- # <!--
335
- # rdoc-file=lib/rdoc/top_level.rb
336
- # - add_alias(an_alias)
337
- # -->
338
- # Adds `an_alias` to `Object` instead of `self`.
339
- #
340
- def add_alias: (RDoc::Alias an_alias) -> RDoc::Alias
341
-
342
- # <!--
343
- # rdoc-file=lib/rdoc/top_level.rb
344
- # - add_constant(constant)
345
- # -->
346
- # Adds `constant` to `Object` instead of `self`.
347
- #
348
- def add_constant: (RDoc::Constant constant) -> RDoc::Constant
349
-
350
- # <!--
351
- # rdoc-file=lib/rdoc/top_level.rb
352
- # - add_include(include)
353
- # -->
354
- # Adds `include` to `Object` instead of `self`.
355
- #
356
- def add_include: (RDoc::Include `include`) -> RDoc::Include
357
-
358
- # <!--
359
- # rdoc-file=lib/rdoc/top_level.rb
360
- # - add_method(method)
361
- # -->
362
- # Adds `method` to `Object` instead of `self`.
363
- #
364
- def add_method: (RDoc::AnyMethod method) -> RDoc::AnyMethod
365
-
366
- # <!--
367
- # rdoc-file=lib/rdoc/top_level.rb
368
- # - find_class_or_module(name)
369
- # -->
370
- # See RDoc::TopLevel::find_class_or_module
371
- #
372
- def find_class_or_module: (::String name) -> RDoc::Context
373
-
374
- # <!--
375
- # rdoc-file=lib/rdoc/top_level.rb
376
- # - find_module_named(name)
377
- # -->
378
- # Finds a module or class with `name`
379
- #
380
- def find_module_named: (String name) -> RDoc::Context
381
-
382
- # <!--
383
- # rdoc-file=lib/rdoc/top_level.rb
384
- # - full_name()
385
- # -->
386
- # Returns the relative name of this file
387
- #
388
- def full_name: () -> String
389
-
390
- def to_s: () -> ::String
391
- end
392
-
393
65
  # <!-- rdoc-file=lib/rdoc/token_stream.rb -->
394
66
  # A TokenStream is a list of tokens, gathered during the parse of some entity
395
67
  # (say a method). Entities populate these streams by being registered with the
@@ -422,45 +94,6 @@ module RDoc
422
94
  alias start_collecting_tokens collect_tokens
423
95
  end
424
96
 
425
- # <!-- rdoc-file=lib/rdoc/comment.rb -->
426
- # A comment holds the text comment for a RDoc::CodeObject and provides a unified
427
- # way of cleaning it up and parsing it into an RDoc::Markup::Document.
428
- #
429
- # Each comment may have a different markup format set by #format=. By default
430
- # 'rdoc' is used. The :markup: directive tells RDoc which format to use.
431
- #
432
- # See RDoc::Markup@Other+directives for instructions on adding an alternate
433
- # format.
434
- #
435
- class Comment
436
- # <!-- rdoc-file=lib/rdoc/comment.rb -->
437
- # The format of this comment. Defaults to RDoc::Markup
438
- #
439
- attr_reader format: String
440
-
441
- # <!-- rdoc-file=lib/rdoc/comment.rb -->
442
- # The RDoc::TopLevel this comment was found in
443
- #
444
- attr_accessor location: String
445
-
446
- # <!--
447
- # rdoc-file=lib/rdoc/comment.rb
448
- # - new(text = nil, location = nil, language = nil)
449
- # -->
450
- # Creates a new comment with `text` that is found in the RDoc::TopLevel
451
- # `location`.
452
- #
453
- def initialize: (?String? text, ?RDoc::Context? location, ?String? language) -> void
454
-
455
- # <!--
456
- # rdoc-file=lib/rdoc/comment.rb
457
- # - format=(format)
458
- # -->
459
- # Sets the format of this comment and resets any parsed document
460
- #
461
- def format=: (String format) -> void
462
- end
463
-
464
97
  # <!-- rdoc-file=lib/rdoc/class_module.rb -->
465
98
  # ClassModule is the base class for objects representing either a class or a
466
99
  # module.
@@ -0,0 +1,17 @@
1
+ %a{annotate:rdoc:skip}
2
+ module RDoc
3
+ # <!-- rdoc-file=lib/rdoc/ri.rb -->
4
+ # Namespace for the ri command line tool's implementation.
5
+ #
6
+ # See `ri --help` for details.
7
+ #
8
+ module RI
9
+ module Paths
10
+ type path_type = :system | :site | :home | :gem | :extra
11
+
12
+ type gem_filter = :latest | :all
13
+
14
+ def self.each: (?bool system, ?bool site, ?bool home, ?gem_filter | false gems, *String extra_dirs) { (String, path_type) -> void } -> void
15
+ end
16
+ end
17
+ end
@@ -0,0 +1,48 @@
1
+ %a{annotate:rdoc:skip}
2
+ module RDoc
3
+ # <!-- rdoc-file=lib/rdoc/store.rb -->
4
+ # A set of rdoc data for a single project (gem, path, etc.).
5
+ #
6
+ # The store manages reading and writing ri data for a project and maintains a
7
+ # cache of methods, classes and ancestors in the store.
8
+ #
9
+ # The store maintains a #cache of its contents for faster lookup. After adding
10
+ # items to the store it must be flushed using #save_cache. The cache contains
11
+ # the following structures:
12
+ #
13
+ # @cache = {
14
+ # :ancestors => {}, # class name => ancestor names
15
+ # :attributes => {}, # class name => attributes
16
+ # :class_methods => {}, # class name => class methods
17
+ # :instance_methods => {}, # class name => instance methods
18
+ # :modules => [], # classes and modules in this store
19
+ # :pages => [], # page names
20
+ # }
21
+ #
22
+ class Store
23
+ # <!--
24
+ # rdoc-file=lib/rdoc/store.rb
25
+ # - new(path = nil, type = nil)
26
+ # -->
27
+ # Creates a new Store of `type` that will load or save to `path`
28
+ #
29
+ def initialize: (?String? path, ?Symbol? type) -> void
30
+
31
+ # <!--
32
+ # rdoc-file=lib/rdoc/store.rb
33
+ # - find_class_or_module(name)
34
+ # -->
35
+ # Finds the class or module with `name`
36
+ #
37
+ def find_class_or_module: (String) -> ClassModule?
38
+
39
+ # <!--
40
+ # rdoc-file=lib/rdoc/store.rb
41
+ # - load_all()
42
+ # -->
43
+ # Loads all items from this store into memory. This recreates a documentation
44
+ # tree for use by a generator
45
+ #
46
+ def load_all: () -> void
47
+ end
48
+ end
@@ -0,0 +1,97 @@
1
+ %a{annotate:rdoc:skip}
2
+ module RDoc
3
+ # <!-- rdoc-file=lib/rdoc/top_level.rb -->
4
+ # A TopLevel context is a representation of the contents of a single file
5
+ #
6
+ class TopLevel < Context
7
+ MARSHAL_VERSION: 0
8
+
9
+ # <!-- rdoc-file=lib/rdoc/top_level.rb -->
10
+ # Relative name of this file
11
+ #
12
+ attr_accessor relative_name: String
13
+
14
+ # <!--
15
+ # rdoc-file=lib/rdoc/top_level.rb
16
+ # - new(absolute_name, relative_name = absolute_name)
17
+ # -->
18
+ # Creates a new TopLevel for the file at `absolute_name`. If documentation is
19
+ # being generated outside the source dir `relative_name` is relative to the
20
+ # source directory.
21
+ #
22
+ def initialize: (String absolute_name, ?String relative_name) -> void
23
+
24
+ # <!--
25
+ # rdoc-file=lib/rdoc/top_level.rb
26
+ # - ==(other)
27
+ # -->
28
+ # An RDoc::TopLevel is equal to another with the same relative_name
29
+ #
30
+ def ==: (untyped other) -> bool
31
+
32
+ # <!--
33
+ # rdoc-file=lib/rdoc/top_level.rb
34
+ # - eql?(other)
35
+ # -->
36
+ #
37
+ alias eql? ==
38
+
39
+ # <!--
40
+ # rdoc-file=lib/rdoc/top_level.rb
41
+ # - add_alias(an_alias)
42
+ # -->
43
+ # Adds `an_alias` to `Object` instead of `self`.
44
+ #
45
+ def add_alias: (RDoc::Alias an_alias) -> RDoc::Alias
46
+
47
+ # <!--
48
+ # rdoc-file=lib/rdoc/top_level.rb
49
+ # - add_constant(constant)
50
+ # -->
51
+ # Adds `constant` to `Object` instead of `self`.
52
+ #
53
+ def add_constant: (RDoc::Constant constant) -> RDoc::Constant
54
+
55
+ # <!--
56
+ # rdoc-file=lib/rdoc/top_level.rb
57
+ # - add_include(include)
58
+ # -->
59
+ # Adds `include` to `Object` instead of `self`.
60
+ #
61
+ def add_include: (RDoc::Include `include`) -> RDoc::Include
62
+
63
+ # <!--
64
+ # rdoc-file=lib/rdoc/top_level.rb
65
+ # - add_method(method)
66
+ # -->
67
+ # Adds `method` to `Object` instead of `self`.
68
+ #
69
+ def add_method: (RDoc::AnyMethod method) -> RDoc::AnyMethod
70
+
71
+ # <!--
72
+ # rdoc-file=lib/rdoc/top_level.rb
73
+ # - find_class_or_module(name)
74
+ # -->
75
+ # See RDoc::TopLevel::find_class_or_module
76
+ #
77
+ def find_class_or_module: (::String name) -> RDoc::Context
78
+
79
+ # <!--
80
+ # rdoc-file=lib/rdoc/top_level.rb
81
+ # - find_module_named(name)
82
+ # -->
83
+ # Finds a module or class with `name`
84
+ #
85
+ def find_module_named: (String name) -> RDoc::Context
86
+
87
+ # <!--
88
+ # rdoc-file=lib/rdoc/top_level.rb
89
+ # - full_name()
90
+ # -->
91
+ # Returns the relative name of this file
92
+ #
93
+ def full_name: () -> String
94
+
95
+ def to_s: () -> ::String
96
+ end
97
+ end