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,393 @@
|
|
1
|
+
%a{annotate:rdoc:skip}
|
2
|
+
module URI
|
3
|
+
# <!--
|
4
|
+
# rdoc-file=lib/open-uri.rb
|
5
|
+
# - open(name, *rest, &block)
|
6
|
+
# -->
|
7
|
+
# Allows the opening of various resources including URIs.
|
8
|
+
#
|
9
|
+
# If the first argument responds to the 'open' method, 'open' is called on it
|
10
|
+
# with the rest of the arguments.
|
11
|
+
#
|
12
|
+
# If the first argument is a string that begins with `(protocol)://`, it is
|
13
|
+
# parsed by URI.parse. If the parsed object responds to the 'open' method,
|
14
|
+
# 'open' is called on it with the rest of the arguments.
|
15
|
+
#
|
16
|
+
# Otherwise, Kernel#open is called.
|
17
|
+
#
|
18
|
+
# OpenURI::OpenRead#open provides URI::HTTP#open, URI::HTTPS#open and
|
19
|
+
# URI::FTP#open, Kernel#open.
|
20
|
+
#
|
21
|
+
# We can accept URIs and strings that begin with http://, https:// and ftp://.
|
22
|
+
# In these cases, the opened file object is extended by OpenURI::Meta.
|
23
|
+
#
|
24
|
+
def self.open: (String name, ?String mode, ?Integer perm, ?untyped options) -> ((StringIO & OpenURI::Meta) | (Tempfile & OpenURI::Meta))
|
25
|
+
| [T] (String name, ?String mode, ?Integer perm, ?untyped options) { (StringIO | Tempfile) -> T } -> T
|
26
|
+
end
|
27
|
+
|
28
|
+
# <!-- rdoc-file=lib/open-uri.rb -->
|
29
|
+
# OpenURI is an easy-to-use wrapper for Net::HTTP, Net::HTTPS and Net::FTP.
|
30
|
+
#
|
31
|
+
# ## Example
|
32
|
+
#
|
33
|
+
# It is possible to open an http, https or ftp URL as though it were a file:
|
34
|
+
#
|
35
|
+
# URI.open("http://www.ruby-lang.org/") {|f|
|
36
|
+
# f.each_line {|line| p line}
|
37
|
+
# }
|
38
|
+
#
|
39
|
+
# The opened file has several getter methods for its meta-information, as
|
40
|
+
# follows, since it is extended by OpenURI::Meta.
|
41
|
+
#
|
42
|
+
# URI.open("http://www.ruby-lang.org/en") {|f|
|
43
|
+
# f.each_line {|line| p line}
|
44
|
+
# p f.base_uri # <URI::HTTP:0x40e6ef2 URL:http://www.ruby-lang.org/en/>
|
45
|
+
# p f.content_type # "text/html"
|
46
|
+
# p f.charset # "iso-8859-1"
|
47
|
+
# p f.content_encoding # []
|
48
|
+
# p f.last_modified # Thu Dec 05 02:45:02 UTC 2002
|
49
|
+
# }
|
50
|
+
#
|
51
|
+
# Additional header fields can be specified by an optional hash argument.
|
52
|
+
#
|
53
|
+
# URI.open("http://www.ruby-lang.org/en/",
|
54
|
+
# "User-Agent" => "Ruby/#{RUBY_VERSION}",
|
55
|
+
# "From" => "foo@bar.invalid",
|
56
|
+
# "Referer" => "http://www.ruby-lang.org/") {|f|
|
57
|
+
# # ...
|
58
|
+
# }
|
59
|
+
#
|
60
|
+
# The environment variables such as http_proxy, https_proxy and ftp_proxy are in
|
61
|
+
# effect by default. Here we disable proxy:
|
62
|
+
#
|
63
|
+
# URI.open("http://www.ruby-lang.org/en/", :proxy => nil) {|f|
|
64
|
+
# # ...
|
65
|
+
# }
|
66
|
+
#
|
67
|
+
# See OpenURI::OpenRead.open and URI.open for more on available options.
|
68
|
+
#
|
69
|
+
# URI objects can be opened in a similar way.
|
70
|
+
#
|
71
|
+
# uri = URI.parse("http://www.ruby-lang.org/en/")
|
72
|
+
# uri.open {|f|
|
73
|
+
# # ...
|
74
|
+
# }
|
75
|
+
#
|
76
|
+
# URI objects can be read directly. The returned string is also extended by
|
77
|
+
# OpenURI::Meta.
|
78
|
+
#
|
79
|
+
# str = uri.read
|
80
|
+
# p str.base_uri
|
81
|
+
#
|
82
|
+
# Author
|
83
|
+
# : Tanaka Akira <akr@m17n.org>
|
84
|
+
#
|
85
|
+
module OpenURI
|
86
|
+
# <!-- rdoc-file=lib/open-uri.rb -->
|
87
|
+
# Mixin for holding meta-information.
|
88
|
+
#
|
89
|
+
module Meta
|
90
|
+
# <!-- rdoc-file=lib/open-uri.rb -->
|
91
|
+
# returns an Array that consists of status code and message.
|
92
|
+
#
|
93
|
+
attr_accessor status: [ String, String ]
|
94
|
+
|
95
|
+
# <!-- rdoc-file=lib/open-uri.rb -->
|
96
|
+
# returns a URI that is the base of relative URIs in the data. It may differ
|
97
|
+
# from the URI supplied by a user due to redirection.
|
98
|
+
#
|
99
|
+
attr_accessor base_uri: URI::Generic
|
100
|
+
|
101
|
+
# <!-- rdoc-file=lib/open-uri.rb -->
|
102
|
+
# returns a Hash that represents header fields. The Hash keys are downcased for
|
103
|
+
# canonicalization. The Hash values are a field body. If there are multiple
|
104
|
+
# field with same field name, the field values are concatenated with a comma.
|
105
|
+
#
|
106
|
+
attr_reader meta: Hash[String, String]
|
107
|
+
|
108
|
+
# <!--
|
109
|
+
# rdoc-file=lib/open-uri.rb
|
110
|
+
# - last_modified()
|
111
|
+
# -->
|
112
|
+
# returns a Time that represents the Last-Modified field.
|
113
|
+
#
|
114
|
+
def last_modified: () -> Time?
|
115
|
+
|
116
|
+
# <!--
|
117
|
+
# rdoc-file=lib/open-uri.rb
|
118
|
+
# - content_type()
|
119
|
+
# -->
|
120
|
+
# returns "type/subtype" which is MIME Content-Type. It is downcased for
|
121
|
+
# canonicalization. Content-Type parameters are stripped.
|
122
|
+
#
|
123
|
+
def content_type: () -> String
|
124
|
+
|
125
|
+
def charet: () -> String?
|
126
|
+
|
127
|
+
# <!--
|
128
|
+
# rdoc-file=lib/open-uri.rb
|
129
|
+
# - content_encoding()
|
130
|
+
# -->
|
131
|
+
# Returns a list of encodings in Content-Encoding field as an array of strings.
|
132
|
+
#
|
133
|
+
# The encodings are downcased for canonicalization.
|
134
|
+
#
|
135
|
+
def content_encoding: () -> Array[String]
|
136
|
+
end
|
137
|
+
|
138
|
+
# <!-- rdoc-file=lib/open-uri.rb -->
|
139
|
+
# Mixin for HTTP and FTP URIs.
|
140
|
+
#
|
141
|
+
module OpenRead
|
142
|
+
# <!--
|
143
|
+
# rdoc-file=lib/open-uri.rb
|
144
|
+
# - open(*rest, &block)
|
145
|
+
# -->
|
146
|
+
# OpenURI::OpenRead#open provides `open' for URI::HTTP and URI::FTP.
|
147
|
+
#
|
148
|
+
# OpenURI::OpenRead#open takes optional 3 arguments as:
|
149
|
+
#
|
150
|
+
# OpenURI::OpenRead#open([mode [, perm]] [, options]) [{|io| ... }]
|
151
|
+
#
|
152
|
+
# OpenURI::OpenRead#open returns an IO-like object if block is not given.
|
153
|
+
# Otherwise it yields the IO object and return the value of the block. The IO
|
154
|
+
# object is extended with OpenURI::Meta.
|
155
|
+
#
|
156
|
+
# `mode` and `perm` are the same as Kernel#open.
|
157
|
+
#
|
158
|
+
# However, `mode` must be read mode because OpenURI::OpenRead#open doesn't
|
159
|
+
# support write mode (yet). Also `perm` is ignored because it is meaningful only
|
160
|
+
# for file creation.
|
161
|
+
#
|
162
|
+
# `options` must be a hash.
|
163
|
+
#
|
164
|
+
# Each option with a string key specifies an extra header field for HTTP. I.e.,
|
165
|
+
# it is ignored for FTP without HTTP proxy.
|
166
|
+
#
|
167
|
+
# The hash may include other options, where keys are symbols:
|
168
|
+
#
|
169
|
+
# :proxy
|
170
|
+
# : Synopsis:
|
171
|
+
# :proxy => "http://proxy.foo.com:8000/"
|
172
|
+
# :proxy => URI.parse("http://proxy.foo.com:8000/")
|
173
|
+
# :proxy => true
|
174
|
+
# :proxy => false
|
175
|
+
# :proxy => nil
|
176
|
+
#
|
177
|
+
# If :proxy option is specified, the value should be String, URI, boolean or
|
178
|
+
# nil.
|
179
|
+
#
|
180
|
+
# When String or URI is given, it is treated as proxy URI.
|
181
|
+
#
|
182
|
+
# When true is given or the option itself is not specified, environment
|
183
|
+
# variable `scheme_proxy' is examined. `scheme' is replaced by `http',
|
184
|
+
# `https' or `ftp'.
|
185
|
+
#
|
186
|
+
# When false or nil is given, the environment variables are ignored and
|
187
|
+
# connection will be made to a server directly.
|
188
|
+
#
|
189
|
+
#
|
190
|
+
# :proxy_http_basic_authentication
|
191
|
+
# : Synopsis:
|
192
|
+
# :proxy_http_basic_authentication =>
|
193
|
+
# ["http://proxy.foo.com:8000/", "proxy-user", "proxy-password"]
|
194
|
+
# :proxy_http_basic_authentication =>
|
195
|
+
# [URI.parse("http://proxy.foo.com:8000/"),
|
196
|
+
# "proxy-user", "proxy-password"]
|
197
|
+
#
|
198
|
+
# If :proxy option is specified, the value should be an Array with 3
|
199
|
+
# elements. It should contain a proxy URI, a proxy user name and a proxy
|
200
|
+
# password. The proxy URI should be a String, an URI or nil. The proxy
|
201
|
+
# user name and password should be a String.
|
202
|
+
#
|
203
|
+
# If nil is given for the proxy URI, this option is just ignored.
|
204
|
+
#
|
205
|
+
# If :proxy and :proxy_http_basic_authentication is specified, ArgumentError
|
206
|
+
# is raised.
|
207
|
+
#
|
208
|
+
#
|
209
|
+
# :http_basic_authentication
|
210
|
+
# : Synopsis:
|
211
|
+
# :http_basic_authentication=>[user, password]
|
212
|
+
#
|
213
|
+
# If :http_basic_authentication is specified, the value should be an array
|
214
|
+
# which contains 2 strings: username and password. It is used for HTTP Basic
|
215
|
+
# authentication defined by RFC 2617.
|
216
|
+
#
|
217
|
+
#
|
218
|
+
# :content_length_proc
|
219
|
+
# : Synopsis:
|
220
|
+
# :content_length_proc => lambda {|content_length| ... }
|
221
|
+
#
|
222
|
+
# If :content_length_proc option is specified, the option value procedure is
|
223
|
+
# called before actual transfer is started. It takes one argument, which is
|
224
|
+
# expected content length in bytes.
|
225
|
+
#
|
226
|
+
# If two or more transfers are performed by HTTP redirection, the procedure
|
227
|
+
# is called only once for the last transfer.
|
228
|
+
#
|
229
|
+
# When expected content length is unknown, the procedure is called with nil.
|
230
|
+
# This happens when the HTTP response has no Content-Length header.
|
231
|
+
#
|
232
|
+
#
|
233
|
+
# :progress_proc
|
234
|
+
# : Synopsis:
|
235
|
+
# :progress_proc => lambda {|size| ...}
|
236
|
+
#
|
237
|
+
# If :progress_proc option is specified, the proc is called with one
|
238
|
+
# argument each time when `open' gets content fragment from network. The
|
239
|
+
# argument `size` is the accumulated transferred size in bytes.
|
240
|
+
#
|
241
|
+
# If two or more transfer is done by HTTP redirection, the procedure is
|
242
|
+
# called only one for a last transfer.
|
243
|
+
#
|
244
|
+
# :progress_proc and :content_length_proc are intended to be used for
|
245
|
+
# progress bar. For example, it can be implemented as follows using
|
246
|
+
# Ruby/ProgressBar.
|
247
|
+
#
|
248
|
+
# pbar = nil
|
249
|
+
# open("http://...",
|
250
|
+
# :content_length_proc => lambda {|t|
|
251
|
+
# if t && 0 < t
|
252
|
+
# pbar = ProgressBar.new("...", t)
|
253
|
+
# pbar.file_transfer_mode
|
254
|
+
# end
|
255
|
+
# },
|
256
|
+
# :progress_proc => lambda {|s|
|
257
|
+
# pbar.set s if pbar
|
258
|
+
# }) {|f| ... }
|
259
|
+
#
|
260
|
+
#
|
261
|
+
# :read_timeout
|
262
|
+
# : Synopsis:
|
263
|
+
# :read_timeout=>nil (no timeout)
|
264
|
+
# :read_timeout=>10 (10 second)
|
265
|
+
#
|
266
|
+
# :read_timeout option specifies a timeout of read for http connections.
|
267
|
+
#
|
268
|
+
#
|
269
|
+
# :open_timeout
|
270
|
+
# : Synopsis:
|
271
|
+
# :open_timeout=>nil (no timeout)
|
272
|
+
# :open_timeout=>10 (10 second)
|
273
|
+
#
|
274
|
+
# :open_timeout option specifies a timeout of open for http connections.
|
275
|
+
#
|
276
|
+
#
|
277
|
+
# :ssl_ca_cert
|
278
|
+
# : Synopsis:
|
279
|
+
# :ssl_ca_cert=>filename or an Array of filenames
|
280
|
+
#
|
281
|
+
# :ssl_ca_cert is used to specify CA certificate for SSL. If it is given,
|
282
|
+
# default certificates are not used.
|
283
|
+
#
|
284
|
+
#
|
285
|
+
# :ssl_verify_mode
|
286
|
+
# : Synopsis:
|
287
|
+
# :ssl_verify_mode=>mode
|
288
|
+
#
|
289
|
+
# :ssl_verify_mode is used to specify openssl verify mode.
|
290
|
+
#
|
291
|
+
#
|
292
|
+
# :ssl_min_version
|
293
|
+
# : Synopsis:
|
294
|
+
# :ssl_min_version=>:TLS1_2
|
295
|
+
#
|
296
|
+
# :ssl_min_version option specifies the minimum allowed SSL/TLS protocol
|
297
|
+
# version. See also OpenSSL::SSL::SSLContext#min_version=.
|
298
|
+
#
|
299
|
+
#
|
300
|
+
# :ssl_max_version
|
301
|
+
# : Synopsis:
|
302
|
+
# :ssl_max_version=>:TLS1_2
|
303
|
+
#
|
304
|
+
# :ssl_max_version option specifies the maximum allowed SSL/TLS protocol
|
305
|
+
# version. See also OpenSSL::SSL::SSLContext#max_version=.
|
306
|
+
#
|
307
|
+
#
|
308
|
+
# :ftp_active_mode
|
309
|
+
# : Synopsis:
|
310
|
+
# :ftp_active_mode=>bool
|
311
|
+
#
|
312
|
+
# `:ftp_active_mode => true` is used to make ftp active mode. Ruby 1.9 uses
|
313
|
+
# passive mode by default. Note that the active mode is default in Ruby 1.8
|
314
|
+
# or prior.
|
315
|
+
#
|
316
|
+
#
|
317
|
+
# :redirect
|
318
|
+
# : Synopsis:
|
319
|
+
# :redirect=>bool
|
320
|
+
#
|
321
|
+
# `:redirect` is true by default. `:redirect => false` is used to disable
|
322
|
+
# all HTTP redirects.
|
323
|
+
#
|
324
|
+
# OpenURI::HTTPRedirect exception raised on redirection. Using `true` also
|
325
|
+
# means that redirections between http and ftp are permitted.
|
326
|
+
#
|
327
|
+
#
|
328
|
+
# :max_redirects
|
329
|
+
# : Synopsis:
|
330
|
+
# :max_redirects=>int
|
331
|
+
#
|
332
|
+
# Number of HTTP redirects allowed before OpenURI::TooManyRedirects is
|
333
|
+
# raised. The default is 64.
|
334
|
+
#
|
335
|
+
#
|
336
|
+
# :request_specific_fields
|
337
|
+
# : Synopsis:
|
338
|
+
# :request_specific_fields => {}
|
339
|
+
# :request_specific_fields => lambda {|url| ...}
|
340
|
+
#
|
341
|
+
# :request_specific_fields option allows specifying custom header fields
|
342
|
+
# that are sent with the HTTP request. It can be passed as a Hash or a Proc
|
343
|
+
# that gets evaluated on each request and returns a Hash of header fields.
|
344
|
+
#
|
345
|
+
# If a Hash is provided, it specifies the headers only for the initial
|
346
|
+
# request and these headers will not be sent on redirects.
|
347
|
+
#
|
348
|
+
# If a Proc is provided, it will be executed for each request including
|
349
|
+
# redirects, allowing dynamic header customization based on the request URL.
|
350
|
+
# It is important that the Proc returns a Hash. And this Hash specifies the
|
351
|
+
# headers to be sent with the request.
|
352
|
+
#
|
353
|
+
# For Example with Hash
|
354
|
+
# URI.open("http://...",
|
355
|
+
# request_specific_fields: {"Authorization" => "token dummy"}) {|f| ... }
|
356
|
+
#
|
357
|
+
# For Example with Proc:
|
358
|
+
# URI.open("http://...",
|
359
|
+
# request_specific_fields: lambda { |uri|
|
360
|
+
# if uri.host == "example.com"
|
361
|
+
# {"Authorization" => "token dummy"}
|
362
|
+
# else
|
363
|
+
# {}
|
364
|
+
# end
|
365
|
+
# }) {|f| ... }
|
366
|
+
#
|
367
|
+
def open: (*untyped) -> IO
|
368
|
+
| [T] (*untyped) { (IO) -> T } -> T
|
369
|
+
|
370
|
+
# <!--
|
371
|
+
# rdoc-file=lib/open-uri.rb
|
372
|
+
# - read(options={})
|
373
|
+
# -->
|
374
|
+
# OpenURI::OpenRead#read([ options ]) reads a content referenced by self and
|
375
|
+
# returns the content as string. The string is extended with OpenURI::Meta. The
|
376
|
+
# argument `options` is same as OpenURI::OpenRead#open.
|
377
|
+
#
|
378
|
+
def read: (untyped options) -> String
|
379
|
+
end
|
380
|
+
end
|
381
|
+
|
382
|
+
%a{annotate:rdoc:skip}
|
383
|
+
module URI
|
384
|
+
%a{annotate:rdoc:skip}
|
385
|
+
class HTTP
|
386
|
+
include OpenURI::OpenRead
|
387
|
+
end
|
388
|
+
|
389
|
+
%a{annotate:rdoc:skip}
|
390
|
+
class FTP
|
391
|
+
include OpenURI::OpenRead
|
392
|
+
end
|
393
|
+
end
|
@@ -0,0 +1,147 @@
|
|
1
|
+
# <!-- rdoc-file=lib/open3.rb -->
|
2
|
+
# Module Open3 supports creating child processes with access to their $stdin,
|
3
|
+
# $stdout, and $stderr streams.
|
4
|
+
#
|
5
|
+
# ## What's Here
|
6
|
+
#
|
7
|
+
# Each of these methods executes a given command in a new process or subshell,
|
8
|
+
# or multiple commands in new processes and/or subshells:
|
9
|
+
#
|
10
|
+
# * Each of these methods executes a single command in a process or subshell,
|
11
|
+
# accepts a string for input to $stdin, and returns string output from
|
12
|
+
# $stdout, $stderr, or both:
|
13
|
+
#
|
14
|
+
# * Open3.capture2: Executes the command; returns the string from $stdout.
|
15
|
+
# * Open3.capture2e: Executes the command; returns the string from merged
|
16
|
+
# $stdout and $stderr.
|
17
|
+
# * Open3.capture3: Executes the command; returns strings from $stdout and
|
18
|
+
# $stderr.
|
19
|
+
#
|
20
|
+
# * Each of these methods executes a single command in a process or subshell,
|
21
|
+
# and returns pipes for $stdin, $stdout, and/or $stderr:
|
22
|
+
#
|
23
|
+
# * Open3.popen2: Executes the command; returns pipes for $stdin and
|
24
|
+
# $stdout.
|
25
|
+
# * Open3.popen2e: Executes the command; returns pipes for $stdin and
|
26
|
+
# merged $stdout and $stderr.
|
27
|
+
# * Open3.popen3: Executes the command; returns pipes for $stdin, $stdout,
|
28
|
+
# and $stderr.
|
29
|
+
#
|
30
|
+
# * Each of these methods executes one or more commands in processes and/or
|
31
|
+
# subshells, returns pipes for the first $stdin, the last $stdout, or both:
|
32
|
+
#
|
33
|
+
# * Open3.pipeline_r: Returns a pipe for the last $stdout.
|
34
|
+
# * Open3.pipeline_rw: Returns pipes for the first $stdin and the last
|
35
|
+
# $stdout.
|
36
|
+
# * Open3.pipeline_w: Returns a pipe for the first $stdin.
|
37
|
+
# * Open3.pipeline_start: Does not wait for processes to complete.
|
38
|
+
# * Open3.pipeline: Waits for processes to complete.
|
39
|
+
#
|
40
|
+
# Each of the methods above accepts:
|
41
|
+
#
|
42
|
+
# * An optional hash of environment variable names and values; see [Execution
|
43
|
+
# Environment](rdoc-ref:Process@Execution+Environment).
|
44
|
+
# * A required string argument that is a `command_line` or `exe_path`; see
|
45
|
+
# [Argument command_line or
|
46
|
+
# exe_path](rdoc-ref:Process@Argument+command_line+or+exe_path).
|
47
|
+
# * An optional hash of execution options; see [Execution
|
48
|
+
# Options](rdoc-ref:Process@Execution+Options).
|
49
|
+
#
|
50
|
+
module Open3
|
51
|
+
# <!--
|
52
|
+
# rdoc-file=lib/open3.rb
|
53
|
+
# - Open3.capture2e([env, ] command_line, options = {}) -> [stdout_and_stderr_s, status]
|
54
|
+
# - Open3.capture2e([env, ] exe_path, *args, options = {}) -> [stdout_and_stderr_s, status]
|
55
|
+
# -->
|
56
|
+
# Basically a wrapper for Open3.popen3 that:
|
57
|
+
#
|
58
|
+
# * Creates a child process, by calling Open3.popen3 with the given arguments
|
59
|
+
# (except for certain entries in hash `options`; see below).
|
60
|
+
# * Returns as string `stdout_and_stderr_s` the merged standard output and
|
61
|
+
# standard error of the child process.
|
62
|
+
# * Returns as `status` a `Process::Status` object that represents the exit
|
63
|
+
# status of the child process.
|
64
|
+
#
|
65
|
+
# Returns the array `[stdout_and_stderr_s, status]`:
|
66
|
+
#
|
67
|
+
# stdout_and_stderr_s, status = Open3.capture2e('echo "Foo"')
|
68
|
+
# # => ["Foo\n", #<Process::Status: pid 2371692 exit 0>]
|
69
|
+
#
|
70
|
+
# Like Process.spawn, this method has potential security vulnerabilities if
|
71
|
+
# called with untrusted input; see [Command
|
72
|
+
# Injection](rdoc-ref:command_injection.rdoc@Command+Injection).
|
73
|
+
#
|
74
|
+
# Unlike Process.spawn, this method waits for the child process to exit before
|
75
|
+
# returning, so the caller need not do so.
|
76
|
+
#
|
77
|
+
# If the first argument is a hash, it becomes leading argument `env` in the call
|
78
|
+
# to Open3.popen3; see [Execution
|
79
|
+
# Environment](rdoc-ref:Process@Execution+Environment).
|
80
|
+
#
|
81
|
+
# If the last argument is a hash, it becomes trailing argument `options` in the
|
82
|
+
# call to Open3.popen3; see [Execution
|
83
|
+
# Options](rdoc-ref:Process@Execution+Options).
|
84
|
+
#
|
85
|
+
# The hash `options` is given; two options have local effect in method
|
86
|
+
# Open3.capture2e:
|
87
|
+
#
|
88
|
+
# * If entry `options[:stdin_data]` exists, the entry is removed and its
|
89
|
+
# string value is sent to the command's standard input:
|
90
|
+
#
|
91
|
+
# Open3.capture2e('tee', stdin_data: 'Foo')
|
92
|
+
# # => ["Foo", #<Process::Status: pid 2371732 exit 0>]
|
93
|
+
#
|
94
|
+
# * If entry `options[:binmode]` exists, the entry is removed and the internal
|
95
|
+
# streams are set to binary mode.
|
96
|
+
#
|
97
|
+
# The single required argument is one of the following:
|
98
|
+
#
|
99
|
+
# * `command_line` if it is a string, and if it begins with a shell reserved
|
100
|
+
# word or special built-in, or if it contains one or more metacharacters.
|
101
|
+
# * `exe_path` otherwise.
|
102
|
+
#
|
103
|
+
# **Argument `command_line`**
|
104
|
+
#
|
105
|
+
# String argument `command_line` is a command line to be passed to a shell; it
|
106
|
+
# must begin with a shell reserved word, begin with a special built-in, or
|
107
|
+
# contain meta characters:
|
108
|
+
#
|
109
|
+
# Open3.capture2e('if true; then echo "Foo"; fi') # Shell reserved word.
|
110
|
+
# # => ["Foo\n", #<Process::Status: pid 2371740 exit 0>]
|
111
|
+
# Open3.capture2e('echo') # Built-in.
|
112
|
+
# # => ["\n", #<Process::Status: pid 2371774 exit 0>]
|
113
|
+
# Open3.capture2e('date > date.tmp') # Contains meta character.
|
114
|
+
# # => ["", #<Process::Status: pid 2371812 exit 0>]
|
115
|
+
#
|
116
|
+
# The command line may also contain arguments and options for the command:
|
117
|
+
#
|
118
|
+
# Open3.capture2e('echo "Foo"')
|
119
|
+
# # => ["Foo\n", #<Process::Status: pid 2326183 exit 0>]
|
120
|
+
#
|
121
|
+
# **Argument `exe_path`**
|
122
|
+
#
|
123
|
+
# Argument `exe_path` is one of the following:
|
124
|
+
#
|
125
|
+
# * The string path to an executable to be called.
|
126
|
+
# * A 2-element array containing the path to an executable and the string to
|
127
|
+
# be used as the name of the executing process.
|
128
|
+
#
|
129
|
+
# Example:
|
130
|
+
#
|
131
|
+
# Open3.capture2e('/usr/bin/date')
|
132
|
+
# # => ["Sat Sep 30 09:01:46 AM CDT 2023\n", #<Process::Status: pid 2371820 exit 0>]
|
133
|
+
#
|
134
|
+
# Ruby invokes the executable directly, with no shell and no shell expansion:
|
135
|
+
#
|
136
|
+
# Open3.capture2e('doesnt_exist') # Raises Errno::ENOENT
|
137
|
+
#
|
138
|
+
# If one or more `args` is given, each is an argument or option to be passed to
|
139
|
+
# the executable:
|
140
|
+
#
|
141
|
+
# Open3.capture2e('echo', 'C #')
|
142
|
+
# # => ["C #\n", #<Process::Status: pid 2371856 exit 0>]
|
143
|
+
# Open3.capture2e('echo', 'hello', 'world')
|
144
|
+
# # => ["hello world\n", #<Process::Status: pid 2371894 exit 0>]
|
145
|
+
#
|
146
|
+
def self.capture2e: (*String, ?stdin_data: String, ?binmode: boolish) -> [String, Process::Status]
|
147
|
+
end
|