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
@@ -0,0 +1,293 @@
1
+ %a{annotate:rdoc:skip}
2
+ module Zlib
3
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
4
+ # Zlib::GzipReader is the class for reading a gzipped file. GzipReader should
5
+ # be used as an IO, or -IO-like, object.
6
+ #
7
+ # Zlib::GzipReader.open('hoge.gz') {|gz|
8
+ # print gz.read
9
+ # }
10
+ #
11
+ # File.open('hoge.gz') do |f|
12
+ # gz = Zlib::GzipReader.new(f)
13
+ # print gz.read
14
+ # gz.close
15
+ # end
16
+ #
17
+ # ## Method Catalogue
18
+ #
19
+ # The following methods in Zlib::GzipReader are just like their counterparts in
20
+ # IO, but they raise Zlib::Error or Zlib::GzipFile::Error exception if an error
21
+ # was found in the gzip file.
22
+ # * #each
23
+ # * #each_line
24
+ # * #each_byte
25
+ # * #gets
26
+ # * #getc
27
+ # * #lineno
28
+ # * #lineno=
29
+ # * #read
30
+ # * #readchar
31
+ # * #readline
32
+ # * #readlines
33
+ # * #ungetc
34
+ #
35
+ # Be careful of the footer of the gzip file. A gzip file has the checksum of
36
+ # pre-compressed data in its footer. GzipReader checks all uncompressed data
37
+ # against that checksum at the following cases, and if it fails, raises
38
+ # `Zlib::GzipFile::NoFooter`, `Zlib::GzipFile::CRCError`, or
39
+ # `Zlib::GzipFile::LengthError` exception.
40
+ #
41
+ # * When an reading request is received beyond the end of file (the end of
42
+ # compressed data). That is, when Zlib::GzipReader#read,
43
+ # Zlib::GzipReader#gets, or some other methods for reading returns nil.
44
+ # * When Zlib::GzipFile#close method is called after the object reaches the
45
+ # end of file.
46
+ # * When Zlib::GzipReader#unused method is called after the object reaches the
47
+ # end of file.
48
+ #
49
+ # The rest of the methods are adequately described in their own documentation.
50
+ #
51
+ class GzipReader < Zlib::GzipFile
52
+ include Enumerable[String]
53
+
54
+ def self.wrap: (IO io) -> instance
55
+ | (IO io) { (instance gz) -> void } -> void
56
+
57
+ # <!--
58
+ # rdoc-file=ext/zlib/zlib.c
59
+ # - Zlib::GzipReader.open(filename) {|gz| ... }
60
+ # -->
61
+ # Opens a file specified by `filename` as a gzipped file, and returns a
62
+ # GzipReader object associated with that file. Further details of this method
63
+ # are in Zlib::GzipReader.new and ZLib::GzipFile.wrap.
64
+ #
65
+ def self.open: (String | _ToPath filename) -> instance
66
+ | (String | _ToPath filename) { (instance gz) -> void } -> void
67
+
68
+ # <!--
69
+ # rdoc-file=ext/zlib/zlib.c
70
+ # - Zlib::GzipReader.zcat(io, options = {}, &block) => nil
71
+ # - Zlib::GzipReader.zcat(io, options = {}) => string
72
+ # -->
73
+ # Decompresses all gzip data in the `io`, handling multiple gzip streams until
74
+ # the end of the `io`. There should not be any non-gzip data after the gzip
75
+ # streams.
76
+ #
77
+ # If a block is given, it is yielded strings of uncompressed data, and the
78
+ # method returns `nil`. If a block is not given, the method returns the
79
+ # concatenation of all uncompressed data in all gzip streams.
80
+ #
81
+ def self.zcat: (IO io, **untyped) -> String
82
+ | (IO io, **untyped) { (String chunk) -> void } -> nil
83
+
84
+ # <!--
85
+ # rdoc-file=ext/zlib/zlib.c
86
+ # - each(*args)
87
+ # -->
88
+ # See Zlib::GzipReader documentation for a description.
89
+ #
90
+ def each: (*untyped) { (String) -> void } -> void
91
+
92
+ # <!--
93
+ # rdoc-file=ext/zlib/zlib.c
94
+ # - each_byte()
95
+ # -->
96
+ # See Zlib::GzipReader documentation for a description.
97
+ #
98
+ def each_byte: () { (String) -> void } -> void
99
+
100
+ # <!--
101
+ # rdoc-file=ext/zlib/zlib.c
102
+ # - each_char()
103
+ # -->
104
+ # See Zlib::GzipReader documentation for a description.
105
+ #
106
+ def each_char: () { (String) -> void } -> void
107
+
108
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
109
+ # See Zlib::GzipReader documentation for a description.
110
+ #
111
+ def each_line: (*untyped) { (String) -> void } -> void
112
+
113
+ # <!--
114
+ # rdoc-file=ext/zlib/zlib.c
115
+ # - eof()
116
+ # -->
117
+ # Returns `true` or `false` whether the stream has reached the end.
118
+ #
119
+ def eof: () -> bool
120
+
121
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
122
+ # Returns `true` or `false` whether the stream has reached the end.
123
+ #
124
+ def eof?: () -> bool
125
+
126
+ # <!--
127
+ # rdoc-file=ext/zlib/zlib.c
128
+ # - external_encoding()
129
+ # -->
130
+ # See Zlib::GzipReader documentation for a description.
131
+ #
132
+ def external_encoding: () -> Encoding
133
+
134
+ # <!--
135
+ # rdoc-file=ext/zlib/zlib.c
136
+ # - getbyte()
137
+ # -->
138
+ # See Zlib::GzipReader documentation for a description.
139
+ #
140
+ def getbyte: () -> Integer?
141
+
142
+ # <!--
143
+ # rdoc-file=ext/zlib/zlib.c
144
+ # - getc()
145
+ # -->
146
+ # See Zlib::GzipReader documentation for a description.
147
+ #
148
+ def getc: () -> String?
149
+
150
+ # <!--
151
+ # rdoc-file=ext/zlib/zlib.c
152
+ # - gets(*args)
153
+ # -->
154
+ # See Zlib::GzipReader documentation for a description. However, note that this
155
+ # method can return `nil` even if #eof? returns false, unlike the behavior of
156
+ # File#gets.
157
+ #
158
+ def gets: (?String sep, ?Integer limit) -> String?
159
+
160
+ # <!--
161
+ # rdoc-file=ext/zlib/zlib.c
162
+ # - lineno()
163
+ # -->
164
+ # The line number of the last row read from this file.
165
+ #
166
+ def lineno: () -> Integer
167
+
168
+ # <!--
169
+ # rdoc-file=ext/zlib/zlib.c
170
+ # - lineno=(p1)
171
+ # -->
172
+ # Specify line number of the last row read from this file.
173
+ #
174
+ def lineno=: (Integer arg0) -> Integer
175
+
176
+ # <!--
177
+ # rdoc-file=ext/zlib/zlib.c
178
+ # - pos()
179
+ # -->
180
+ # Total number of output bytes output so far.
181
+ #
182
+ def pos: () -> Integer
183
+
184
+ # <!--
185
+ # rdoc-file=ext/zlib/zlib.c
186
+ # - read(p1 = v1, p2 = v2)
187
+ # -->
188
+ # See Zlib::GzipReader documentation for a description.
189
+ #
190
+ def read: (?int? length, ?string outbuf) -> String?
191
+
192
+ # <!--
193
+ # rdoc-file=ext/zlib/zlib.c
194
+ # - readbyte()
195
+ # -->
196
+ # See Zlib::GzipReader documentation for a description.
197
+ #
198
+ def readbyte: () -> Integer
199
+
200
+ # <!--
201
+ # rdoc-file=ext/zlib/zlib.c
202
+ # - readchar()
203
+ # -->
204
+ # See Zlib::GzipReader documentation for a description.
205
+ #
206
+ def readchar: () -> String
207
+
208
+ # <!--
209
+ # rdoc-file=ext/zlib/zlib.c
210
+ # - readline(*args)
211
+ # -->
212
+ # See Zlib::GzipReader documentation for a description.
213
+ #
214
+ def readline: (?String sep, ?Integer limit) -> String
215
+
216
+ # <!--
217
+ # rdoc-file=ext/zlib/zlib.c
218
+ # - readlines(*args)
219
+ # -->
220
+ # See Zlib::GzipReader documentation for a description.
221
+ #
222
+ def readlines: (?String sep, ?Integer limit) -> ::Array[String]
223
+
224
+ # <!--
225
+ # rdoc-file=ext/zlib/zlib.c
226
+ # - gzipreader.readpartial(maxlen [, outbuf]) => string, outbuf
227
+ # -->
228
+ # Reads at most *maxlen* bytes from the gzipped stream but it blocks only if
229
+ # *gzipreader* has no data immediately available. If the optional *outbuf*
230
+ # argument is present, it must reference a String, which will receive the data.
231
+ # It raises `EOFError` on end of file.
232
+ #
233
+ def readpartial: (int maxlen, ?string outbuf) -> String
234
+
235
+ # <!--
236
+ # rdoc-file=ext/zlib/zlib.c
237
+ # - rewind()
238
+ # -->
239
+ # Resets the position of the file pointer to the point created the GzipReader
240
+ # object. The associated IO object needs to respond to the `seek` method.
241
+ #
242
+ def rewind: () -> Integer
243
+
244
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
245
+ # Total number of output bytes output so far.
246
+ #
247
+ def tell: () -> Integer
248
+
249
+ # <!--
250
+ # rdoc-file=ext/zlib/zlib.c
251
+ # - ungetbyte(p1)
252
+ # -->
253
+ # See Zlib::GzipReader documentation for a description.
254
+ #
255
+ def ungetbyte: (String | Integer arg0) -> NilClass
256
+
257
+ # <!--
258
+ # rdoc-file=ext/zlib/zlib.c
259
+ # - ungetc(p1)
260
+ # -->
261
+ # See Zlib::GzipReader documentation for a description.
262
+ #
263
+ def ungetc: (String arg0) -> NilClass
264
+
265
+ # <!--
266
+ # rdoc-file=ext/zlib/zlib.c
267
+ # - unused()
268
+ # -->
269
+ # Returns the rest of the data which had read for parsing gzip format, or `nil`
270
+ # if the whole gzip file is not parsed yet.
271
+ #
272
+ def unused: () -> String?
273
+
274
+ private
275
+
276
+ # <!--
277
+ # rdoc-file=ext/zlib/zlib.c
278
+ # - Zlib::GzipReader.new(io, options = {})
279
+ # -->
280
+ # Creates a GzipReader object associated with `io`. The GzipReader object reads
281
+ # gzipped data from `io`, and parses/decompresses it. The `io` must have a
282
+ # `read` method that behaves same as the IO#read.
283
+ #
284
+ # The `options` hash may be used to set the encoding of the data.
285
+ # `:external_encoding`, `:internal_encoding` and `:encoding` may be set as in
286
+ # IO::new.
287
+ #
288
+ # If the gzip file header is incorrect, raises an Zlib::GzipFile::Error
289
+ # exception.
290
+ #
291
+ def initialize: (_Reader io, **untyped opts) -> void
292
+ end
293
+ end
@@ -0,0 +1,166 @@
1
+ %a{annotate:rdoc:skip}
2
+ module Zlib
3
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
4
+ # Zlib::GzipWriter is a class for writing gzipped files. GzipWriter should be
5
+ # used with an instance of IO, or IO-like, object.
6
+ #
7
+ # Following two example generate the same result.
8
+ #
9
+ # Zlib::GzipWriter.open('hoge.gz') do |gz|
10
+ # gz.write 'jugemu jugemu gokou no surikire...'
11
+ # end
12
+ #
13
+ # File.open('hoge.gz', 'w') do |f|
14
+ # gz = Zlib::GzipWriter.new(f)
15
+ # gz.write 'jugemu jugemu gokou no surikire...'
16
+ # gz.close
17
+ # end
18
+ #
19
+ # To make like gzip(1) does, run following:
20
+ #
21
+ # orig = 'hoge.txt'
22
+ # Zlib::GzipWriter.open('hoge.gz') do |gz|
23
+ # gz.mtime = File.mtime(orig)
24
+ # gz.orig_name = orig
25
+ # gz.write IO.binread(orig)
26
+ # end
27
+ #
28
+ # NOTE: Due to the limitation of Ruby's finalizer, you must explicitly close
29
+ # GzipWriter objects by Zlib::GzipWriter#close etc. Otherwise, GzipWriter will
30
+ # be not able to write the gzip footer and will generate a broken gzip file.
31
+ #
32
+ class GzipWriter < Zlib::GzipFile
33
+ # <!--
34
+ # rdoc-file=ext/zlib/zlib.c
35
+ # - Zlib::GzipWriter.open(filename, level=nil, strategy=nil) { |gz| ... }
36
+ # -->
37
+ # Opens a file specified by `filename` for writing gzip compressed data, and
38
+ # returns a GzipWriter object associated with that file. Further details of
39
+ # this method are found in Zlib::GzipWriter.new and Zlib::GzipFile.wrap.
40
+ #
41
+ def self.open: (String filename) { (instance gz) -> void } -> instance
42
+
43
+ # <!--
44
+ # rdoc-file=ext/zlib/zlib.c
45
+ # - <<(p1)
46
+ # -->
47
+ # Same as IO.
48
+ #
49
+ def <<: (_ToS obj) -> self
50
+
51
+ # <!--
52
+ # rdoc-file=ext/zlib/zlib.c
53
+ # - comment=(p1)
54
+ # -->
55
+ # Specify the comment (`str`) in the gzip header.
56
+ #
57
+ def comment=: (String arg0) -> void
58
+
59
+ # <!--
60
+ # rdoc-file=ext/zlib/zlib.c
61
+ # - flush(flush=nil)
62
+ # -->
63
+ # Flushes all the internal buffers of the GzipWriter object. The meaning of
64
+ # `flush` is same as in Zlib::Deflate#deflate. `Zlib::SYNC_FLUSH` is used if
65
+ # `flush` is omitted. It is no use giving flush `Zlib::NO_FLUSH`.
66
+ #
67
+ def flush: (?Integer flush) -> String
68
+
69
+ # <!--
70
+ # rdoc-file=ext/zlib/zlib.c
71
+ # - mtime=(p1)
72
+ # -->
73
+ # Specify the modification time (`mtime`) in the gzip header. Using an Integer.
74
+ #
75
+ # Setting the mtime in the gzip header does not effect the mtime of the file
76
+ # generated. Different utilities that expand the gzipped files may use the mtime
77
+ # header. For example the gunzip utility can use the `-N` flag which will set
78
+ # the resultant file's mtime to the value in the header. By default many tools
79
+ # will set the mtime of the expanded file to the mtime of the gzipped file, not
80
+ # the mtime in the header.
81
+ #
82
+ # If you do not set an mtime, the default value will be the time when
83
+ # compression started. Setting a value of 0 indicates no time stamp is
84
+ # available.
85
+ #
86
+ def mtime=: (string | _ToPath | IO file_name) -> Time
87
+
88
+ # <!--
89
+ # rdoc-file=ext/zlib/zlib.c
90
+ # - orig_name=(p1)
91
+ # -->
92
+ # Specify the original name (`str`) in the gzip header.
93
+ #
94
+ def orig_name=: (String arg0) -> void
95
+
96
+ # <!--
97
+ # rdoc-file=ext/zlib/zlib.c
98
+ # - pos()
99
+ # -->
100
+ # Total number of input bytes read so far.
101
+ #
102
+ def pos: () -> Integer
103
+
104
+ # <!--
105
+ # rdoc-file=ext/zlib/zlib.c
106
+ # - print(*args)
107
+ # -->
108
+ # Same as IO.
109
+ #
110
+ def print: (*untyped arg0) -> NilClass
111
+
112
+ # <!--
113
+ # rdoc-file=ext/zlib/zlib.c
114
+ # - printf(*args)
115
+ # -->
116
+ # Same as IO.
117
+ #
118
+ def printf: (String format_string, *untyped arg0) -> NilClass
119
+
120
+ # <!--
121
+ # rdoc-file=ext/zlib/zlib.c
122
+ # - putc(p1)
123
+ # -->
124
+ # Same as IO.
125
+ #
126
+ def putc: (Numeric | String arg0) -> untyped
127
+
128
+ # <!--
129
+ # rdoc-file=ext/zlib/zlib.c
130
+ # - puts(*args)
131
+ # -->
132
+ # Same as IO.
133
+ #
134
+ def puts: (*untyped arg0) -> NilClass
135
+
136
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
137
+ # Total number of input bytes read so far.
138
+ #
139
+ def tell: () -> Integer
140
+
141
+ # <!--
142
+ # rdoc-file=ext/zlib/zlib.c
143
+ # - write(*args)
144
+ # -->
145
+ # Same as IO.
146
+ #
147
+ def write: (*_ToS string) -> Integer
148
+
149
+ private
150
+
151
+ # <!--
152
+ # rdoc-file=ext/zlib/zlib.c
153
+ # - Zlib::GzipWriter.new(io, level = nil, strategy = nil, options = {})
154
+ # -->
155
+ # Creates a GzipWriter object associated with `io`. `level` and `strategy`
156
+ # should be the same as the arguments of Zlib::Deflate.new. The GzipWriter
157
+ # object writes gzipped data to `io`. `io` must respond to the `write` method
158
+ # that behaves the same as IO#write.
159
+ #
160
+ # The `options` hash may be used to set the encoding of the data.
161
+ # `:external_encoding`, `:internal_encoding` and `:encoding` may be set as in
162
+ # IO::new.
163
+ #
164
+ def initialize: (_Writer io, Integer level, Integer strategy, **untyped opts) -> void
165
+ end
166
+ end
@@ -0,0 +1,180 @@
1
+ %a{annotate:rdoc:skip}
2
+ module Zlib
3
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
4
+ # Zlib:Inflate is the class for decompressing compressed data. Unlike
5
+ # Zlib::Deflate, an instance of this class is not able to duplicate (clone, dup)
6
+ # itself.
7
+ #
8
+ class Inflate < Zlib::ZStream
9
+ # <!--
10
+ # rdoc-file=ext/zlib/zlib.c
11
+ # - Zlib.inflate(string)
12
+ # - Zlib::Inflate.inflate(string)
13
+ # -->
14
+ # Decompresses `string`. Raises a Zlib::NeedDict exception if a preset
15
+ # dictionary is needed for decompression.
16
+ #
17
+ # This method is almost equivalent to the following code:
18
+ #
19
+ # def inflate(string)
20
+ # zstream = Zlib::Inflate.new
21
+ # buf = zstream.inflate(string)
22
+ # zstream.finish
23
+ # zstream.close
24
+ # buf
25
+ # end
26
+ #
27
+ # See also Zlib.deflate
28
+ #
29
+ def self.inflate: (string string) -> String
30
+
31
+ # <!--
32
+ # rdoc-file=ext/zlib/zlib.c
33
+ # - <<(p1)
34
+ # -->
35
+ # Same as IO.
36
+ #
37
+ def <<: (_ToS obj) -> self
38
+
39
+ # <!--
40
+ # rdoc-file=ext/zlib/zlib.c
41
+ # - add_dictionary(string)
42
+ # -->
43
+ # Provide the inflate stream with a dictionary that may be required in the
44
+ # future. Multiple dictionaries may be provided. The inflate stream will
45
+ # automatically choose the correct user-provided dictionary based on the
46
+ # stream's required dictionary.
47
+ #
48
+ def add_dictionary: (String arg0) -> void
49
+
50
+ # <!--
51
+ # rdoc-file=ext/zlib/zlib.c
52
+ # - inflate(deflate_string, buffer: nil) -> String
53
+ # - inflate(deflate_string, buffer: nil) { |chunk| ... } -> nil
54
+ # -->
55
+ # Inputs `deflate_string` into the inflate stream and returns the output from
56
+ # the stream. Calling this method, both the input and the output buffer of the
57
+ # stream are flushed. If string is `nil`, this method finishes the stream, just
58
+ # like Zlib::ZStream#finish.
59
+ #
60
+ # If a block is given consecutive inflated chunks from the `deflate_string` are
61
+ # yielded to the block and `nil` is returned.
62
+ #
63
+ # If a :buffer keyword argument is given and not nil:
64
+ #
65
+ # * The :buffer keyword should be a String, and will used as the output
66
+ # buffer. Using this option can reuse the memory required during inflation.
67
+ # * When not passing a block, the return value will be the same object as the
68
+ # :buffer keyword argument.
69
+ # * When passing a block, the yielded chunks will be the same value as the
70
+ # :buffer keyword argument.
71
+ #
72
+ # Raises a Zlib::NeedDict exception if a preset dictionary is needed to
73
+ # decompress. Set the dictionary by Zlib::Inflate#set_dictionary and then call
74
+ # this method again with an empty string to flush the stream:
75
+ #
76
+ # inflater = Zlib::Inflate.new
77
+ #
78
+ # begin
79
+ # out = inflater.inflate compressed
80
+ # rescue Zlib::NeedDict
81
+ # # ensure the dictionary matches the stream's required dictionary
82
+ # raise unless inflater.adler == Zlib.adler32(dictionary)
83
+ #
84
+ # inflater.set_dictionary dictionary
85
+ # inflater.inflate ''
86
+ # end
87
+ #
88
+ # # ...
89
+ #
90
+ # inflater.close
91
+ #
92
+ # See also Zlib::Inflate.new
93
+ #
94
+ def inflate: (string string, ?buffer: String) -> String
95
+ | (string string, ?buffer: String) { (String chunk) -> nil } -> nil
96
+
97
+ # <!--
98
+ # rdoc-file=ext/zlib/zlib.c
99
+ # - set_dictionary(p1)
100
+ # -->
101
+ # Sets the preset dictionary and returns `string`. This method is available
102
+ # just only after a Zlib::NeedDict exception was raised. See zlib.h for
103
+ # details.
104
+ #
105
+ def set_dictionary: (String p1) -> String
106
+
107
+ # <!--
108
+ # rdoc-file=ext/zlib/zlib.c
109
+ # - sync(string)
110
+ # -->
111
+ # Inputs `string` into the end of input buffer and skips data until a full flush
112
+ # point can be found. If the point is found in the buffer, this method flushes
113
+ # the buffer and returns false. Otherwise it returns `true` and the following
114
+ # data of full flush point is preserved in the buffer.
115
+ #
116
+ def sync: (String string) -> bool
117
+
118
+ # <!--
119
+ # rdoc-file=ext/zlib/zlib.c
120
+ # - sync_point?()
121
+ # -->
122
+ # Quoted verbatim from original documentation:
123
+ #
124
+ # What is this?
125
+ #
126
+ # `:)`
127
+ #
128
+ def sync_point?: () -> bool
129
+
130
+ private
131
+
132
+ # <!--
133
+ # rdoc-file=ext/zlib/zlib.c
134
+ # - Zlib::Inflate.new(window_bits = Zlib::MAX_WBITS)
135
+ # -->
136
+ # Creates a new inflate stream for decompression. `window_bits` sets the size
137
+ # of the history buffer and can have the following values:
138
+ #
139
+ # 0
140
+ # : Have inflate use the window size from the zlib header of the compressed
141
+ # stream.
142
+ #
143
+ #
144
+ # (8..15)
145
+ # : Overrides the window size of the inflate header in the compressed stream.
146
+ # The window size must be greater than or equal to the window size of the
147
+ # compressed stream.
148
+ #
149
+ #
150
+ # Greater than 15
151
+ # : Add 32 to window_bits to enable zlib and gzip decoding with automatic
152
+ # header detection, or add 16 to decode only the gzip format (a
153
+ # Zlib::DataError will be raised for a non-gzip stream).
154
+ #
155
+ #
156
+ # (-8..-15)
157
+ # : Enables raw deflate mode which will not generate a check value, and will
158
+ # not look for any check values for comparison at the end of the stream.
159
+ #
160
+ # This is for use with other formats that use the deflate compressed data
161
+ # format such as zip which provide their own check values.
162
+ #
163
+ #
164
+ # ## Example
165
+ #
166
+ # open "compressed.file" do |compressed_io|
167
+ # zi = Zlib::Inflate.new(Zlib::MAX_WBITS + 32)
168
+ #
169
+ # begin
170
+ # open "uncompressed.file", "w+" do |uncompressed_io|
171
+ # uncompressed_io << zi.inflate(compressed_io.read)
172
+ # end
173
+ # ensure
174
+ # zi.close
175
+ # end
176
+ # end
177
+ #
178
+ def initialize: (?Integer window_bits) -> void
179
+ end
180
+ end
@@ -0,0 +1,10 @@
1
+ %a{annotate:rdoc:skip}
2
+ module Zlib
3
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
4
+ # Subclass of Zlib::Error
5
+ #
6
+ # When zlib returns a Z_MEM_ERROR, usually if there was not enough memory.
7
+ #
8
+ class MemError < Zlib::Error
9
+ end
10
+ end
@@ -0,0 +1,13 @@
1
+ %a{annotate:rdoc:skip}
2
+ module Zlib
3
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
4
+ # Subclass of Zlib::Error
5
+ #
6
+ # When zlib returns a Z_NEED_DICT if a preset dictionary is needed at this
7
+ # point.
8
+ #
9
+ # Used by Zlib::Inflate.inflate and `Zlib.inflate`
10
+ #
11
+ class NeedDict < Zlib::Error
12
+ end
13
+ end
@@ -0,0 +1,11 @@
1
+ %a{annotate:rdoc:skip}
2
+ module Zlib
3
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
4
+ # Subclass of Zlib::Error
5
+ #
6
+ # When zlib returns a Z_STREAM_END is return if the end of the compressed data
7
+ # has been reached and all uncompressed out put has been produced.
8
+ #
9
+ class StreamEnd < Zlib::Error
10
+ end
11
+ end
@@ -0,0 +1,11 @@
1
+ %a{annotate:rdoc:skip}
2
+ module Zlib
3
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
4
+ # Subclass of Zlib::Error
5
+ #
6
+ # When zlib returns a Z_STREAM_ERROR, usually if the stream state was
7
+ # inconsistent.
8
+ #
9
+ class StreamError < Zlib::Error
10
+ end
11
+ end
@@ -0,0 +1,11 @@
1
+ %a{annotate:rdoc:skip}
2
+ module Zlib
3
+ # <!-- rdoc-file=ext/zlib/zlib.c -->
4
+ # Subclass of Zlib::Error
5
+ #
6
+ # When zlib returns a Z_VERSION_ERROR, usually if the zlib library version is
7
+ # incompatible with the version assumed by the caller.
8
+ #
9
+ class VersionError < Zlib::Error
10
+ end
11
+ end