rbs 2.8.4 → 3.8.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/dependabot.yml +12 -4
- data/.github/workflows/comments.yml +11 -11
- data/.github/workflows/dependabot.yml +30 -0
- data/.github/workflows/ruby.yml +40 -49
- data/.github/workflows/typecheck.yml +36 -0
- data/.github/workflows/windows.yml +28 -0
- data/.gitignore +1 -0
- data/.rubocop.yml +42 -2
- data/CHANGELOG.md +845 -1
- data/README.md +64 -4
- data/Rakefile +198 -18
- data/Steepfile +11 -11
- data/config.yml +311 -0
- data/core/array.rbs +2189 -1914
- data/core/basic_object.rbs +59 -84
- data/core/binding.rbs +7 -69
- data/core/builtin.rbs +210 -11
- data/core/class.rbs +37 -0
- data/core/comparable.rbs +23 -25
- data/core/complex.rbs +449 -227
- data/core/constants.rbs +29 -21
- data/core/data.rbs +415 -0
- data/core/dir.rbs +698 -415
- data/core/encoding.rbs +468 -843
- data/core/enumerable.rbs +495 -455
- data/core/enumerator/product.rbs +92 -0
- data/core/enumerator.rbs +106 -9
- data/core/env.rbs +1 -1
- data/core/errno.rbs +506 -605
- data/core/errors.rbs +15 -17
- data/core/exception.rbs +361 -145
- data/core/false_class.rbs +39 -26
- data/core/fiber.rbs +121 -14
- data/core/file.rbs +1262 -320
- data/core/file_test.rbs +62 -45
- data/core/float.rbs +187 -208
- data/core/gc.rbs +446 -196
- data/core/global_variables.rbs +29 -29
- data/core/hash.rbs +242 -349
- data/core/integer.rbs +246 -308
- data/core/io/buffer.rbs +373 -122
- data/core/io/wait.rbs +29 -17
- data/core/io.rbs +1881 -1518
- data/core/kernel.rbs +2116 -1538
- data/core/marshal.rbs +24 -14
- data/core/match_data.rbs +413 -166
- data/core/math.rbs +531 -291
- data/core/method.rbs +101 -32
- data/core/module.rbs +228 -64
- data/core/nil_class.rbs +106 -47
- data/core/numeric.rbs +206 -292
- data/core/object.rbs +73 -1168
- data/core/object_space/weak_key_map.rbs +166 -0
- data/core/object_space.rbs +5 -3
- data/core/proc.rbs +280 -39
- data/core/process.rbs +1318 -658
- data/core/ractor.rbs +200 -134
- data/core/random.rbs +21 -4
- data/core/range.rbs +309 -153
- data/core/rational.rbs +4 -12
- data/core/rb_config.rbs +64 -43
- data/core/rbs/unnamed/argf.rbs +411 -147
- data/core/rbs/unnamed/env_class.rbs +137 -253
- data/core/rbs/unnamed/random.rbs +49 -26
- data/core/refinement.rbs +16 -1
- data/core/regexp.rbs +1568 -862
- data/core/ruby_vm.rbs +719 -7
- data/core/rubygems/config_file.rbs +3 -0
- data/core/rubygems/errors.rbs +69 -6
- data/core/rubygems/rubygems.rbs +71 -17
- data/core/rubygems/version.rbs +11 -7
- data/{stdlib/set/0 → core}/set.rbs +80 -91
- data/core/signal.rbs +14 -8
- data/core/string.rbs +1732 -1607
- data/core/struct.rbs +467 -95
- data/core/symbol.rbs +215 -245
- data/core/thread.rbs +133 -89
- data/core/thread_group.rbs +9 -9
- data/core/time.rbs +1141 -841
- data/core/trace_point.rbs +181 -121
- data/core/true_class.rbs +58 -32
- data/core/unbound_method.rbs +103 -30
- data/core/warning.rbs +50 -5
- data/docs/CONTRIBUTING.md +1 -1
- data/docs/architecture.md +110 -0
- data/docs/collection.md +59 -5
- data/docs/data_and_struct.md +86 -0
- data/docs/gem.md +57 -0
- data/docs/rbs_by_example.md +16 -35
- data/docs/repo.md +1 -1
- data/docs/sigs.md +7 -7
- data/docs/stdlib.md +63 -5
- data/docs/syntax.md +255 -61
- data/docs/tools.md +1 -0
- data/ext/rbs_extension/extconf.rb +10 -0
- data/ext/rbs_extension/lexer.c +1741 -1548
- data/ext/rbs_extension/lexer.h +11 -1
- data/ext/rbs_extension/lexer.re +12 -6
- data/ext/rbs_extension/lexstate.c +26 -3
- data/ext/rbs_extension/location.c +119 -111
- data/ext/rbs_extension/location.h +32 -7
- data/ext/rbs_extension/main.c +3 -0
- data/ext/rbs_extension/parser.c +883 -481
- data/ext/rbs_extension/parserstate.c +65 -25
- data/ext/rbs_extension/parserstate.h +13 -3
- data/ext/rbs_extension/rbs_extension.h +1 -10
- data/ext/rbs_extension/unescape.c +7 -47
- data/goodcheck.yml +2 -2
- data/{ext/rbs_extension → include/rbs}/constants.h +26 -15
- data/include/rbs/ruby_objs.h +72 -0
- data/include/rbs.h +7 -0
- data/lib/rbs/annotate/annotations.rb +3 -3
- data/lib/rbs/annotate/formatter.rb +13 -3
- data/lib/rbs/annotate/rdoc_annotator.rb +1 -1
- data/lib/rbs/annotate/rdoc_source.rb +12 -3
- data/lib/rbs/ast/declarations.rb +85 -2
- data/lib/rbs/ast/directives.rb +39 -0
- data/lib/rbs/ast/members.rb +49 -15
- data/lib/rbs/ast/type_param.rb +104 -15
- data/lib/rbs/ast/visitor.rb +137 -0
- data/lib/rbs/buffer.rb +5 -0
- data/lib/rbs/cli/colored_io.rb +48 -0
- data/lib/rbs/cli/diff.rb +83 -0
- data/lib/rbs/cli/validate.rb +356 -0
- data/lib/rbs/cli.rb +253 -143
- data/lib/rbs/collection/cleaner.rb +8 -1
- data/lib/rbs/collection/config/lockfile.rb +92 -0
- data/lib/rbs/collection/config/lockfile_generator.rb +154 -65
- data/lib/rbs/collection/config.rb +19 -46
- data/lib/rbs/collection/installer.rb +12 -13
- data/lib/rbs/collection/sources/base.rb +2 -2
- data/lib/rbs/collection/sources/git.rb +146 -69
- data/lib/rbs/collection/sources/local.rb +81 -0
- data/lib/rbs/collection/sources/rubygems.rb +10 -12
- data/lib/rbs/collection/sources/stdlib.rb +14 -13
- data/lib/rbs/collection/sources.rb +15 -2
- data/lib/rbs/collection.rb +2 -1
- data/lib/rbs/definition.rb +13 -16
- data/lib/rbs/definition_builder/ancestor_builder.rb +100 -24
- data/lib/rbs/definition_builder/method_builder.rb +4 -4
- data/lib/rbs/definition_builder.rb +489 -584
- data/lib/rbs/diff.rb +125 -0
- data/lib/rbs/environment/use_map.rb +77 -0
- data/lib/rbs/environment.rb +406 -105
- data/lib/rbs/environment_loader.rb +48 -44
- data/lib/rbs/environment_walker.rb +1 -1
- data/lib/rbs/errors.rb +175 -56
- data/lib/rbs/file_finder.rb +28 -0
- data/lib/rbs/location_aux.rb +8 -7
- data/lib/rbs/locator.rb +37 -15
- data/lib/rbs/method_type.rb +23 -0
- data/lib/rbs/namespace.rb +1 -0
- data/lib/rbs/parser/lex_result.rb +15 -0
- data/lib/rbs/parser/token.rb +23 -0
- data/lib/rbs/parser_aux.rb +22 -13
- data/lib/rbs/prototype/helpers.rb +48 -22
- data/lib/rbs/prototype/node_usage.rb +99 -0
- data/lib/rbs/prototype/rb.rb +125 -31
- data/lib/rbs/prototype/rbi.rb +49 -36
- 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 +273 -159
- data/lib/rbs/resolver/constant_resolver.rb +24 -8
- data/lib/rbs/resolver/type_name_resolver.rb +41 -7
- data/lib/rbs/sorter.rb +153 -123
- data/lib/rbs/substitution.rb +19 -0
- data/lib/rbs/subtractor.rb +201 -0
- data/lib/rbs/test/errors.rb +24 -11
- data/lib/rbs/test/guaranteed.rb +30 -0
- data/lib/rbs/test/hook.rb +45 -40
- data/lib/rbs/test/setup.rb +1 -1
- data/lib/rbs/test/tester.rb +1 -1
- data/lib/rbs/test/type_check.rb +120 -23
- data/lib/rbs/test.rb +6 -3
- data/lib/rbs/type_alias_dependency.rb +13 -3
- data/lib/rbs/type_alias_regularity.rb +21 -14
- data/lib/rbs/type_name.rb +18 -13
- data/lib/rbs/types.rb +352 -18
- data/lib/rbs/unit_test/convertibles.rb +176 -0
- data/lib/rbs/unit_test/spy.rb +136 -0
- data/lib/rbs/unit_test/type_assertions.rb +341 -0
- data/lib/rbs/unit_test/with_aliases.rb +143 -0
- data/lib/rbs/unit_test.rb +6 -0
- data/lib/rbs/validator.rb +55 -30
- data/lib/rbs/variance_calculator.rb +26 -23
- data/lib/rbs/vendorer.rb +3 -3
- data/lib/rbs/version.rb +1 -1
- data/lib/rbs/writer.rb +69 -22
- data/lib/rbs.rb +7 -2
- data/lib/rdoc/discover.rb +1 -1
- data/lib/rdoc_plugin/parser.rb +5 -5
- data/rbs.gemspec +12 -2
- data/schema/decls.json +1 -1
- data/schema/members.json +15 -10
- data/sig/ancestor_builder.rbs +4 -0
- data/sig/ancestor_graph.rbs +22 -2
- data/sig/annotate/formatter.rbs +2 -2
- data/sig/annotate/rdoc_annotater.rbs +1 -1
- 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 +4 -0
- data/sig/collection/config/lockfile.rbs +74 -0
- data/sig/collection/config/lockfile_generator.rbs +66 -0
- data/sig/collection/config.rbs +5 -48
- data/sig/collection/installer.rbs +1 -1
- data/sig/collection/sources.rbs +105 -33
- data/sig/constant.rbs +1 -1
- data/sig/declarations.rbs +42 -3
- data/sig/definition.rbs +26 -10
- data/sig/definition_builder.rbs +103 -81
- data/sig/diff.rbs +28 -0
- data/sig/directives.rbs +61 -0
- data/sig/environment.rbs +175 -29
- data/sig/environment_loader.rbs +20 -18
- data/sig/errors.rbs +123 -2
- data/sig/file_finder.rbs +28 -0
- data/sig/location.rbs +0 -3
- data/sig/locator.rbs +14 -2
- data/sig/manifest.yaml +0 -1
- data/sig/members.rbs +32 -9
- data/sig/method_types.rbs +10 -4
- data/sig/namespace.rbs +2 -3
- data/sig/parser.rbs +55 -16
- data/sig/prototype/helpers.rbs +4 -0
- data/sig/prototype/node_usage.rbs +20 -0
- data/sig/prototype/rb.rbs +10 -2
- data/sig/prototype/rbi.rbs +2 -0
- data/sig/prototype/runtime.rbs +182 -0
- data/sig/rbs.rbs +1 -1
- data/sig/rdoc/rbs.rbs +4 -0
- data/sig/repository.rbs +7 -5
- data/sig/resolver/constant_resolver.rbs +3 -4
- data/sig/resolver/context.rbs +1 -1
- data/sig/resolver/type_name_resolver.rbs +5 -1
- data/sig/shims/bundler.rbs +38 -0
- data/sig/shims/rubygems.rbs +19 -0
- data/sig/sorter.rbs +23 -5
- data/sig/substitution.rbs +6 -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 +31 -0
- data/sig/type_alias_regularity.rbs +12 -6
- data/sig/type_param.rbs +45 -9
- data/sig/typename.rbs +8 -5
- data/sig/types.rbs +119 -12
- data/sig/unit_test/convertibles.rbs +154 -0
- data/sig/unit_test/spy.rbs +28 -0
- data/sig/unit_test/type_assertions.rbs +194 -0
- data/sig/unit_test/with_aliases.rbs +136 -0
- data/sig/use_map.rbs +35 -0
- data/sig/validator.rbs +12 -5
- data/sig/variance_calculator.rbs +3 -1
- data/sig/vendorer.rbs +1 -1
- data/sig/visitor.rbs +47 -0
- data/sig/writer.rbs +6 -2
- data/src/constants.c +153 -0
- data/src/ruby_objs.c +793 -0
- data/stdlib/base64/0/base64.rbs +298 -45
- data/stdlib/benchmark/0/benchmark.rbs +12 -3
- data/stdlib/bigdecimal/0/big_decimal.rbs +62 -198
- data/stdlib/cgi/0/core.rbs +68 -15
- data/stdlib/cgi/0/manifest.yaml +1 -0
- data/stdlib/coverage/0/coverage.rbs +50 -11
- data/stdlib/csv/0/csv.rbs +90 -119
- data/stdlib/csv/0/manifest.yaml +1 -0
- data/stdlib/date/0/date.rbs +806 -735
- data/stdlib/date/0/date_time.rbs +70 -211
- data/stdlib/dbm/0/dbm.rbs +0 -2
- 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 +3 -8
- data/stdlib/digest/0/digest.rbs +48 -35
- data/stdlib/erb/0/erb.rbs +15 -39
- data/stdlib/etc/0/etc.rbs +174 -54
- data/stdlib/fileutils/0/fileutils.rbs +1234 -385
- data/stdlib/forwardable/0/forwardable.rbs +4 -4
- data/stdlib/io-console/0/io-console.rbs +82 -17
- data/stdlib/ipaddr/0/ipaddr.rbs +11 -6
- data/stdlib/json/0/json.rbs +434 -151
- data/stdlib/kconv/0/kconv.rbs +166 -0
- data/stdlib/logger/0/formatter.rbs +0 -2
- data/stdlib/logger/0/log_device.rbs +1 -3
- data/stdlib/logger/0/logger.rbs +465 -328
- data/stdlib/minitest/0/kernel.rbs +2 -2
- data/stdlib/minitest/0/minitest/abstract_reporter.rbs +4 -1
- data/stdlib/minitest/0/minitest/assertion.rbs +1 -0
- data/stdlib/minitest/0/minitest/assertions.rbs +58 -13
- data/stdlib/minitest/0/minitest/backtrace_filter.rbs +7 -0
- data/stdlib/minitest/0/minitest/bench_spec.rbs +8 -8
- data/stdlib/minitest/0/minitest/benchmark.rbs +17 -16
- 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/mock.rbs +9 -5
- data/stdlib/minitest/0/minitest/parallel/executor.rbs +4 -0
- data/stdlib/minitest/0/minitest/parallel/test/class_methods.rbs +0 -1
- data/stdlib/minitest/0/minitest/pride_io.rbs +8 -0
- data/stdlib/minitest/0/minitest/pride_lol.rbs +2 -0
- data/stdlib/minitest/0/minitest/progress_reporter.rbs +1 -1
- data/stdlib/minitest/0/minitest/reportable.rbs +2 -0
- data/stdlib/minitest/0/minitest/runnable.rbs +33 -1
- data/stdlib/minitest/0/minitest/spec/dsl/instance_methods.rbs +1 -1
- data/stdlib/minitest/0/minitest/spec/dsl.rbs +10 -6
- data/stdlib/minitest/0/minitest/spec.rbs +1 -1
- data/stdlib/minitest/0/minitest/statistics_reporter.rbs +5 -0
- data/stdlib/minitest/0/minitest/summary_reporter.rbs +0 -7
- data/stdlib/minitest/0/minitest/test/lifecycle_hooks.rbs +7 -7
- data/stdlib/minitest/0/minitest/test.rbs +7 -14
- data/stdlib/minitest/0/minitest/unexpected_error.rbs +2 -0
- data/stdlib/minitest/0/minitest/unexpected_warning.rbs +6 -0
- data/stdlib/minitest/0/minitest/unit.rbs +1 -2
- data/stdlib/minitest/0/minitest.rbs +41 -892
- data/stdlib/monitor/0/monitor.rbs +91 -10
- data/stdlib/mutex_m/0/mutex_m.rbs +0 -2
- data/stdlib/net-http/0/manifest.yaml +1 -1
- data/stdlib/net-http/0/net-http.rbs +3858 -964
- 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 +35 -5
- data/stdlib/objspace/0/objspace.rbs +40 -18
- 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 +1 -0
- data/stdlib/openssl/0/openssl.rbs +681 -316
- data/stdlib/optparse/0/optparse.rbs +100 -65
- data/stdlib/pathname/0/pathname.rbs +24 -15
- data/stdlib/pp/0/manifest.yaml +2 -0
- data/stdlib/pp/0/pp.rbs +300 -0
- data/stdlib/prettyprint/0/prettyprint.rbs +2 -6
- data/stdlib/pstore/0/pstore.rbs +370 -156
- data/stdlib/psych/0/core_ext.rbs +12 -0
- data/stdlib/{yaml → psych}/0/dbm.rbs +3 -3
- data/stdlib/psych/0/manifest.yaml +3 -0
- data/stdlib/psych/0/psych.rbs +402 -0
- data/stdlib/{yaml → psych}/0/store.rbs +2 -2
- data/stdlib/pty/0/pty.rbs +63 -11
- 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 +13 -380
- 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/resolv.rbs +16 -79
- data/stdlib/ripper/0/ripper.rbs +1648 -0
- data/stdlib/securerandom/0/securerandom.rbs +7 -2
- data/stdlib/shellwords/0/shellwords.rbs +11 -12
- data/stdlib/singleton/0/singleton.rbs +0 -3
- data/stdlib/socket/0/addrinfo.rbs +13 -18
- data/stdlib/socket/0/basic_socket.rbs +5 -10
- data/stdlib/socket/0/ip_socket.rbs +0 -2
- data/stdlib/socket/0/socket.rbs +77 -46
- data/stdlib/socket/0/tcp_server.rbs +0 -5
- data/stdlib/socket/0/tcp_socket.rbs +36 -3
- data/stdlib/socket/0/udp_socket.rbs +4 -5
- data/stdlib/socket/0/unix_server.rbs +0 -5
- data/stdlib/socket/0/unix_socket.rbs +2 -4
- data/{core/string_io.rbs → stdlib/stringio/0/stringio.rbs} +188 -107
- data/stdlib/strscan/0/string_scanner.rbs +1269 -425
- data/stdlib/tempfile/0/tempfile.rbs +224 -61
- data/stdlib/time/0/time.rbs +48 -35
- data/stdlib/timeout/0/timeout.rbs +17 -8
- data/stdlib/tmpdir/0/tmpdir.rbs +10 -3
- data/stdlib/tsort/0/tsort.rbs +0 -4
- data/stdlib/uri/0/common.rbs +271 -144
- data/stdlib/uri/0/file.rbs +5 -0
- data/stdlib/uri/0/ftp.rbs +1 -1
- data/stdlib/uri/0/generic.rbs +26 -22
- data/stdlib/uri/0/http.rbs +4 -4
- data/stdlib/uri/0/ldap.rbs +1 -1
- data/stdlib/uri/0/mailto.rbs +84 -0
- data/stdlib/uri/0/rfc2396_parser.rbs +3 -0
- data/stdlib/yaml/0/manifest.yaml +1 -2
- data/stdlib/yaml/0/yaml.rbs +1 -199
- 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 +1 -3
- data/stdlib/zlib/0/zstream.rbs +200 -0
- data/templates/include/rbs/constants.h.erb +20 -0
- data/templates/include/rbs/ruby_objs.h.erb +10 -0
- data/templates/src/constants.c.erb +36 -0
- data/templates/src/ruby_objs.c.erb +27 -0
- data/templates/template.rb +122 -0
- metadata +136 -36
- data/Gemfile +0 -33
- data/Gemfile.lock +0 -118
- data/core/deprecated.rbs +0 -9
- data/ext/rbs_extension/constants.c +0 -135
- data/ext/rbs_extension/ruby_objs.c +0 -525
- data/ext/rbs_extension/ruby_objs.h +0 -43
- data/lib/rbs/constant_table.rb +0 -167
- data/lib/rbs/parser_compat/lexer_error.rb +0 -6
- data/lib/rbs/parser_compat/located_value.rb +0 -7
- data/lib/rbs/parser_compat/semantics_error.rb +0 -6
- data/lib/rbs/parser_compat/syntax_error.rb +0 -6
- data/lib/rbs/test/spy.rb +0 -6
- data/lib/rbs/type_name_resolver.rb +0 -67
- data/sig/constant_table.rbs +0 -30
- data/sig/shims/abstract_syntax_tree.rbs +0 -25
- data/sig/shims/pp.rbs +0 -3
- data/sig/shims/ripper.rbs +0 -8
- data/sig/shims.rbs +0 -69
- data/sig/type_name_resolver.rbs +0 -26
- data/stdlib/minitest/0/manifest.yaml +0 -2
- data/stdlib/prime/0/integer-extension.rbs +0 -41
- data/stdlib/prime/0/manifest.yaml +0 -2
- data/stdlib/prime/0/prime.rbs +0 -372
@@ -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
|