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
@@ -27,7 +27,6 @@ class TCPSocket < IPSocket
|
|
27
27
|
# cannot be released since gethostbyname() is not thread safe.)
|
28
28
|
# * This method uses gethostbyname() function already removed from POSIX.
|
29
29
|
#
|
30
|
-
#
|
31
30
|
# This method lookups host information by *hostname*.
|
32
31
|
#
|
33
32
|
# TCPSocket.gethostbyname("localhost")
|
@@ -38,9 +37,43 @@ class TCPSocket < IPSocket
|
|
38
37
|
private
|
39
38
|
|
40
39
|
# <!--
|
41
|
-
# rdoc-file=
|
42
|
-
# - new(
|
40
|
+
# rdoc-file=ext/socket/tcpsocket.c
|
41
|
+
# - TCPSocket.new(remote_host, remote_port, local_host=nil, local_port=nil, resolv_timeout: nil, connect_timeout: nil, fast_fallback: true)
|
43
42
|
# -->
|
43
|
+
# Opens a TCP connection to `remote_host` on `remote_port`. If `local_host` and
|
44
|
+
# `local_port` are specified, then those parameters are used on the local end to
|
45
|
+
# establish the connection.
|
46
|
+
#
|
47
|
+
# Starting from Ruby 3.4, this method operates according to the Happy Eyeballs
|
48
|
+
# Version 2 ([RFC 8305](https://datatracker.ietf.org/doc/html/rfc8305))
|
49
|
+
# algorithm by default, except on Windows.
|
50
|
+
#
|
51
|
+
# For details on Happy Eyeballs Version 2, see
|
52
|
+
# [Socket.tcp_fast_fallback=](rdoc-ref:Socket.tcp_fast_fallback=).
|
53
|
+
#
|
54
|
+
# To make it behave the same as in Ruby 3.3 and earlier, explicitly specify the
|
55
|
+
# option fast_fallback:false. Or, setting Socket.tcp_fast_fallback=false will
|
56
|
+
# disable Happy Eyeballs Version 2 not only for this method but for all Socket
|
57
|
+
# globally.
|
58
|
+
#
|
59
|
+
# When using TCPSocket.new on Windows, Happy Eyeballs Version 2 is not provided,
|
60
|
+
# and it behaves the same as in Ruby 3.3 and earlier.
|
61
|
+
#
|
62
|
+
# :resolv_timeout
|
63
|
+
# : Specifies the timeout in seconds from when the hostname resolution starts.
|
64
|
+
#
|
65
|
+
# :connect_timeout
|
66
|
+
# : This method sequentially attempts connecting to all candidate destination
|
67
|
+
# addresses.
|
68
|
+
# The `connect_timeout` specifies the timeout in seconds from the start of
|
69
|
+
# the connection attempt to the last candidate.
|
70
|
+
# By default, all connection attempts continue until the timeout occurs.
|
71
|
+
# When `fast_fallback:false` is explicitly specified,
|
72
|
+
# a timeout is set for each connection attempt and any connection attempt
|
73
|
+
# that exceeds its timeout will be canceled.
|
74
|
+
#
|
75
|
+
# :fast_fallback
|
76
|
+
# : Enables the Happy Eyeballs Version 2 algorithm (enabled by default).
|
44
77
|
#
|
45
78
|
def initialize: (String remote_host, Integer remote_port, ?String local_host, ?Integer local_port) -> untyped
|
46
79
|
end
|
@@ -2,8 +2,6 @@
|
|
2
2
|
# UDPSocket represents a UDP/IP socket.
|
3
3
|
#
|
4
4
|
class UDPSocket < IPSocket
|
5
|
-
public
|
6
|
-
|
7
5
|
# <!--
|
8
6
|
# rdoc-file=ext/socket/udpsocket.c
|
9
7
|
# - udpsocket.bind(host, port) #=> 0
|
@@ -44,8 +42,10 @@ class UDPSocket < IPSocket
|
|
44
42
|
# received. The second element, *sender_inet_addr*, is an array to represent the
|
45
43
|
# sender address.
|
46
44
|
#
|
47
|
-
# When recvfrom(2) returns 0, Socket#
|
48
|
-
#
|
45
|
+
# When recvfrom(2) returns 0, Socket#recv_nonblock returns nil. In most cases it
|
46
|
+
# means the connection was closed, but it may also mean an empty packet was
|
47
|
+
# received, as the underlying API makes it impossible to distinguish these two
|
48
|
+
# cases.
|
49
49
|
#
|
50
50
|
# ### Parameters
|
51
51
|
# * `maxlen` - the number of bytes to receive from the socket
|
@@ -53,7 +53,6 @@ class UDPSocket < IPSocket
|
|
53
53
|
# * `outbuf` - destination String buffer
|
54
54
|
# * `options` - keyword hash, supporting `exception: false`
|
55
55
|
#
|
56
|
-
#
|
57
56
|
# ### Example
|
58
57
|
# require 'socket'
|
59
58
|
# s1 = UDPSocket.new
|
@@ -2,8 +2,6 @@
|
|
2
2
|
# UNIXServer represents a UNIX domain stream server socket.
|
3
3
|
#
|
4
4
|
class UNIXServer < UNIXSocket
|
5
|
-
public
|
6
|
-
|
7
5
|
# <!--
|
8
6
|
# rdoc-file=ext/socket/unixserver.c
|
9
7
|
# - unixserver.accept => unixsocket
|
@@ -71,7 +69,6 @@ class UNIXServer < UNIXSocket
|
|
71
69
|
# ### Parameter
|
72
70
|
# * `backlog` - the maximum length of the queue for pending connections.
|
73
71
|
#
|
74
|
-
#
|
75
72
|
# ### Example 1
|
76
73
|
# require 'socket'
|
77
74
|
# include Socket::Constants
|
@@ -108,7 +105,6 @@ class UNIXServer < UNIXSocket
|
|
108
105
|
# * Errno::ENOBUFS - insufficient resources are available in the system to
|
109
106
|
# complete the call
|
110
107
|
#
|
111
|
-
#
|
112
108
|
# ### Windows Exceptions
|
113
109
|
# On Windows systems the following system exceptions may be raised if the call
|
114
110
|
# to *listen* fails:
|
@@ -128,7 +124,6 @@ class UNIXServer < UNIXSocket
|
|
128
124
|
# * Errno::EOPNOTSUPP - the referenced `socket` is not a type that supports
|
129
125
|
# the *listen* method
|
130
126
|
#
|
131
|
-
#
|
132
127
|
# ### See
|
133
128
|
# * listen manual pages on unix-based systems
|
134
129
|
# * listen function in Microsoft's Winsock functions reference
|
@@ -9,7 +9,7 @@ class UNIXSocket < BasicSocket
|
|
9
9
|
# -->
|
10
10
|
# Creates a pair of sockets connected to each other.
|
11
11
|
#
|
12
|
-
# *
|
12
|
+
# *type* should be a socket type such as: :STREAM, :DGRAM, :RAW, etc.
|
13
13
|
#
|
14
14
|
# *protocol* should be a protocol defined in the domain. 0 is default protocol
|
15
15
|
# for the domain.
|
@@ -28,7 +28,7 @@ class UNIXSocket < BasicSocket
|
|
28
28
|
# -->
|
29
29
|
# Creates a pair of sockets connected to each other.
|
30
30
|
#
|
31
|
-
# *
|
31
|
+
# *type* should be a socket type such as: :STREAM, :DGRAM, :RAW, etc.
|
32
32
|
#
|
33
33
|
# *protocol* should be a protocol defined in the domain. 0 is default protocol
|
34
34
|
# for the domain.
|
@@ -40,8 +40,6 @@ class UNIXSocket < BasicSocket
|
|
40
40
|
#
|
41
41
|
def self.socketpair: (?Symbol socktype, ?Integer protocol) -> [ instance, instance ]
|
42
42
|
|
43
|
-
public
|
44
|
-
|
45
43
|
# <!--
|
46
44
|
# rdoc-file=ext/socket/unixsocket.c
|
47
45
|
# - unixsocket.addr => [address_family, unix_path]
|
@@ -1,39 +1,52 @@
|
|
1
1
|
# <!-- rdoc-file=ext/stringio/stringio.c -->
|
2
|
-
#
|
2
|
+
# IO streams for strings, with access similar to [IO](rdoc-ref:IO); see
|
3
|
+
# [IO](rdoc-ref:IO).
|
3
4
|
#
|
4
|
-
#
|
5
|
+
# ### About the Examples
|
5
6
|
#
|
6
|
-
#
|
7
|
+
# Examples on this page assume that StringIO has been required:
|
7
8
|
#
|
8
9
|
# require 'stringio'
|
9
10
|
#
|
10
|
-
# # Writing stream emulation
|
11
|
-
# io = StringIO.new
|
12
|
-
# io.puts "Hello World"
|
13
|
-
# io.string #=> "Hello World\n"
|
14
|
-
#
|
15
|
-
# # Reading stream emulation
|
16
|
-
# io = StringIO.new "first\nsecond\nlast\n"
|
17
|
-
# io.getc #=> "f"
|
18
|
-
# io.gets #=> "irst\n"
|
19
|
-
# io.read #=> "second\nlast\n"
|
20
|
-
#
|
21
11
|
class StringIO
|
22
12
|
# <!--
|
23
13
|
# rdoc-file=ext/stringio/stringio.c
|
24
|
-
# - StringIO.new(string=
|
14
|
+
# - StringIO.new(string = '', mode = 'r+') -> new_stringio
|
25
15
|
# -->
|
26
|
-
#
|
16
|
+
# Note that `mode` defaults to `'r'` if `string` is frozen.
|
17
|
+
#
|
18
|
+
# Returns a new StringIO instance formed from `string` and `mode`; see [Access
|
19
|
+
# Modes](rdoc-ref:File@Access+Modes):
|
20
|
+
#
|
21
|
+
# strio = StringIO.new # => #<StringIO>
|
22
|
+
# strio.close
|
23
|
+
#
|
24
|
+
# The instance should be closed when no longer needed.
|
25
|
+
#
|
26
|
+
# Related: StringIO.open (accepts block; closes automatically).
|
27
27
|
#
|
28
28
|
def initialize: (?String string, ?String? mode) -> void
|
29
29
|
|
30
30
|
# <!--
|
31
31
|
# rdoc-file=ext/stringio/stringio.c
|
32
|
-
# - StringIO.open(string=
|
32
|
+
# - StringIO.open(string = '', mode = 'r+') {|strio| ... }
|
33
33
|
# -->
|
34
|
-
#
|
35
|
-
#
|
36
|
-
#
|
34
|
+
# Note that `mode` defaults to `'r'` if `string` is frozen.
|
35
|
+
#
|
36
|
+
# Creates a new StringIO instance formed from `string` and `mode`; see [Access
|
37
|
+
# Modes](rdoc-ref:File@Access+Modes).
|
38
|
+
#
|
39
|
+
# With no block, returns the new instance:
|
40
|
+
#
|
41
|
+
# strio = StringIO.open # => #<StringIO>
|
42
|
+
#
|
43
|
+
# With a block, calls the block with the new instance and returns the block's
|
44
|
+
# value; closes the instance on block exit.
|
45
|
+
#
|
46
|
+
# StringIO.open {|strio| p strio }
|
47
|
+
# # => #<StringIO>
|
48
|
+
#
|
49
|
+
# Related: StringIO.new.
|
37
50
|
#
|
38
51
|
def self.open: [U] (?String string, ?String? mode) { (StringIO arg) -> U } -> U
|
39
52
|
|
@@ -41,116 +54,130 @@ class StringIO
|
|
41
54
|
|
42
55
|
# <!--
|
43
56
|
# rdoc-file=ext/stringio/stringio.c
|
44
|
-
# -
|
57
|
+
# - binmode -> self
|
45
58
|
# -->
|
46
|
-
#
|
59
|
+
# Sets the data mode in `self` to binary mode; see [Data
|
60
|
+
# Mode](rdoc-ref:File@Data+Mode).
|
47
61
|
#
|
48
62
|
def binmode: () -> self
|
49
63
|
|
50
64
|
# <!--
|
51
65
|
# rdoc-file=ext/stringio/stringio.c
|
52
|
-
# -
|
66
|
+
# - close -> nil
|
53
67
|
# -->
|
54
|
-
# Closes
|
55
|
-
#
|
68
|
+
# Closes `self` for both reading and writing.
|
69
|
+
#
|
70
|
+
# Raises IOError if reading or writing is attempted.
|
71
|
+
#
|
72
|
+
# Related: StringIO#close_read, StringIO#close_write.
|
56
73
|
#
|
57
74
|
def close: () -> nil
|
58
75
|
|
59
76
|
# <!--
|
60
77
|
# rdoc-file=ext/stringio/stringio.c
|
61
|
-
# -
|
78
|
+
# - close_read -> nil
|
62
79
|
# -->
|
63
|
-
# Closes
|
64
|
-
#
|
80
|
+
# Closes `self` for reading; closed-write setting remains unchanged.
|
81
|
+
#
|
82
|
+
# Raises IOError if reading is attempted.
|
83
|
+
#
|
84
|
+
# Related: StringIO#close, StringIO#close_write.
|
65
85
|
#
|
66
86
|
def close_read: () -> nil
|
67
87
|
|
68
88
|
# <!--
|
69
89
|
# rdoc-file=ext/stringio/stringio.c
|
70
|
-
# -
|
90
|
+
# - close_write -> nil
|
71
91
|
# -->
|
72
|
-
# Closes
|
73
|
-
#
|
92
|
+
# Closes `self` for writing; closed-read setting remains unchanged.
|
93
|
+
#
|
94
|
+
# Raises IOError if writing is attempted.
|
95
|
+
#
|
96
|
+
# Related: StringIO#close, StringIO#close_read.
|
74
97
|
#
|
75
98
|
def close_write: () -> nil
|
76
99
|
|
77
100
|
# <!--
|
78
101
|
# rdoc-file=ext/stringio/stringio.c
|
79
|
-
# -
|
102
|
+
# - closed? -> true or false
|
80
103
|
# -->
|
81
|
-
# Returns `true` if
|
104
|
+
# Returns `true` if `self` is closed for both reading and writing, `false`
|
105
|
+
# otherwise.
|
82
106
|
#
|
83
107
|
def closed?: () -> bool
|
84
108
|
|
85
109
|
# <!--
|
86
110
|
# rdoc-file=ext/stringio/stringio.c
|
87
|
-
# -
|
111
|
+
# - closed_read? -> true or false
|
88
112
|
# -->
|
89
|
-
# Returns `true` if
|
113
|
+
# Returns `true` if `self` is closed for reading, `false` otherwise.
|
90
114
|
#
|
91
115
|
def closed_read?: () -> bool
|
92
116
|
|
93
117
|
# <!--
|
94
118
|
# rdoc-file=ext/stringio/stringio.c
|
95
|
-
# -
|
119
|
+
# - closed_write? -> true or false
|
96
120
|
# -->
|
97
|
-
# Returns `true` if
|
121
|
+
# Returns `true` if `self` is closed for writing, `false` otherwise.
|
98
122
|
#
|
99
123
|
def closed_write?: () -> bool
|
100
124
|
|
101
125
|
# <!--
|
102
126
|
# rdoc-file=ext/stringio/stringio.c
|
103
|
-
# -
|
104
|
-
# -
|
105
|
-
# -
|
106
|
-
# - strio.each(...) -> anEnumerator
|
107
|
-
# - strio.each_line(sep=$/, chomp: false) {|line| block } -> strio
|
108
|
-
# - strio.each_line(limit, chomp: false) {|line| block } -> strio
|
109
|
-
# - strio.each_line(sep, limit, chomp: false) {|line| block } -> strio
|
110
|
-
# - strio.each_line(...) -> anEnumerator
|
127
|
+
# - each_line(sep = $/, chomp: false) {|line| ... } -> self
|
128
|
+
# - each_line(limit, chomp: false) {|line| ... } -> self
|
129
|
+
# - each_line(sep, limit, chomp: false) {|line| ... } -> self
|
111
130
|
# -->
|
112
|
-
#
|
131
|
+
# Calls the block with each remaining line read from the stream; does nothing if
|
132
|
+
# already at end-of-file; returns `self`. See [Line IO](rdoc-ref:IO@Line+IO).
|
113
133
|
#
|
114
134
|
def each: (?String sep, ?Integer limit, ?chomp: boolish) { (String) -> untyped } -> self
|
115
135
|
| (?String sep, ?Integer limit, ?chomp: boolish) -> ::Enumerator[String, self]
|
116
136
|
|
117
137
|
# <!--
|
118
138
|
# rdoc-file=ext/stringio/stringio.c
|
119
|
-
# -
|
120
|
-
# - strio.each_byte -> anEnumerator
|
139
|
+
# - each_byte {|byte| ... } -> self
|
121
140
|
# -->
|
122
|
-
#
|
141
|
+
# With a block given, calls the block with each remaining byte in the stream;
|
142
|
+
# see [Byte IO](rdoc-ref:IO@Byte+IO).
|
143
|
+
#
|
144
|
+
# With no block given, returns an enumerator.
|
123
145
|
#
|
124
146
|
def each_byte: () { (Integer arg0) -> untyped } -> self
|
125
147
|
| () -> ::Enumerator[Integer, self]
|
126
148
|
|
127
149
|
# <!--
|
128
150
|
# rdoc-file=ext/stringio/stringio.c
|
129
|
-
# -
|
130
|
-
# - strio.each_char -> anEnumerator
|
151
|
+
# - each_char {|c| ... } -> self
|
131
152
|
# -->
|
132
|
-
#
|
153
|
+
# With a block given, calls the block with each remaining character in the
|
154
|
+
# stream; see [Character IO](rdoc-ref:IO@Character+IO).
|
155
|
+
#
|
156
|
+
# With no block given, returns an enumerator.
|
133
157
|
#
|
134
158
|
def each_char: () { (String arg0) -> untyped } -> self
|
135
159
|
| () -> ::Enumerator[String, self]
|
136
160
|
|
137
161
|
# <!--
|
138
162
|
# rdoc-file=ext/stringio/stringio.c
|
139
|
-
# -
|
140
|
-
# - strio.each_codepoint -> anEnumerator
|
163
|
+
# - each_codepoint {|codepoint| ... } -> self
|
141
164
|
# -->
|
142
|
-
#
|
165
|
+
# With a block given, calls the block with each remaining codepoint in the
|
166
|
+
# stream; see [Codepoint IO](rdoc-ref:IO@Codepoint+IO).
|
167
|
+
#
|
168
|
+
# With no block given, returns an enumerator.
|
143
169
|
#
|
144
170
|
def each_codepoint: () { (Integer arg0) -> untyped } -> self
|
145
171
|
| () -> ::Enumerator[Integer, self]
|
146
172
|
|
147
173
|
# <!--
|
148
174
|
# rdoc-file=ext/stringio/stringio.c
|
149
|
-
# -
|
150
|
-
# - strio.eof? -> true or false
|
175
|
+
# - eof? -> true or false
|
151
176
|
# -->
|
152
|
-
# Returns true if
|
153
|
-
#
|
177
|
+
# Returns `true` if positioned at end-of-stream, `false` otherwise; see
|
178
|
+
# [Position](rdoc-ref:IO@Position).
|
179
|
+
#
|
180
|
+
# Raises IOError if the stream is not opened for reading.
|
154
181
|
#
|
155
182
|
def eof: () -> bool
|
156
183
|
|
@@ -188,27 +215,30 @@ class StringIO
|
|
188
215
|
|
189
216
|
# <!--
|
190
217
|
# rdoc-file=ext/stringio/stringio.c
|
191
|
-
# -
|
218
|
+
# - getbyte -> byte or nil
|
192
219
|
# -->
|
193
|
-
#
|
220
|
+
# Reads and returns the next 8-bit byte from the stream; see [Byte
|
221
|
+
# IO](rdoc-ref:IO@Byte+IO).
|
194
222
|
#
|
195
223
|
def getbyte: () -> Integer?
|
196
224
|
|
197
225
|
# <!--
|
198
226
|
# rdoc-file=ext/stringio/stringio.c
|
199
|
-
# -
|
227
|
+
# - getc -> character or nil
|
200
228
|
# -->
|
201
|
-
#
|
229
|
+
# Reads and returns the next character from the stream; see [Character
|
230
|
+
# IO](rdoc-ref:IO@Character+IO).
|
202
231
|
#
|
203
232
|
def getc: () -> String?
|
204
233
|
|
205
234
|
# <!--
|
206
235
|
# rdoc-file=ext/stringio/stringio.c
|
207
|
-
# -
|
208
|
-
# -
|
209
|
-
# -
|
236
|
+
# - gets(sep = $/, chomp: false) -> string or nil
|
237
|
+
# - gets(limit, chomp: false) -> string or nil
|
238
|
+
# - gets(sep, limit, chomp: false) -> string or nil
|
210
239
|
# -->
|
211
|
-
#
|
240
|
+
# Reads and returns a line from the stream; assigns the return value to `$_`;
|
241
|
+
# see [Line IO](rdoc-ref:IO@Line+IO).
|
212
242
|
#
|
213
243
|
def gets: (?String sep, ?Integer limit, ?chomp: boolish) -> String?
|
214
244
|
|
@@ -240,21 +270,19 @@ class StringIO
|
|
240
270
|
|
241
271
|
# <!--
|
242
272
|
# rdoc-file=ext/stringio/stringio.c
|
243
|
-
# -
|
273
|
+
# - lineno -> current_line_number
|
244
274
|
# -->
|
245
|
-
# Returns the current line number
|
246
|
-
#
|
247
|
-
# of newlines encountered. The two values will differ if `gets` is called with
|
248
|
-
# a separator other than newline. See also the `$.` variable.
|
275
|
+
# Returns the current line number in `self`; see [Line
|
276
|
+
# Number](rdoc-ref:IO@Line+Number).
|
249
277
|
#
|
250
278
|
def lineno: () -> Integer
|
251
279
|
|
252
280
|
# <!--
|
253
281
|
# rdoc-file=ext/stringio/stringio.c
|
254
|
-
# -
|
282
|
+
# - lineno = new_line_number -> new_line_number
|
255
283
|
# -->
|
256
|
-
#
|
257
|
-
#
|
284
|
+
# Sets the current line number in `self` to the given `new_line_number`; see
|
285
|
+
# [Line Number](rdoc-ref:IO@Line+Number).
|
258
286
|
#
|
259
287
|
def lineno=: (Integer arg0) -> Integer
|
260
288
|
|
@@ -268,18 +296,17 @@ class StringIO
|
|
268
296
|
|
269
297
|
# <!--
|
270
298
|
# rdoc-file=ext/stringio/stringio.c
|
271
|
-
# -
|
272
|
-
# - strio.tell -> integer
|
299
|
+
# - pos -> stream_position
|
273
300
|
# -->
|
274
|
-
# Returns the current
|
301
|
+
# Returns the current position (in bytes); see [Position](rdoc-ref:IO@Position).
|
275
302
|
#
|
276
303
|
def pos: () -> Integer
|
277
304
|
|
278
305
|
# <!--
|
279
306
|
# rdoc-file=ext/stringio/stringio.c
|
280
|
-
# -
|
307
|
+
# - pos = new_position -> new_position
|
281
308
|
# -->
|
282
|
-
#
|
309
|
+
# Sets the current position (in bytes); see [Position](rdoc-ref:IO@Position).
|
283
310
|
#
|
284
311
|
def pos=: (Integer arg0) -> Integer
|
285
312
|
|
@@ -327,29 +354,45 @@ class StringIO
|
|
327
354
|
|
328
355
|
# <!--
|
329
356
|
# rdoc-file=ext/stringio/stringio.c
|
330
|
-
# -
|
331
|
-
# - strio.reopen(string, mode) -> strio
|
357
|
+
# - reopen(other, mode = 'r+') -> self
|
332
358
|
# -->
|
333
|
-
# Reinitializes the stream with the given
|
334
|
-
#
|
359
|
+
# Reinitializes the stream with the given `other` (string or StringIO) and
|
360
|
+
# `mode`; see IO.new:
|
361
|
+
#
|
362
|
+
# StringIO.open('foo') do |strio|
|
363
|
+
# p strio.string
|
364
|
+
# strio.reopen('bar')
|
365
|
+
# p strio.string
|
366
|
+
# other_strio = StringIO.new('baz')
|
367
|
+
# strio.reopen(other_strio)
|
368
|
+
# p strio.string
|
369
|
+
# other_strio.close
|
370
|
+
# end
|
371
|
+
#
|
372
|
+
# Output:
|
373
|
+
#
|
374
|
+
# "foo"
|
375
|
+
# "bar"
|
376
|
+
# "baz"
|
335
377
|
#
|
336
378
|
def reopen: (StringIO other) -> self
|
337
379
|
| (String other, ?String mode_str) -> self
|
338
380
|
|
339
381
|
# <!--
|
340
382
|
# rdoc-file=ext/stringio/stringio.c
|
341
|
-
# -
|
383
|
+
# - rewind -> 0
|
342
384
|
# -->
|
343
|
-
#
|
385
|
+
# Sets the current position and line number to zero; see
|
386
|
+
# [Position](rdoc-ref:IO@Position) and [Line Number](rdoc-ref:IO@Line+Number).
|
344
387
|
#
|
345
388
|
def rewind: () -> Integer
|
346
389
|
|
347
390
|
# <!--
|
348
391
|
# rdoc-file=ext/stringio/stringio.c
|
349
|
-
# -
|
392
|
+
# - seek(offset, whence = SEEK_SET) -> 0
|
350
393
|
# -->
|
351
|
-
#
|
352
|
-
#
|
394
|
+
# Sets the current position to the given integer `offset` (in bytes), with
|
395
|
+
# respect to a given constant `whence`; see [Position](rdoc-ref:IO@Position).
|
353
396
|
#
|
354
397
|
def seek: (Integer amount, ?Integer whence) -> Integer
|
355
398
|
|
@@ -366,17 +409,44 @@ class StringIO
|
|
366
409
|
|
367
410
|
# <!--
|
368
411
|
# rdoc-file=ext/stringio/stringio.c
|
369
|
-
# -
|
412
|
+
# - string -> string
|
370
413
|
# -->
|
371
|
-
# Returns underlying
|
414
|
+
# Returns underlying string:
|
415
|
+
#
|
416
|
+
# StringIO.open('foo') do |strio|
|
417
|
+
# p strio.string
|
418
|
+
# strio.string = 'bar'
|
419
|
+
# p strio.string
|
420
|
+
# end
|
421
|
+
#
|
422
|
+
# Output:
|
423
|
+
#
|
424
|
+
# "foo"
|
425
|
+
# "bar"
|
426
|
+
#
|
427
|
+
# Related: StringIO#string= (assigns the underlying string).
|
372
428
|
#
|
373
429
|
def string: () -> String
|
374
430
|
|
375
431
|
# <!--
|
376
432
|
# rdoc-file=ext/stringio/stringio.c
|
377
|
-
# -
|
433
|
+
# - string = other_string -> other_string
|
378
434
|
# -->
|
379
|
-
#
|
435
|
+
# Assigns the underlying string as `other_string`, and sets position to zero;
|
436
|
+
# returns `other_string`:
|
437
|
+
#
|
438
|
+
# StringIO.open('foo') do |strio|
|
439
|
+
# p strio.string
|
440
|
+
# strio.string = 'bar'
|
441
|
+
# p strio.string
|
442
|
+
# end
|
443
|
+
#
|
444
|
+
# Output:
|
445
|
+
#
|
446
|
+
# "foo"
|
447
|
+
# "bar"
|
448
|
+
#
|
449
|
+
# Related: StringIO#string (returns the underlying string).
|
380
450
|
#
|
381
451
|
def string=: (String str) -> String
|
382
452
|
|
@@ -391,9 +461,9 @@ class StringIO
|
|
391
461
|
|
392
462
|
# <!--
|
393
463
|
# rdoc-file=ext/stringio/stringio.c
|
394
|
-
# -
|
464
|
+
# - sync -> true
|
395
465
|
# -->
|
396
|
-
# Returns `true
|
466
|
+
# Returns `true`; implemented only for compatibility with other stream classes.
|
397
467
|
#
|
398
468
|
def sync: () -> bool
|
399
469
|
|
@@ -411,13 +481,21 @@ class StringIO
|
|
411
481
|
|
412
482
|
# <!--
|
413
483
|
# rdoc-file=ext/stringio/stringio.c
|
414
|
-
# -
|
415
|
-
# - strio.tell -> integer
|
484
|
+
# - pos -> stream_position
|
416
485
|
# -->
|
417
|
-
# Returns the current
|
486
|
+
# Returns the current position (in bytes); see [Position](rdoc-ref:IO@Position).
|
418
487
|
#
|
419
488
|
def tell: () -> Integer
|
420
489
|
|
490
|
+
# <!--
|
491
|
+
# rdoc-file=ext/stringio/stringio.c
|
492
|
+
# - strio.truncate(integer) -> 0
|
493
|
+
# -->
|
494
|
+
# Truncates the buffer string to at most *integer* bytes. The stream must be
|
495
|
+
# opened for writing.
|
496
|
+
#
|
497
|
+
def truncate: (Integer) -> 0
|
498
|
+
|
421
499
|
# <!-- rdoc-file=ext/stringio/stringio.c -->
|
422
500
|
# Returns `false`. Just for compatibility to IO.
|
423
501
|
#
|
@@ -425,19 +503,19 @@ class StringIO
|
|
425
503
|
|
426
504
|
# <!--
|
427
505
|
# rdoc-file=ext/stringio/stringio.c
|
428
|
-
# -
|
506
|
+
# - ungetbyte(byte) -> nil
|
429
507
|
# -->
|
430
|
-
#
|
508
|
+
# Pushes back ("unshifts") an 8-bit byte onto the stream; see [Byte
|
509
|
+
# IO](rdoc-ref:IO@Byte+IO).
|
431
510
|
#
|
432
511
|
def ungetbyte: (String | Integer arg0) -> nil
|
433
512
|
|
434
513
|
# <!--
|
435
514
|
# rdoc-file=ext/stringio/stringio.c
|
436
|
-
# -
|
515
|
+
# - ungetc(character) -> nil
|
437
516
|
# -->
|
438
|
-
# Pushes back
|
439
|
-
#
|
440
|
-
# including pushing back behind the beginning of the buffer string.
|
517
|
+
# Pushes back ("unshifts") a character or integer onto the stream; see
|
518
|
+
# [Character IO](rdoc-ref:IO@Character+IO).
|
441
519
|
#
|
442
520
|
def ungetc: (String arg0) -> nil
|
443
521
|
|
@@ -468,14 +546,17 @@ class StringIO
|
|
468
546
|
| () -> ::Enumerator[Integer, self]
|
469
547
|
|
470
548
|
# <!-- rdoc-file=ext/stringio/stringio.c -->
|
471
|
-
#
|
549
|
+
# Calls the block with each remaining line read from the stream; does nothing if
|
550
|
+
# already at end-of-file; returns `self`. See [Line IO](rdoc-ref:IO@Line+IO).
|
472
551
|
#
|
473
552
|
def each_line: (?String sep, ?Integer limit, ?chomp: boolish) { (String) -> untyped } -> self
|
474
553
|
| (?String sep, ?Integer limit, ?chomp: boolish) -> ::Enumerator[String, self]
|
475
554
|
|
476
555
|
# <!-- rdoc-file=ext/stringio/stringio.c -->
|
477
|
-
# Returns true if
|
478
|
-
#
|
556
|
+
# Returns `true` if positioned at end-of-stream, `false` otherwise; see
|
557
|
+
# [Position](rdoc-ref:IO@Position).
|
558
|
+
#
|
559
|
+
# Raises IOError if the stream is not opened for reading.
|
479
560
|
#
|
480
561
|
def eof?: () -> bool
|
481
562
|
|