rbs-relaxed 3.9.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.github/dependabot.yml +22 -0
- data/.github/workflows/comments.yml +35 -0
- data/.github/workflows/dependabot.yml +30 -0
- data/.github/workflows/ruby.yml +82 -0
- data/.github/workflows/typecheck.yml +38 -0
- data/.github/workflows/windows.yml +43 -0
- data/.gitignore +23 -0
- data/.rubocop.yml +68 -0
- data/BSDL +22 -0
- data/CHANGELOG.md +1868 -0
- data/COPYING +56 -0
- data/README.md +203 -0
- data/Rakefile +417 -0
- data/Steepfile +44 -0
- data/config.yml +313 -0
- data/core/array.rbs +4062 -0
- data/core/basic_object.rbs +375 -0
- data/core/binding.rbs +150 -0
- data/core/builtin.rbs +277 -0
- data/core/class.rbs +220 -0
- data/core/comparable.rbs +171 -0
- data/core/complex.rbs +786 -0
- data/core/constants.rbs +96 -0
- data/core/data.rbs +415 -0
- data/core/dir.rbs +981 -0
- data/core/encoding.rbs +1371 -0
- data/core/enumerable.rbs +2405 -0
- data/core/enumerator/product.rbs +92 -0
- data/core/enumerator.rbs +630 -0
- data/core/env.rbs +6 -0
- data/core/errno.rbs +673 -0
- data/core/errors.rbs +760 -0
- data/core/exception.rbs +485 -0
- data/core/false_class.rbs +82 -0
- data/core/fiber.rbs +550 -0
- data/core/fiber_error.rbs +11 -0
- data/core/file.rbs +2936 -0
- data/core/file_test.rbs +331 -0
- data/core/float.rbs +1151 -0
- data/core/gc.rbs +644 -0
- data/core/global_variables.rbs +184 -0
- data/core/hash.rbs +1861 -0
- data/core/integer.rbs +1413 -0
- data/core/io/buffer.rbs +984 -0
- data/core/io/wait.rbs +70 -0
- data/core/io.rbs +3406 -0
- data/core/kernel.rbs +3096 -0
- data/core/marshal.rbs +207 -0
- data/core/match_data.rbs +635 -0
- data/core/math.rbs +729 -0
- data/core/method.rbs +386 -0
- data/core/module.rbs +1704 -0
- data/core/nil_class.rbs +209 -0
- data/core/numeric.rbs +818 -0
- data/core/object.rbs +110 -0
- data/core/object_space/weak_key_map.rbs +166 -0
- data/core/object_space.rbs +190 -0
- data/core/proc.rbs +868 -0
- data/core/process.rbs +2296 -0
- data/core/ractor.rbs +1068 -0
- data/core/random.rbs +237 -0
- data/core/range.rbs +1107 -0
- data/core/rational.rbs +531 -0
- data/core/rb_config.rbs +88 -0
- data/core/rbs/unnamed/argf.rbs +1229 -0
- data/core/rbs/unnamed/env_class.rbs +1209 -0
- data/core/rbs/unnamed/random.rbs +293 -0
- data/core/refinement.rbs +59 -0
- data/core/regexp.rbs +1930 -0
- data/core/ruby_vm.rbs +765 -0
- data/core/rubygems/basic_specification.rbs +6 -0
- data/core/rubygems/config_file.rbs +38 -0
- data/core/rubygems/dependency_installer.rbs +6 -0
- data/core/rubygems/errors.rbs +176 -0
- data/core/rubygems/installer.rbs +15 -0
- data/core/rubygems/path_support.rbs +6 -0
- data/core/rubygems/platform.rbs +7 -0
- data/core/rubygems/request_set.rbs +49 -0
- data/core/rubygems/requirement.rbs +148 -0
- data/core/rubygems/rubygems.rbs +1171 -0
- data/core/rubygems/source_list.rbs +15 -0
- data/core/rubygems/specification.rbs +23 -0
- data/core/rubygems/stream_ui.rbs +5 -0
- data/core/rubygems/uninstaller.rbs +10 -0
- data/core/rubygems/version.rbs +294 -0
- data/core/set.rbs +621 -0
- data/core/signal.rbs +100 -0
- data/core/string.rbs +3583 -0
- data/core/struct.rbs +667 -0
- data/core/symbol.rbs +475 -0
- data/core/thread.rbs +1765 -0
- data/core/thread_group.rbs +79 -0
- data/core/time.rbs +1762 -0
- data/core/trace_point.rbs +477 -0
- data/core/true_class.rbs +98 -0
- data/core/unbound_method.rbs +329 -0
- data/core/warning.rbs +87 -0
- data/docs/CONTRIBUTING.md +106 -0
- data/docs/architecture.md +110 -0
- data/docs/collection.md +192 -0
- data/docs/data_and_struct.md +86 -0
- data/docs/gem.md +57 -0
- data/docs/rbs_by_example.md +309 -0
- data/docs/repo.md +125 -0
- data/docs/sigs.md +167 -0
- data/docs/stdlib.md +147 -0
- data/docs/syntax.md +910 -0
- data/docs/tools.md +17 -0
- data/exe/rbs +7 -0
- data/ext/rbs_extension/extconf.rb +15 -0
- data/ext/rbs_extension/lexer.c +2728 -0
- data/ext/rbs_extension/lexer.h +179 -0
- data/ext/rbs_extension/lexer.re +147 -0
- data/ext/rbs_extension/lexstate.c +175 -0
- data/ext/rbs_extension/location.c +325 -0
- data/ext/rbs_extension/location.h +85 -0
- data/ext/rbs_extension/main.c +33 -0
- data/ext/rbs_extension/parser.c +2973 -0
- data/ext/rbs_extension/parser.h +18 -0
- data/ext/rbs_extension/parserstate.c +397 -0
- data/ext/rbs_extension/parserstate.h +163 -0
- data/ext/rbs_extension/rbs_extension.h +31 -0
- data/ext/rbs_extension/unescape.c +32 -0
- data/goodcheck.yml +91 -0
- data/include/rbs/constants.h +82 -0
- data/include/rbs/ruby_objs.h +72 -0
- data/include/rbs/util/rbs_constant_pool.h +219 -0
- data/include/rbs.h +7 -0
- data/lib/rbs/ancestor_graph.rb +92 -0
- data/lib/rbs/annotate/annotations.rb +199 -0
- data/lib/rbs/annotate/formatter.rb +92 -0
- data/lib/rbs/annotate/rdoc_annotator.rb +400 -0
- data/lib/rbs/annotate/rdoc_source.rb +131 -0
- data/lib/rbs/annotate.rb +8 -0
- data/lib/rbs/ast/annotation.rb +29 -0
- data/lib/rbs/ast/comment.rb +29 -0
- data/lib/rbs/ast/declarations.rb +467 -0
- data/lib/rbs/ast/directives.rb +49 -0
- data/lib/rbs/ast/members.rb +451 -0
- data/lib/rbs/ast/type_param.rb +225 -0
- data/lib/rbs/ast/visitor.rb +137 -0
- data/lib/rbs/buffer.rb +67 -0
- data/lib/rbs/builtin_names.rb +58 -0
- data/lib/rbs/cli/colored_io.rb +48 -0
- data/lib/rbs/cli/diff.rb +83 -0
- data/lib/rbs/cli/validate.rb +357 -0
- data/lib/rbs/cli.rb +1223 -0
- data/lib/rbs/collection/cleaner.rb +38 -0
- data/lib/rbs/collection/config/lockfile.rb +92 -0
- data/lib/rbs/collection/config/lockfile_generator.rb +218 -0
- data/lib/rbs/collection/config.rb +81 -0
- data/lib/rbs/collection/installer.rb +32 -0
- data/lib/rbs/collection/sources/base.rb +14 -0
- data/lib/rbs/collection/sources/git.rb +258 -0
- data/lib/rbs/collection/sources/local.rb +81 -0
- data/lib/rbs/collection/sources/rubygems.rb +48 -0
- data/lib/rbs/collection/sources/stdlib.rb +50 -0
- data/lib/rbs/collection/sources.rb +38 -0
- data/lib/rbs/collection.rb +16 -0
- data/lib/rbs/constant.rb +28 -0
- data/lib/rbs/definition.rb +401 -0
- data/lib/rbs/definition_builder/ancestor_builder.rb +620 -0
- data/lib/rbs/definition_builder/method_builder.rb +254 -0
- data/lib/rbs/definition_builder.rb +845 -0
- data/lib/rbs/diff.rb +125 -0
- data/lib/rbs/environment/use_map.rb +77 -0
- data/lib/rbs/environment.rb +829 -0
- data/lib/rbs/environment_loader.rb +173 -0
- data/lib/rbs/environment_walker.rb +155 -0
- data/lib/rbs/errors.rb +645 -0
- data/lib/rbs/factory.rb +18 -0
- data/lib/rbs/file_finder.rb +28 -0
- data/lib/rbs/location_aux.rb +138 -0
- data/lib/rbs/locator.rb +243 -0
- data/lib/rbs/method_type.rb +143 -0
- data/lib/rbs/namespace.rb +125 -0
- data/lib/rbs/parser/lex_result.rb +15 -0
- data/lib/rbs/parser/token.rb +23 -0
- data/lib/rbs/parser_aux.rb +114 -0
- data/lib/rbs/prototype/helpers.rb +140 -0
- data/lib/rbs/prototype/node_usage.rb +99 -0
- data/lib/rbs/prototype/rb.rb +840 -0
- data/lib/rbs/prototype/rbi.rb +641 -0
- data/lib/rbs/prototype/runtime/helpers.rb +59 -0
- data/lib/rbs/prototype/runtime/reflection.rb +19 -0
- data/lib/rbs/prototype/runtime/value_object_generator.rb +279 -0
- data/lib/rbs/prototype/runtime.rb +667 -0
- data/lib/rbs/repository.rb +127 -0
- data/lib/rbs/resolver/constant_resolver.rb +219 -0
- data/lib/rbs/resolver/type_name_resolver.rb +91 -0
- data/lib/rbs/sorter.rb +198 -0
- data/lib/rbs/substitution.rb +83 -0
- data/lib/rbs/subtractor.rb +201 -0
- data/lib/rbs/test/errors.rb +80 -0
- data/lib/rbs/test/guaranteed.rb +30 -0
- data/lib/rbs/test/hook.rb +212 -0
- data/lib/rbs/test/observer.rb +19 -0
- data/lib/rbs/test/setup.rb +84 -0
- data/lib/rbs/test/setup_helper.rb +50 -0
- data/lib/rbs/test/tester.rb +167 -0
- data/lib/rbs/test/type_check.rb +435 -0
- data/lib/rbs/test.rb +112 -0
- data/lib/rbs/type_alias_dependency.rb +100 -0
- data/lib/rbs/type_alias_regularity.rb +126 -0
- data/lib/rbs/type_name.rb +109 -0
- data/lib/rbs/types.rb +1596 -0
- data/lib/rbs/unit_test/convertibles.rb +176 -0
- data/lib/rbs/unit_test/spy.rb +138 -0
- data/lib/rbs/unit_test/type_assertions.rb +347 -0
- data/lib/rbs/unit_test/with_aliases.rb +143 -0
- data/lib/rbs/unit_test.rb +6 -0
- data/lib/rbs/validator.rb +186 -0
- data/lib/rbs/variance_calculator.rb +189 -0
- data/lib/rbs/vendorer.rb +71 -0
- data/lib/rbs/version.rb +5 -0
- data/lib/rbs/writer.rb +424 -0
- data/lib/rbs.rb +94 -0
- data/lib/rdoc/discover.rb +20 -0
- data/lib/rdoc_plugin/parser.rb +163 -0
- data/rbs-relaxed.gemspec +48 -0
- data/schema/annotation.json +14 -0
- data/schema/comment.json +26 -0
- data/schema/decls.json +326 -0
- data/schema/function.json +87 -0
- data/schema/location.json +56 -0
- data/schema/members.json +266 -0
- data/schema/methodType.json +50 -0
- data/schema/typeParam.json +36 -0
- data/schema/types.json +317 -0
- data/sig/ancestor_builder.rbs +163 -0
- data/sig/ancestor_graph.rbs +60 -0
- data/sig/annotate/annotations.rbs +102 -0
- data/sig/annotate/formatter.rbs +24 -0
- data/sig/annotate/rdoc_annotater.rbs +82 -0
- data/sig/annotate/rdoc_source.rbs +30 -0
- data/sig/annotation.rbs +27 -0
- data/sig/buffer.rbs +32 -0
- data/sig/builtin_names.rbs +44 -0
- data/sig/cli/colored_io.rbs +15 -0
- data/sig/cli/diff.rbs +21 -0
- data/sig/cli/validate.rbs +43 -0
- data/sig/cli.rbs +87 -0
- data/sig/collection/cleaner.rbs +13 -0
- data/sig/collection/config/lockfile.rbs +74 -0
- data/sig/collection/config/lockfile_generator.rbs +66 -0
- data/sig/collection/config.rbs +46 -0
- data/sig/collection/installer.rbs +17 -0
- data/sig/collection/sources.rbs +214 -0
- data/sig/collection.rbs +4 -0
- data/sig/comment.rbs +26 -0
- data/sig/constant.rbs +21 -0
- data/sig/declarations.rbs +267 -0
- data/sig/definition.rbs +173 -0
- data/sig/definition_builder.rbs +165 -0
- data/sig/diff.rbs +28 -0
- data/sig/directives.rbs +77 -0
- data/sig/environment.rbs +279 -0
- data/sig/environment_loader.rbs +111 -0
- data/sig/environment_walker.rbs +65 -0
- data/sig/errors.rbs +405 -0
- data/sig/factory.rbs +5 -0
- data/sig/file_finder.rbs +28 -0
- data/sig/location.rbs +110 -0
- data/sig/locator.rbs +58 -0
- data/sig/manifest.yaml +7 -0
- data/sig/members.rbs +258 -0
- data/sig/method_builder.rbs +84 -0
- data/sig/method_types.rbs +58 -0
- data/sig/namespace.rbs +146 -0
- data/sig/parser.rbs +100 -0
- data/sig/prototype/helpers.rbs +27 -0
- data/sig/prototype/node_usage.rbs +20 -0
- data/sig/prototype/rb.rbs +96 -0
- data/sig/prototype/rbi.rbs +75 -0
- data/sig/prototype/runtime.rbs +182 -0
- data/sig/rbs.rbs +21 -0
- data/sig/rdoc/rbs.rbs +67 -0
- data/sig/repository.rbs +85 -0
- data/sig/resolver/constant_resolver.rbs +92 -0
- data/sig/resolver/context.rbs +34 -0
- data/sig/resolver/type_name_resolver.rbs +35 -0
- data/sig/shims/bundler.rbs +38 -0
- data/sig/shims/enumerable.rbs +5 -0
- data/sig/shims/rubygems.rbs +19 -0
- data/sig/sorter.rbs +41 -0
- data/sig/substitution.rbs +48 -0
- data/sig/subtractor.rbs +37 -0
- data/sig/test/errors.rbs +52 -0
- data/sig/test/guranteed.rbs +9 -0
- data/sig/test/type_check.rbs +19 -0
- data/sig/test.rbs +82 -0
- data/sig/type_alias_dependency.rbs +53 -0
- data/sig/type_alias_regularity.rbs +98 -0
- data/sig/type_param.rbs +110 -0
- data/sig/typename.rbs +79 -0
- data/sig/types.rbs +579 -0
- data/sig/unit_test/convertibles.rbs +154 -0
- data/sig/unit_test/spy.rbs +30 -0
- data/sig/unit_test/type_assertions.rbs +196 -0
- data/sig/unit_test/with_aliases.rbs +136 -0
- data/sig/use_map.rbs +35 -0
- data/sig/util.rbs +9 -0
- data/sig/validator.rbs +63 -0
- data/sig/variance_calculator.rbs +87 -0
- data/sig/vendorer.rbs +51 -0
- data/sig/version.rbs +3 -0
- data/sig/visitor.rbs +47 -0
- data/sig/writer.rbs +127 -0
- data/src/constants.c +153 -0
- data/src/ruby_objs.c +795 -0
- data/src/util/rbs_constant_pool.c +342 -0
- data/stdlib/abbrev/0/abbrev.rbs +66 -0
- data/stdlib/abbrev/0/array.rbs +26 -0
- data/stdlib/base64/0/base64.rbs +355 -0
- data/stdlib/benchmark/0/benchmark.rbs +452 -0
- data/stdlib/bigdecimal/0/big_decimal.rbs +1629 -0
- data/stdlib/bigdecimal-math/0/big_math.rbs +119 -0
- data/stdlib/bigdecimal-math/0/manifest.yaml +2 -0
- data/stdlib/cgi/0/core.rbs +1285 -0
- data/stdlib/cgi/0/manifest.yaml +3 -0
- data/stdlib/coverage/0/coverage.rbs +263 -0
- data/stdlib/csv/0/csv.rbs +3776 -0
- data/stdlib/csv/0/manifest.yaml +3 -0
- data/stdlib/date/0/date.rbs +1585 -0
- data/stdlib/date/0/date_time.rbs +616 -0
- data/stdlib/date/0/time.rbs +26 -0
- data/stdlib/dbm/0/dbm.rbs +421 -0
- data/stdlib/delegate/0/delegator.rbs +184 -0
- data/stdlib/delegate/0/kernel.rbs +47 -0
- data/stdlib/delegate/0/simple_delegator.rbs +96 -0
- data/stdlib/did_you_mean/0/did_you_mean.rbs +343 -0
- data/stdlib/digest/0/digest.rbs +577 -0
- data/stdlib/erb/0/erb.rbs +532 -0
- data/stdlib/etc/0/etc.rbs +865 -0
- data/stdlib/fileutils/0/fileutils.rbs +1734 -0
- data/stdlib/find/0/find.rbs +49 -0
- data/stdlib/forwardable/0/forwardable.rbs +268 -0
- data/stdlib/io-console/0/io-console.rbs +414 -0
- data/stdlib/ipaddr/0/ipaddr.rbs +428 -0
- data/stdlib/json/0/json.rbs +1916 -0
- data/stdlib/kconv/0/kconv.rbs +166 -0
- data/stdlib/logger/0/formatter.rbs +45 -0
- data/stdlib/logger/0/log_device.rbs +100 -0
- data/stdlib/logger/0/logger.rbs +796 -0
- data/stdlib/logger/0/manifest.yaml +2 -0
- data/stdlib/logger/0/period.rbs +17 -0
- data/stdlib/logger/0/severity.rbs +34 -0
- data/stdlib/minitest/0/kernel.rbs +42 -0
- data/stdlib/minitest/0/minitest/abstract_reporter.rbs +52 -0
- data/stdlib/minitest/0/minitest/assertion.rbs +17 -0
- data/stdlib/minitest/0/minitest/assertions.rbs +590 -0
- data/stdlib/minitest/0/minitest/backtrace_filter.rbs +23 -0
- data/stdlib/minitest/0/minitest/bench_spec.rbs +102 -0
- data/stdlib/minitest/0/minitest/benchmark.rbs +259 -0
- data/stdlib/minitest/0/minitest/composite_reporter.rbs +25 -0
- data/stdlib/minitest/0/minitest/compress.rbs +13 -0
- data/stdlib/minitest/0/minitest/error_on_warning.rbs +3 -0
- data/stdlib/minitest/0/minitest/expectation.rbs +2 -0
- data/stdlib/minitest/0/minitest/expectations.rbs +21 -0
- data/stdlib/minitest/0/minitest/guard.rbs +64 -0
- data/stdlib/minitest/0/minitest/mock.rbs +64 -0
- data/stdlib/minitest/0/minitest/parallel/executor.rbs +46 -0
- data/stdlib/minitest/0/minitest/parallel/test/class_methods.rbs +5 -0
- data/stdlib/minitest/0/minitest/parallel/test.rbs +3 -0
- data/stdlib/minitest/0/minitest/parallel.rbs +2 -0
- data/stdlib/minitest/0/minitest/pride_io.rbs +62 -0
- data/stdlib/minitest/0/minitest/pride_lol.rbs +19 -0
- data/stdlib/minitest/0/minitest/progress_reporter.rbs +11 -0
- data/stdlib/minitest/0/minitest/reportable.rbs +53 -0
- data/stdlib/minitest/0/minitest/reporter.rbs +5 -0
- data/stdlib/minitest/0/minitest/result.rbs +28 -0
- data/stdlib/minitest/0/minitest/runnable.rbs +163 -0
- data/stdlib/minitest/0/minitest/skip.rbs +6 -0
- data/stdlib/minitest/0/minitest/spec/dsl/instance_methods.rbs +48 -0
- data/stdlib/minitest/0/minitest/spec/dsl.rbs +129 -0
- data/stdlib/minitest/0/minitest/spec.rbs +11 -0
- data/stdlib/minitest/0/minitest/statistics_reporter.rbs +81 -0
- data/stdlib/minitest/0/minitest/summary_reporter.rbs +18 -0
- data/stdlib/minitest/0/minitest/test/lifecycle_hooks.rbs +92 -0
- data/stdlib/minitest/0/minitest/test.rbs +69 -0
- data/stdlib/minitest/0/minitest/unexpected_error.rbs +12 -0
- data/stdlib/minitest/0/minitest/unexpected_warning.rbs +6 -0
- data/stdlib/minitest/0/minitest/unit/test_case.rbs +3 -0
- data/stdlib/minitest/0/minitest/unit.rbs +4 -0
- data/stdlib/minitest/0/minitest.rbs +115 -0
- data/stdlib/monitor/0/monitor.rbs +363 -0
- data/stdlib/mutex_m/0/mutex_m.rbs +104 -0
- data/stdlib/net-http/0/manifest.yaml +3 -0
- data/stdlib/net-http/0/net-http.rbs +5552 -0
- data/stdlib/net-protocol/0/manifest.yaml +2 -0
- data/stdlib/net-protocol/0/net-protocol.rbs +56 -0
- data/stdlib/net-smtp/0/manifest.yaml +2 -0
- data/stdlib/net-smtp/0/net-smtp.rbs +55 -0
- data/stdlib/nkf/0/nkf.rbs +402 -0
- data/stdlib/objspace/0/objspace.rbs +487 -0
- data/stdlib/observable/0/observable.rbs +217 -0
- data/stdlib/open-uri/0/manifest.yaml +4 -0
- data/stdlib/open-uri/0/open-uri.rbs +393 -0
- data/stdlib/open3/0/open3.rbs +147 -0
- data/stdlib/openssl/0/manifest.yaml +3 -0
- data/stdlib/openssl/0/openssl.rbs +12113 -0
- data/stdlib/optparse/0/optparse.rbs +1725 -0
- data/stdlib/pathname/0/pathname.rbs +1406 -0
- data/stdlib/pp/0/manifest.yaml +2 -0
- data/stdlib/pp/0/pp.rbs +300 -0
- data/stdlib/prettyprint/0/prettyprint.rbs +383 -0
- data/stdlib/pstore/0/pstore.rbs +603 -0
- data/stdlib/psych/0/core_ext.rbs +12 -0
- data/stdlib/psych/0/dbm.rbs +237 -0
- data/stdlib/psych/0/manifest.yaml +3 -0
- data/stdlib/psych/0/psych.rbs +402 -0
- data/stdlib/psych/0/store.rbs +59 -0
- data/stdlib/pty/0/pty.rbs +237 -0
- data/stdlib/rdoc/0/code_object.rbs +51 -0
- data/stdlib/rdoc/0/comment.rbs +59 -0
- data/stdlib/rdoc/0/context.rbs +153 -0
- data/stdlib/rdoc/0/markup.rbs +117 -0
- data/stdlib/rdoc/0/parser.rbs +56 -0
- data/stdlib/rdoc/0/rdoc.rbs +391 -0
- data/stdlib/rdoc/0/ri.rbs +17 -0
- data/stdlib/rdoc/0/store.rbs +48 -0
- data/stdlib/rdoc/0/top_level.rbs +97 -0
- data/stdlib/resolv/0/manifest.yaml +3 -0
- data/stdlib/resolv/0/resolv.rbs +1830 -0
- data/stdlib/ripper/0/ripper.rbs +1648 -0
- data/stdlib/securerandom/0/securerandom.rbs +62 -0
- data/stdlib/shellwords/0/shellwords.rbs +229 -0
- data/stdlib/singleton/0/singleton.rbs +131 -0
- data/stdlib/socket/0/addrinfo.rbs +666 -0
- data/stdlib/socket/0/basic_socket.rbs +590 -0
- data/stdlib/socket/0/constants.rbs +2295 -0
- data/stdlib/socket/0/ip_socket.rbs +92 -0
- data/stdlib/socket/0/socket.rbs +4157 -0
- data/stdlib/socket/0/socket_error.rbs +5 -0
- data/stdlib/socket/0/tcp_server.rbs +192 -0
- data/stdlib/socket/0/tcp_socket.rbs +79 -0
- data/stdlib/socket/0/udp_socket.rbs +133 -0
- data/stdlib/socket/0/unix_server.rbs +169 -0
- data/stdlib/socket/0/unix_socket.rbs +172 -0
- data/stdlib/stringio/0/stringio.rbs +567 -0
- data/stdlib/strscan/0/string_scanner.rbs +1627 -0
- data/stdlib/tempfile/0/tempfile.rbs +479 -0
- data/stdlib/time/0/time.rbs +432 -0
- data/stdlib/timeout/0/timeout.rbs +81 -0
- data/stdlib/tmpdir/0/tmpdir.rbs +69 -0
- data/stdlib/tsort/0/cyclic.rbs +5 -0
- data/stdlib/tsort/0/interfaces.rbs +20 -0
- data/stdlib/tsort/0/tsort.rbs +409 -0
- data/stdlib/uri/0/common.rbs +582 -0
- data/stdlib/uri/0/file.rbs +118 -0
- data/stdlib/uri/0/ftp.rbs +13 -0
- data/stdlib/uri/0/generic.rbs +1108 -0
- data/stdlib/uri/0/http.rbs +104 -0
- data/stdlib/uri/0/https.rbs +14 -0
- data/stdlib/uri/0/ldap.rbs +230 -0
- data/stdlib/uri/0/ldaps.rbs +14 -0
- data/stdlib/uri/0/mailto.rbs +92 -0
- data/stdlib/uri/0/rfc2396_parser.rbs +189 -0
- data/stdlib/uri/0/rfc3986_parser.rbs +2 -0
- data/stdlib/uri/0/ws.rbs +13 -0
- data/stdlib/uri/0/wss.rbs +9 -0
- data/stdlib/yaml/0/manifest.yaml +2 -0
- data/stdlib/yaml/0/yaml.rbs +1 -0
- data/stdlib/zlib/0/buf_error.rbs +10 -0
- data/stdlib/zlib/0/data_error.rbs +10 -0
- data/stdlib/zlib/0/deflate.rbs +210 -0
- data/stdlib/zlib/0/error.rbs +20 -0
- data/stdlib/zlib/0/gzip_file/crc_error.rbs +12 -0
- data/stdlib/zlib/0/gzip_file/error.rbs +23 -0
- data/stdlib/zlib/0/gzip_file/length_error.rbs +12 -0
- data/stdlib/zlib/0/gzip_file/no_footer.rbs +11 -0
- data/stdlib/zlib/0/gzip_file.rbs +156 -0
- data/stdlib/zlib/0/gzip_reader.rbs +293 -0
- data/stdlib/zlib/0/gzip_writer.rbs +166 -0
- data/stdlib/zlib/0/inflate.rbs +180 -0
- data/stdlib/zlib/0/mem_error.rbs +10 -0
- data/stdlib/zlib/0/need_dict.rbs +13 -0
- data/stdlib/zlib/0/stream_end.rbs +11 -0
- data/stdlib/zlib/0/stream_error.rbs +11 -0
- data/stdlib/zlib/0/version_error.rbs +11 -0
- data/stdlib/zlib/0/zlib.rbs +449 -0
- data/stdlib/zlib/0/zstream.rbs +200 -0
- metadata +532 -0
@@ -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,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_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
|