rbs 4.0.0.dev.4 → 4.0.0
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 +4 -4
- data/.github/dependabot.yml +14 -14
- data/.github/workflows/bundle-update.yml +60 -0
- data/.github/workflows/c-check.yml +18 -11
- data/.github/workflows/comments.yml +5 -3
- data/.github/workflows/dependabot.yml +2 -2
- data/.github/workflows/ruby.yml +27 -34
- data/.github/workflows/rust.yml +95 -0
- data/.github/workflows/typecheck.yml +2 -2
- data/.github/workflows/windows.yml +2 -2
- data/.rubocop.yml +1 -1
- data/CHANGELOG.md +323 -0
- data/README.md +1 -1
- data/Rakefile +43 -33
- data/Steepfile +1 -0
- data/config.yml +426 -24
- data/core/array.rbs +307 -227
- data/core/basic_object.rbs +9 -8
- data/core/binding.rbs +0 -2
- data/core/builtin.rbs +2 -2
- data/core/class.rbs +6 -5
- data/core/comparable.rbs +55 -34
- data/core/complex.rbs +104 -78
- data/core/dir.rbs +61 -49
- data/core/encoding.rbs +12 -15
- data/core/enumerable.rbs +179 -87
- data/core/enumerator/arithmetic_sequence.rbs +70 -0
- data/core/enumerator.rbs +65 -2
- data/core/errno.rbs +11 -2
- data/core/errors.rbs +58 -29
- data/core/exception.rbs +13 -13
- data/core/fiber.rbs +74 -54
- data/core/file.rbs +280 -177
- data/core/file_test.rbs +3 -3
- data/core/float.rbs +257 -92
- data/core/gc.rbs +425 -281
- data/core/hash.rbs +1045 -739
- data/core/integer.rbs +135 -137
- data/core/io/buffer.rbs +53 -42
- data/core/io/wait.rbs +13 -35
- data/core/io.rbs +192 -144
- data/core/kernel.rbs +216 -155
- data/core/marshal.rbs +4 -4
- data/core/match_data.rbs +15 -13
- data/core/math.rbs +107 -66
- data/core/method.rbs +69 -33
- data/core/module.rbs +244 -106
- data/core/nil_class.rbs +7 -6
- data/core/numeric.rbs +74 -63
- data/core/object.rbs +9 -11
- data/core/object_space.rbs +30 -23
- data/core/pathname.rbs +1322 -0
- data/core/proc.rbs +95 -58
- data/core/process.rbs +222 -202
- data/core/ractor.rbs +371 -515
- data/core/random.rbs +21 -3
- data/core/range.rbs +159 -57
- data/core/rational.rbs +60 -89
- data/core/rbs/unnamed/argf.rbs +60 -53
- data/core/rbs/unnamed/env_class.rbs +19 -14
- data/core/rbs/unnamed/main_class.rbs +123 -0
- data/core/rbs/unnamed/random.rbs +11 -118
- data/core/regexp.rbs +258 -214
- data/core/ruby.rbs +53 -0
- data/core/ruby_vm.rbs +38 -34
- data/core/rubygems/config_file.rbs +5 -5
- data/core/rubygems/errors.rbs +4 -71
- data/core/rubygems/requirement.rbs +5 -5
- data/core/rubygems/rubygems.rbs +16 -82
- data/core/rubygems/version.rbs +2 -3
- data/core/set.rbs +490 -360
- data/core/signal.rbs +26 -16
- data/core/string.rbs +3234 -1285
- data/core/struct.rbs +27 -26
- data/core/symbol.rbs +41 -34
- data/core/thread.rbs +135 -67
- data/core/time.rbs +81 -50
- data/core/trace_point.rbs +41 -35
- data/core/true_class.rbs +2 -2
- data/core/unbound_method.rbs +24 -16
- data/core/warning.rbs +7 -7
- data/docs/aliases.md +79 -0
- data/docs/collection.md +3 -3
- data/docs/config.md +171 -0
- data/docs/encoding.md +56 -0
- data/docs/gem.md +0 -1
- data/docs/inline.md +576 -0
- data/docs/sigs.md +3 -3
- data/docs/syntax.md +46 -16
- data/docs/type_fingerprint.md +21 -0
- data/exe/rbs +1 -1
- data/ext/rbs_extension/ast_translation.c +544 -116
- data/ext/rbs_extension/ast_translation.h +3 -0
- data/ext/rbs_extension/class_constants.c +16 -2
- data/ext/rbs_extension/class_constants.h +8 -0
- data/ext/rbs_extension/extconf.rb +5 -1
- data/ext/rbs_extension/legacy_location.c +33 -56
- data/ext/rbs_extension/legacy_location.h +37 -0
- data/ext/rbs_extension/main.c +44 -35
- data/include/rbs/ast.h +448 -173
- data/include/rbs/defines.h +27 -0
- data/include/rbs/lexer.h +30 -11
- data/include/rbs/location.h +25 -44
- data/include/rbs/parser.h +6 -6
- data/include/rbs/string.h +0 -2
- data/include/rbs/util/rbs_allocator.h +34 -13
- data/include/rbs/util/rbs_assert.h +12 -1
- data/include/rbs/util/rbs_constant_pool.h +0 -3
- data/include/rbs/util/rbs_encoding.h +2 -0
- data/include/rbs/util/rbs_unescape.h +2 -1
- data/include/rbs.h +8 -0
- data/lib/rbs/ast/annotation.rb +1 -1
- data/lib/rbs/ast/comment.rb +1 -1
- data/lib/rbs/ast/declarations.rb +10 -10
- data/lib/rbs/ast/members.rb +14 -14
- data/lib/rbs/ast/ruby/annotations.rb +293 -3
- data/lib/rbs/ast/ruby/comment_block.rb +24 -0
- data/lib/rbs/ast/ruby/declarations.rb +198 -3
- data/lib/rbs/ast/ruby/helpers/constant_helper.rb +4 -0
- data/lib/rbs/ast/ruby/members.rb +532 -22
- data/lib/rbs/ast/type_param.rb +24 -4
- data/lib/rbs/buffer.rb +20 -15
- data/lib/rbs/cli/diff.rb +16 -15
- data/lib/rbs/cli/validate.rb +38 -106
- data/lib/rbs/cli.rb +52 -19
- data/lib/rbs/collection/config/lockfile_generator.rb +14 -2
- data/lib/rbs/collection/sources/git.rb +1 -0
- data/lib/rbs/definition.rb +1 -1
- data/lib/rbs/definition_builder/ancestor_builder.rb +62 -9
- data/lib/rbs/definition_builder/method_builder.rb +20 -0
- data/lib/rbs/definition_builder.rb +147 -25
- data/lib/rbs/diff.rb +7 -1
- data/lib/rbs/environment.rb +227 -74
- data/lib/rbs/environment_loader.rb +0 -6
- data/lib/rbs/errors.rb +27 -18
- data/lib/rbs/inline_parser.rb +342 -6
- data/lib/rbs/location_aux.rb +1 -1
- data/lib/rbs/locator.rb +5 -1
- data/lib/rbs/method_type.rb +5 -3
- data/lib/rbs/parser_aux.rb +20 -7
- data/lib/rbs/prototype/helpers.rb +57 -0
- data/lib/rbs/prototype/rb.rb +3 -28
- data/lib/rbs/prototype/rbi.rb +3 -20
- data/lib/rbs/prototype/runtime.rb +8 -0
- data/lib/rbs/resolver/constant_resolver.rb +2 -2
- data/lib/rbs/resolver/type_name_resolver.rb +116 -38
- data/lib/rbs/subtractor.rb +3 -1
- data/lib/rbs/test/type_check.rb +19 -2
- data/lib/rbs/type_name.rb +1 -1
- data/lib/rbs/types.rb +88 -78
- data/lib/rbs/unit_test/type_assertions.rb +35 -8
- data/lib/rbs/validator.rb +2 -2
- data/lib/rbs/version.rb +1 -1
- data/lib/rbs.rb +1 -2
- data/lib/rdoc/discover.rb +1 -1
- data/lib/rdoc_plugin/parser.rb +1 -1
- data/rbs.gemspec +4 -3
- data/rust/.gitignore +1 -0
- data/rust/Cargo.lock +378 -0
- data/rust/Cargo.toml +7 -0
- data/rust/ruby-rbs/Cargo.toml +22 -0
- data/rust/ruby-rbs/build.rs +764 -0
- data/rust/ruby-rbs/examples/locations.rs +60 -0
- data/rust/ruby-rbs/src/lib.rs +1 -0
- data/rust/ruby-rbs/src/node/mod.rs +742 -0
- data/rust/ruby-rbs/tests/sanity.rs +47 -0
- data/rust/ruby-rbs/vendor/rbs/config.yml +1 -0
- data/rust/ruby-rbs-sys/Cargo.toml +23 -0
- data/rust/ruby-rbs-sys/build.rs +204 -0
- data/rust/ruby-rbs-sys/src/lib.rs +50 -0
- data/rust/ruby-rbs-sys/vendor/rbs/include +1 -0
- data/rust/ruby-rbs-sys/vendor/rbs/src +1 -0
- data/rust/ruby-rbs-sys/wrapper.h +1 -0
- data/schema/typeParam.json +17 -1
- data/sig/ast/ruby/annotations.rbs +315 -4
- data/sig/ast/ruby/comment_block.rbs +8 -0
- data/sig/ast/ruby/declarations.rbs +102 -4
- data/sig/ast/ruby/members.rbs +108 -2
- data/sig/cli/diff.rbs +5 -11
- data/sig/cli/validate.rbs +12 -8
- data/sig/cli.rbs +18 -18
- data/sig/definition.rbs +6 -1
- data/sig/definition_builder.rbs +2 -0
- data/sig/environment.rbs +70 -12
- data/sig/errors.rbs +13 -14
- data/sig/inline_parser.rbs +39 -2
- data/sig/locator.rbs +0 -2
- data/sig/manifest.yaml +0 -1
- data/sig/method_builder.rbs +3 -1
- data/sig/parser.rbs +31 -13
- data/sig/prototype/helpers.rbs +2 -0
- data/sig/resolver/type_name_resolver.rbs +35 -7
- data/sig/source.rbs +3 -3
- data/sig/type_param.rbs +13 -8
- data/sig/types.rbs +6 -7
- data/sig/unit_test/spy.rbs +0 -8
- data/sig/unit_test/type_assertions.rbs +11 -0
- data/src/ast.c +410 -153
- data/src/lexer.c +1392 -1313
- data/src/lexer.re +3 -0
- data/src/lexstate.c +58 -37
- data/src/location.c +8 -48
- data/src/parser.c +977 -516
- data/src/string.c +0 -48
- data/src/util/rbs_allocator.c +89 -71
- data/src/util/rbs_assert.c +1 -1
- data/src/util/rbs_buffer.c +2 -2
- data/src/util/rbs_constant_pool.c +10 -14
- data/src/util/rbs_encoding.c +4 -8
- data/src/util/rbs_unescape.c +56 -20
- data/stdlib/bigdecimal/0/big_decimal.rbs +116 -98
- data/stdlib/bigdecimal-math/0/big_math.rbs +169 -8
- data/stdlib/cgi/0/core.rbs +9 -393
- data/stdlib/cgi/0/manifest.yaml +1 -0
- data/stdlib/cgi-escape/0/escape.rbs +171 -0
- data/stdlib/coverage/0/coverage.rbs +7 -4
- data/stdlib/date/0/date.rbs +92 -79
- data/stdlib/date/0/date_time.rbs +25 -24
- data/stdlib/delegate/0/delegator.rbs +10 -7
- data/stdlib/did_you_mean/0/did_you_mean.rbs +17 -16
- data/stdlib/digest/0/digest.rbs +110 -0
- data/stdlib/erb/0/erb.rbs +748 -347
- data/stdlib/etc/0/etc.rbs +55 -50
- data/stdlib/fileutils/0/fileutils.rbs +158 -139
- data/stdlib/forwardable/0/forwardable.rbs +13 -10
- data/stdlib/io-console/0/io-console.rbs +2 -2
- data/stdlib/json/0/json.rbs +217 -136
- data/stdlib/monitor/0/monitor.rbs +3 -3
- data/stdlib/net-http/0/net-http.rbs +162 -134
- data/stdlib/objspace/0/objspace.rbs +17 -34
- data/stdlib/open-uri/0/open-uri.rbs +48 -8
- data/stdlib/open3/0/open3.rbs +469 -10
- data/stdlib/openssl/0/openssl.rbs +475 -357
- data/stdlib/optparse/0/optparse.rbs +26 -17
- data/stdlib/pathname/0/pathname.rbs +11 -1381
- data/stdlib/pp/0/pp.rbs +9 -8
- data/stdlib/prettyprint/0/prettyprint.rbs +7 -7
- data/stdlib/pstore/0/pstore.rbs +35 -30
- data/stdlib/psych/0/psych.rbs +65 -12
- data/stdlib/psych/0/store.rbs +2 -4
- data/stdlib/pty/0/pty.rbs +9 -6
- data/stdlib/random-formatter/0/random-formatter.rbs +277 -0
- data/stdlib/rdoc/0/code_object.rbs +2 -1
- data/stdlib/rdoc/0/parser.rbs +1 -1
- data/stdlib/rdoc/0/rdoc.rbs +1 -1
- data/stdlib/rdoc/0/store.rbs +1 -1
- data/stdlib/resolv/0/resolv.rbs +25 -68
- data/stdlib/ripper/0/ripper.rbs +22 -19
- data/stdlib/securerandom/0/manifest.yaml +2 -0
- data/stdlib/securerandom/0/securerandom.rbs +7 -20
- data/stdlib/shellwords/0/shellwords.rbs +2 -2
- data/stdlib/singleton/0/singleton.rbs +3 -0
- data/stdlib/socket/0/addrinfo.rbs +7 -7
- data/stdlib/socket/0/basic_socket.rbs +3 -3
- data/stdlib/socket/0/ip_socket.rbs +10 -8
- data/stdlib/socket/0/socket.rbs +23 -10
- data/stdlib/socket/0/tcp_server.rbs +1 -1
- data/stdlib/socket/0/tcp_socket.rbs +11 -3
- data/stdlib/socket/0/udp_socket.rbs +1 -1
- data/stdlib/socket/0/unix_server.rbs +1 -1
- data/stdlib/stringio/0/stringio.rbs +1177 -85
- data/stdlib/strscan/0/string_scanner.rbs +27 -25
- data/stdlib/tempfile/0/tempfile.rbs +25 -21
- data/stdlib/time/0/time.rbs +8 -6
- data/stdlib/timeout/0/timeout.rbs +63 -7
- data/stdlib/tsort/0/cyclic.rbs +3 -0
- data/stdlib/tsort/0/tsort.rbs +7 -6
- data/stdlib/uri/0/common.rbs +42 -20
- data/stdlib/uri/0/file.rbs +3 -3
- data/stdlib/uri/0/generic.rbs +26 -18
- data/stdlib/uri/0/http.rbs +2 -2
- data/stdlib/uri/0/ldap.rbs +2 -2
- data/stdlib/uri/0/mailto.rbs +3 -3
- data/stdlib/uri/0/rfc2396_parser.rbs +12 -12
- data/stdlib/zlib/0/deflate.rbs +4 -3
- data/stdlib/zlib/0/gzip_reader.rbs +6 -6
- data/stdlib/zlib/0/gzip_writer.rbs +14 -12
- data/stdlib/zlib/0/inflate.rbs +1 -1
- data/stdlib/zlib/0/need_dict.rbs +1 -1
- data/stdlib/zlib/0/zstream.rbs +1 -0
- metadata +50 -6
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
# <!-- rdoc-file=ext/strscan/strscan.c -->
|
|
2
2
|
# Class `StringScanner` supports processing a stored string as a stream;
|
|
3
|
-
# this code creates a new `StringScanner` object with string
|
|
3
|
+
# this code creates a new `StringScanner` object with string
|
|
4
|
+
# <code>'foobarbaz'</code>:
|
|
4
5
|
# require 'strscan'
|
|
5
6
|
# scanner = StringScanner.new('foobarbaz')
|
|
6
7
|
#
|
|
@@ -19,16 +20,16 @@
|
|
|
19
20
|
# ENGLISH_TEXT = 'Hello'
|
|
20
21
|
#
|
|
21
22
|
# Some examples here assume that certain helper methods are defined:
|
|
22
|
-
# *
|
|
23
|
+
# * <code>put_situation(scanner)</code>:
|
|
23
24
|
# Displays the values of the scanner's
|
|
24
25
|
# methods #pos, #charpos, #rest, and #rest_size.
|
|
25
|
-
# *
|
|
26
|
+
# * <code>put_match_values(scanner)</code>:
|
|
26
27
|
# Displays the scanner's [match
|
|
27
28
|
# values](rdoc-ref:StringScanner@Match+Values).
|
|
28
|
-
# *
|
|
29
|
+
# * <code>match_values_cleared?(scanner)</code>:
|
|
29
30
|
# Returns whether the scanner's [match
|
|
30
31
|
# values](rdoc-ref:StringScanner@Match+Values) are cleared.
|
|
31
|
-
# See examples [
|
|
32
|
+
# See examples at [helper methods](helper_methods.md).
|
|
32
33
|
# ## The `StringScanner` Object
|
|
33
34
|
# This code creates a `StringScanner` object
|
|
34
35
|
# (we'll call it simply a *scanner*),
|
|
@@ -45,7 +46,7 @@
|
|
|
45
46
|
# The scanner has:
|
|
46
47
|
# * A *stored string*, which is:
|
|
47
48
|
# * Initially set by StringScanner.new(string) to the given `string`
|
|
48
|
-
# (
|
|
49
|
+
# (<code>'foobarbaz'</code> in the example above).
|
|
49
50
|
# * Modifiable by methods #string=(new_string) and #concat(more_string).
|
|
50
51
|
# * Returned by method #string.
|
|
51
52
|
# More at [Stored String](rdoc-ref:StringScanner@Stored+String) below.
|
|
@@ -63,7 +64,7 @@
|
|
|
63
64
|
# which is a trailing substring of the stored string;
|
|
64
65
|
# it extends from the current position to the end of the stored string:
|
|
65
66
|
# * Initially set by StringScanner.new(string) to the given `string`
|
|
66
|
-
# (
|
|
67
|
+
# (<code>'foobarbaz'</code> in the example above).
|
|
67
68
|
# * Returned by method #rest.
|
|
68
69
|
# * Modified by any modification to either the stored string or the
|
|
69
70
|
# position.
|
|
@@ -85,10 +86,10 @@
|
|
|
85
86
|
# and a zero-based *character position*.
|
|
86
87
|
# Each of these methods explicitly sets positions:
|
|
87
88
|
# Method | Effect
|
|
88
|
-
#
|
|
89
|
-
# #reset |Sets both positions to zero (
|
|
89
|
+
# ------------------------|---------------------------------------------------------
|
|
90
|
+
# #reset |Sets both positions to zero (beginning of stored string).
|
|
90
91
|
# #terminate | Sets both positions to the end of the stored string.
|
|
91
|
-
# #pos=(new_byte_position)|
|
|
92
|
+
# #pos=(new_byte_position)| Sets byte position; adjusts character position.
|
|
92
93
|
# ### Byte Position (Position)
|
|
93
94
|
# The byte position (or simply *position*)
|
|
94
95
|
# is a zero-based index into the bytes in the scanner's stored string;
|
|
@@ -96,7 +97,7 @@
|
|
|
96
97
|
# When the byte position is:
|
|
97
98
|
# * Zero (at the beginning), the target substring is the entire stored string.
|
|
98
99
|
# * Equal to the size of the stored string (at the end),
|
|
99
|
-
# the target substring is the empty string
|
|
100
|
+
# the target substring is the empty string <code>''</code>.
|
|
100
101
|
# To get or set the byte position:
|
|
101
102
|
# * #pos: returns the byte position.
|
|
102
103
|
# * #pos=(new_pos): sets the byte position.
|
|
@@ -120,7 +121,7 @@
|
|
|
120
121
|
# * #charpos: the [character
|
|
121
122
|
# position](rdoc-ref:StringScanner@Character+Position).
|
|
122
123
|
# * #rest: the [target substring](rdoc-ref:StringScanner@Target+Substring).
|
|
123
|
-
# * #rest_size:
|
|
124
|
+
# * #rest_size: <code>rest.size</code>.
|
|
124
125
|
# ### Character Position
|
|
125
126
|
# The character position is a zero-based index into the *characters*
|
|
126
127
|
# in the stored string;
|
|
@@ -159,7 +160,7 @@
|
|
|
159
160
|
# # rest_size: 12
|
|
160
161
|
#
|
|
161
162
|
# ## Target Substring
|
|
162
|
-
# The target substring is the
|
|
163
|
+
# The target substring is the part of the [stored
|
|
163
164
|
# string](rdoc-ref:StringScanner@Stored+String)
|
|
164
165
|
# that extends from the current [byte
|
|
165
166
|
# position](rdoc-ref:StringScanner@Byte+Position+-28Position-29) to the end of
|
|
@@ -290,7 +291,7 @@
|
|
|
290
291
|
# generally contain the results of the most recent attempted match.
|
|
291
292
|
# Each match value may be thought of as:
|
|
292
293
|
# * *Clear*: Initially, or after an unsuccessful match attempt:
|
|
293
|
-
# usually, `false`, `nil`, or
|
|
294
|
+
# usually, `false`, `nil`, or <code>{}</code>.
|
|
294
295
|
# * *Set*: After a successful match attempt:
|
|
295
296
|
# `true`, string, array, or hash.
|
|
296
297
|
# Each of these methods clears match values:
|
|
@@ -327,10 +328,10 @@
|
|
|
327
328
|
# Method | Return After Match |Return After No Match
|
|
328
329
|
# ---------------|---------------------------------------|---------------------
|
|
329
330
|
# #size | Count of captured substrings. | +nil+.
|
|
330
|
-
# #[](n) |
|
|
331
|
+
# #[](n) | `n`th captured substring. | +nil+.
|
|
331
332
|
# #captures | Array of all captured substrings. | +nil+.
|
|
332
333
|
# #values_at(*n) |Array of specified captured substrings.| +nil+.
|
|
333
|
-
# #named_captures| Hash of named captures. |
|
|
334
|
+
# #named_captures| Hash of named captures. | <code>{}</code>.
|
|
334
335
|
#
|
|
335
336
|
# See examples below.
|
|
336
337
|
# #### Match Values Examples
|
|
@@ -401,7 +402,7 @@
|
|
|
401
402
|
# ## Fixed-Anchor Property
|
|
402
403
|
# Pattern matching in `StringScanner` is the same as in Ruby's,
|
|
403
404
|
# except for its fixed-anchor property,
|
|
404
|
-
# which determines the meaning of
|
|
405
|
+
# which determines the meaning of <code>'\A'</code>:
|
|
405
406
|
# * `false` (the default): matches the current byte position.
|
|
406
407
|
# scanner = StringScanner.new('foobar')
|
|
407
408
|
# scanner.scan(/\A./) # => "f"
|
|
@@ -486,13 +487,13 @@ class StringScanner
|
|
|
486
487
|
# scanner[:day] # => "12"
|
|
487
488
|
# scanner[:nope] # => nil
|
|
488
489
|
#
|
|
489
|
-
# When there are no captures, only
|
|
490
|
+
# When there are no captures, only <code>[0]</code> returns non-`nil`:
|
|
490
491
|
# scanner = StringScanner.new('foobarbaz')
|
|
491
492
|
# scanner.exist?(/bar/)
|
|
492
493
|
# scanner[0] # => "bar"
|
|
493
494
|
# scanner[1] # => nil
|
|
494
495
|
#
|
|
495
|
-
# For a failed match, even
|
|
496
|
+
# For a failed match, even <code>[0]</code> returns `nil`:
|
|
496
497
|
# scanner.scan(/nope/) # => nil
|
|
497
498
|
# scanner[0] # => nil
|
|
498
499
|
# scanner[1] # => nil
|
|
@@ -539,7 +540,8 @@ class StringScanner
|
|
|
539
540
|
# - captures -> substring_array or nil
|
|
540
541
|
# -->
|
|
541
542
|
# Returns the array of [captured match
|
|
542
|
-
# values](rdoc-ref:StringScanner@Captured+Match+Values) at indexes
|
|
543
|
+
# values](rdoc-ref:StringScanner@Captured+Match+Values) at indexes
|
|
544
|
+
# <code>(1..)</code>
|
|
543
545
|
# if the most recent match attempt succeeded, or `nil` otherwise:
|
|
544
546
|
# scanner = StringScanner.new('Fri Dec 12 1975 14:39')
|
|
545
547
|
# scanner.captures # => nil
|
|
@@ -999,7 +1001,7 @@ class StringScanner
|
|
|
999
1001
|
# rdoc-file=ext/strscan/strscan.c
|
|
1000
1002
|
# - peek(length) -> substring
|
|
1001
1003
|
# -->
|
|
1002
|
-
# Returns the substring
|
|
1004
|
+
# Returns the substring <code>string[pos, length]</code>;
|
|
1003
1005
|
# does not update [match values](rdoc-ref:StringScanner@Match+Values) or
|
|
1004
1006
|
# [positions](rdoc-ref:StringScanner@Positions):
|
|
1005
1007
|
# scanner = StringScanner.new('foobarbaz')
|
|
@@ -1151,7 +1153,7 @@ class StringScanner
|
|
|
1151
1153
|
# Sets both [byte position](rdoc-ref:StringScanner@Byte+Position+-28Position-29)
|
|
1152
1154
|
# and [character position](rdoc-ref:StringScanner@Character+Position) to zero,
|
|
1153
1155
|
# and clears [match values](rdoc-ref:StringScanner@Match+Values);
|
|
1154
|
-
# returns
|
|
1156
|
+
# returns +self+:
|
|
1155
1157
|
# scanner = StringScanner.new('foobarbaz')
|
|
1156
1158
|
# scanner.exist?(/bar/) # => 6
|
|
1157
1159
|
# scanner.reset # => #<StringScanner 0/9 @ "fooba...">
|
|
@@ -1237,7 +1239,7 @@ class StringScanner
|
|
|
1237
1239
|
# * Returns the matched substring.
|
|
1238
1240
|
# * Increments the [byte
|
|
1239
1241
|
# position](rdoc-ref:StringScanner@Byte+Position+-28Position-29) by
|
|
1240
|
-
#
|
|
1242
|
+
# <code>substring.bytesize</code>,
|
|
1241
1243
|
# and may increment the [character
|
|
1242
1244
|
# position](rdoc-ref:StringScanner@Character+Position).
|
|
1243
1245
|
# * Sets [match values](rdoc-ref:StringScanner@Match+Values).
|
|
@@ -1517,7 +1519,7 @@ class StringScanner
|
|
|
1517
1519
|
# call-seq:
|
|
1518
1520
|
# terminate -> self
|
|
1519
1521
|
# Sets the scanner to end-of-string;
|
|
1520
|
-
# returns
|
|
1522
|
+
# returns +self+:
|
|
1521
1523
|
# * Sets both [positions](rdoc-ref:StringScanner@Positions) to end-of-stream.
|
|
1522
1524
|
# * Clears [match values](rdoc-ref:StringScanner@Match+Values).
|
|
1523
1525
|
# scanner = StringScanner.new(HIRAGANA_TEXT)
|
|
@@ -1578,7 +1580,7 @@ class StringScanner
|
|
|
1578
1580
|
# - values_at(*specifiers) -> array_of_captures or nil
|
|
1579
1581
|
# -->
|
|
1580
1582
|
# Returns an array of captured substrings, or `nil` of none.
|
|
1581
|
-
# For each `specifier`, the returned substring is
|
|
1583
|
+
# For each `specifier`, the returned substring is <code>[specifier]</code>;
|
|
1582
1584
|
# see #[].
|
|
1583
1585
|
# scanner = StringScanner.new('Fri Dec 12 1975 14:39')
|
|
1584
1586
|
# pattern = /(?<wday>\w+) (?<month>\w+) (?<day>\d+) /
|
|
@@ -19,7 +19,7 @@
|
|
|
19
19
|
# require 'tempfile'
|
|
20
20
|
#
|
|
21
21
|
# # Tempfile.create with a block
|
|
22
|
-
# # The filename are
|
|
22
|
+
# # The filename are chosen automatically.
|
|
23
23
|
# # (You can specify the prefix and suffix of the filename by an optional argument.)
|
|
24
24
|
# Tempfile.create {|f|
|
|
25
25
|
# f.puts "foo"
|
|
@@ -159,7 +159,7 @@ class Tempfile < File
|
|
|
159
159
|
# * Generated filename is unique in that directory.
|
|
160
160
|
# * Permissions are `0600`; see [File
|
|
161
161
|
# Permissions](rdoc-ref:File@File+Permissions).
|
|
162
|
-
# * Mode is
|
|
162
|
+
# * Mode is <code>'w+'</code> (read/write mode, positioned at the end).
|
|
163
163
|
#
|
|
164
164
|
# The temporary file removal depends on the keyword argument `anonymous` and
|
|
165
165
|
# whether a block is given or not. See the description about the `anonymous`
|
|
@@ -206,8 +206,8 @@ class Tempfile < File
|
|
|
206
206
|
#
|
|
207
207
|
# Tempfile.create('foo') # => #<File:/tmp/foo20220505-9795-1gok8l9>
|
|
208
208
|
#
|
|
209
|
-
# * An array of two strings
|
|
210
|
-
# with `prefix` and ends with `suffix`:
|
|
209
|
+
# * An array of two strings <code>[prefix, suffix]</code>: the generated
|
|
210
|
+
# filename begins with `prefix` and ends with `suffix`:
|
|
211
211
|
#
|
|
212
212
|
# Tempfile.create(%w/foo .jpg/) # => #<File:/tmp/foo20220505-17839-tnjchh.jpg>
|
|
213
213
|
#
|
|
@@ -226,16 +226,19 @@ class Tempfile < File
|
|
|
226
226
|
#
|
|
227
227
|
# The keyword argument `anonymous` specifies when the file is removed.
|
|
228
228
|
#
|
|
229
|
-
# *
|
|
230
|
-
#
|
|
231
|
-
#
|
|
232
|
-
#
|
|
233
|
-
# *
|
|
234
|
-
#
|
|
229
|
+
# * <code>anonymous=false</code> (default) without a block: the file is not
|
|
230
|
+
# removed.
|
|
231
|
+
# * <code>anonymous=false</code> (default) with a block: the file is removed
|
|
232
|
+
# after the block exits.
|
|
233
|
+
# * <code>anonymous=true</code> without a block: the file is removed before
|
|
234
|
+
# returning.
|
|
235
|
+
# * <code>anonymous=true</code> with a block: the file is removed before the
|
|
236
|
+
# block is called.
|
|
235
237
|
#
|
|
236
|
-
# In the first case (
|
|
237
|
-
# automatically. It should be explicitly closed. It can be used to
|
|
238
|
-
# desired filename. If the file is not needed, it should be
|
|
238
|
+
# In the first case (<code>anonymous=false</code> without a block), the file is
|
|
239
|
+
# not removed automatically. It should be explicitly closed. It can be used to
|
|
240
|
+
# rename to the desired filename. If the file is not needed, it should be
|
|
241
|
+
# explicitly removed.
|
|
239
242
|
#
|
|
240
243
|
# The File#path method of the created file object returns the temporary
|
|
241
244
|
# directory with a trailing slash when `anonymous` is true.
|
|
@@ -248,8 +251,8 @@ class Tempfile < File
|
|
|
248
251
|
#
|
|
249
252
|
# Implementation note:
|
|
250
253
|
#
|
|
251
|
-
# The keyword argument
|
|
252
|
-
# on Windows. O_TMPFILE is used on Linux.
|
|
254
|
+
# The keyword argument <code>anonymous=true</code> is implemented using
|
|
255
|
+
# `FILE_SHARE_DELETE` on Windows. `O_TMPFILE` is used on Linux.
|
|
253
256
|
#
|
|
254
257
|
# Related: Tempfile.new.
|
|
255
258
|
#
|
|
@@ -283,7 +286,8 @@ class Tempfile < File
|
|
|
283
286
|
#
|
|
284
287
|
# The call returns the value of the block.
|
|
285
288
|
#
|
|
286
|
-
# In any case, all arguments (
|
|
289
|
+
# In any case, all arguments (<code>*args</code>) will be passed to
|
|
290
|
+
# Tempfile.new.
|
|
287
291
|
#
|
|
288
292
|
# Tempfile.open('foo', '/home/temp') do |f|
|
|
289
293
|
# # ... do something with f ...
|
|
@@ -318,7 +322,7 @@ class Tempfile < File
|
|
|
318
322
|
# - close!()
|
|
319
323
|
# -->
|
|
320
324
|
# Closes and unlinks (deletes) the file. Has the same effect as called
|
|
321
|
-
#
|
|
325
|
+
# <code>close(true)</code>.
|
|
322
326
|
#
|
|
323
327
|
def close!: () -> void
|
|
324
328
|
|
|
@@ -422,7 +426,7 @@ class Tempfile < File
|
|
|
422
426
|
# If possible, consider instead using Tempfile.create, which:
|
|
423
427
|
#
|
|
424
428
|
# * Avoids the performance cost of delegation, incurred when Tempfile.new
|
|
425
|
-
# calls its superclass
|
|
429
|
+
# calls its superclass <code>DelegateClass(File)</code>.
|
|
426
430
|
# * Does not rely on a finalizer to close and unlink the file, which can be
|
|
427
431
|
# unreliable.
|
|
428
432
|
#
|
|
@@ -433,7 +437,7 @@ class Tempfile < File
|
|
|
433
437
|
# * Generated filename is unique in that directory.
|
|
434
438
|
# * Permissions are `0600`; see [File
|
|
435
439
|
# Permissions](rdoc-ref:File@File+Permissions).
|
|
436
|
-
# * Mode is
|
|
440
|
+
# * Mode is <code>'w+'</code> (read/write mode, positioned at the end).
|
|
437
441
|
#
|
|
438
442
|
# The underlying file is removed when the Tempfile object dies and is reclaimed
|
|
439
443
|
# by the garbage collector.
|
|
@@ -454,8 +458,8 @@ class Tempfile < File
|
|
|
454
458
|
#
|
|
455
459
|
# Tempfile.new('foo') # => #<Tempfile:/tmp/foo20220505-17839-1whk2f>
|
|
456
460
|
#
|
|
457
|
-
# * An array of two strings
|
|
458
|
-
# with `prefix` and ends with `suffix`:
|
|
461
|
+
# * An array of two strings <code>[prefix, suffix]</code>: the generated
|
|
462
|
+
# filename begins with `prefix` and ends with `suffix`:
|
|
459
463
|
#
|
|
460
464
|
# Tempfile.new(%w/foo .jpg/) # => #<Tempfile:/tmp/foo20220505-17839-58xtfi.jpg>
|
|
461
465
|
#
|
data/stdlib/time/0/time.rbs
CHANGED
|
@@ -10,12 +10,13 @@ class Time
|
|
|
10
10
|
|
|
11
11
|
# <!--
|
|
12
12
|
# rdoc-file=lib/time.rb
|
|
13
|
-
# - zone_offset(zone, year=
|
|
13
|
+
# - zone_offset(zone, year=nil)
|
|
14
14
|
# -->
|
|
15
15
|
# Return the number of seconds the specified time zone differs from UTC.
|
|
16
16
|
#
|
|
17
|
-
# Numeric time zones that include minutes, such as
|
|
18
|
-
# work, as will simpler hour-only time zones like
|
|
17
|
+
# Numeric time zones that include minutes, such as <code>-10:00</code> or
|
|
18
|
+
# <code>+1330</code> will work, as will simpler hour-only time zones like
|
|
19
|
+
# <code>-10</code> or <code>+13</code>.
|
|
19
20
|
#
|
|
20
21
|
# Textual time zones listed in ZoneOffset are also supported.
|
|
21
22
|
#
|
|
@@ -120,9 +121,10 @@ class Time
|
|
|
120
121
|
# Based on this fact, this method only understands the time zone abbreviations
|
|
121
122
|
# described in RFC 822 and the system time zone, in the order named. (i.e. a
|
|
122
123
|
# definition in RFC 822 overrides the system time zone definition.) The system
|
|
123
|
-
# time zone is taken from
|
|
124
|
-
# 1).zone
|
|
125
|
-
# it is ignored and the given time is
|
|
124
|
+
# time zone is taken from <code>Time.local(year, 1, 1).zone</code> and
|
|
125
|
+
# <code>Time.local(year, 7, 1).zone</code>. If the extracted time zone
|
|
126
|
+
# abbreviation does not match any of them, it is ignored and the given time is
|
|
127
|
+
# regarded as a local time.
|
|
126
128
|
#
|
|
127
129
|
# ArgumentError is raised if Date._parse cannot extract information from `date`
|
|
128
130
|
# or if the Time class cannot represent specified date.
|
|
@@ -26,7 +26,7 @@ module Timeout
|
|
|
26
26
|
# rdoc-file=lib/timeout.rb
|
|
27
27
|
# - timeout(sec, klass = nil, message = nil) { |sec| ... }
|
|
28
28
|
# -->
|
|
29
|
-
# Perform an operation in a block, raising an
|
|
29
|
+
# Perform an operation in a block, raising an exception if it takes longer than
|
|
30
30
|
# `sec` seconds to complete.
|
|
31
31
|
#
|
|
32
32
|
# `sec`
|
|
@@ -45,12 +45,20 @@ module Timeout
|
|
|
45
45
|
#
|
|
46
46
|
#
|
|
47
47
|
# Returns the result of the block **if** the block completed before `sec`
|
|
48
|
-
# seconds, otherwise
|
|
48
|
+
# seconds, otherwise raises an exception, based on the value of `klass`.
|
|
49
49
|
#
|
|
50
|
-
# The exception
|
|
51
|
-
#
|
|
52
|
-
#
|
|
53
|
-
#
|
|
50
|
+
# The exception raised to terminate the given block is the given `klass`, or
|
|
51
|
+
# Timeout::ExitException if `klass` is not given. The reason for that behavior
|
|
52
|
+
# is that Timeout::Error inherits from RuntimeError and might be caught
|
|
53
|
+
# unexpectedly by `rescue`. Timeout::ExitException inherits from Exception so it
|
|
54
|
+
# will only be rescued by `rescue Exception`. Note that the
|
|
55
|
+
# Timeout::ExitException is translated to a Timeout::Error once it reaches the
|
|
56
|
+
# Timeout.timeout call, so outside that call it will be a Timeout::Error.
|
|
57
|
+
#
|
|
58
|
+
# In general, be aware that the code block may rescue the exception, and in such
|
|
59
|
+
# a case not respect the timeout. Also, the block can use `ensure` to prevent
|
|
60
|
+
# the handling of the exception. For those reasons, this method cannot be relied
|
|
61
|
+
# on to enforce timeouts for untrusted blocks.
|
|
54
62
|
#
|
|
55
63
|
# If a scheduler is defined, it will be used to handle the timeout by invoking
|
|
56
64
|
# Scheduler#timeout_after.
|
|
@@ -59,11 +67,59 @@ module Timeout
|
|
|
59
67
|
# Timeout` into your classes so they have a #timeout method, as well as a module
|
|
60
68
|
# method, so you can call it directly as Timeout.timeout().
|
|
61
69
|
#
|
|
70
|
+
# #### Ensuring the exception does not fire inside ensure blocks
|
|
71
|
+
#
|
|
72
|
+
# When using Timeout.timeout it can be desirable to ensure the timeout exception
|
|
73
|
+
# does not fire inside an `ensure` block. The simplest and best way to do so it
|
|
74
|
+
# to put the Timeout.timeout call inside the body of the begin/ensure/end:
|
|
75
|
+
#
|
|
76
|
+
# begin
|
|
77
|
+
# Timeout.timeout(sec) { some_long_operation }
|
|
78
|
+
# ensure
|
|
79
|
+
# cleanup # safe, cannot be interrupt by timeout
|
|
80
|
+
# end
|
|
81
|
+
#
|
|
82
|
+
# If that is not feasible, e.g. if there are `ensure` blocks inside
|
|
83
|
+
# `some_long_operation`, they need to not be interrupted by timeout, and it's
|
|
84
|
+
# not possible to move these ensure blocks outside, one can use
|
|
85
|
+
# Thread.handle_interrupt to delay the timeout exception like so:
|
|
86
|
+
#
|
|
87
|
+
# Thread.handle_interrupt(Timeout::Error => :never) {
|
|
88
|
+
# Timeout.timeout(sec, Timeout::Error) do
|
|
89
|
+
# setup # timeout cannot happen here, no matter how long it takes
|
|
90
|
+
# Thread.handle_interrupt(Timeout::Error => :immediate) {
|
|
91
|
+
# some_long_operation # timeout can happen here
|
|
92
|
+
# }
|
|
93
|
+
# ensure
|
|
94
|
+
# cleanup # timeout cannot happen here, no matter how long it takes
|
|
95
|
+
# end
|
|
96
|
+
# }
|
|
97
|
+
#
|
|
98
|
+
# An important thing to note is the need to pass an exception klass to
|
|
99
|
+
# Timeout.timeout, otherwise it does not work. Specifically, using
|
|
100
|
+
# +Thread.handle_interrupt(Timeout::ExitException => ...)+ is unsupported and
|
|
101
|
+
# causes subtle errors like raising the wrong exception outside the block, do
|
|
102
|
+
# not use that.
|
|
103
|
+
#
|
|
104
|
+
# Note that Thread.handle_interrupt is somewhat dangerous because if setup or
|
|
105
|
+
# cleanup hangs then the current thread will hang too and the timeout will never
|
|
106
|
+
# fire. Also note the block might run for longer than `sec` seconds: e.g.
|
|
107
|
+
# some_long_operation executes for `sec` seconds + whatever time cleanup takes.
|
|
108
|
+
#
|
|
109
|
+
# If you want the timeout to only happen on blocking operations one can use
|
|
110
|
+
# :on_blocking instead of :immediate. However, that means if the block uses no
|
|
111
|
+
# blocking operations after `sec` seconds, the block will not be interrupted.
|
|
112
|
+
# ----
|
|
113
|
+
# <!--
|
|
114
|
+
# rdoc-file=lib/timeout.rb
|
|
115
|
+
# - timeout(*args, &block)
|
|
116
|
+
# -->
|
|
117
|
+
#
|
|
62
118
|
def self?.timeout: [T] (Numeric? sec, ?singleton(Exception) klass, ?String message) { (Numeric sec) -> T } -> T
|
|
63
119
|
end
|
|
64
120
|
|
|
65
121
|
# <!-- rdoc-file=lib/timeout.rb -->
|
|
66
|
-
# Internal
|
|
122
|
+
# Internal exception raised to when a timeout is triggered.
|
|
67
123
|
#
|
|
68
124
|
class Timeout::ExitException < Exception
|
|
69
125
|
end
|
data/stdlib/tsort/0/cyclic.rbs
CHANGED
data/stdlib/tsort/0/tsort.rbs
CHANGED
|
@@ -262,9 +262,9 @@ module TSort[Node] : TSort::_Sortable[Node]
|
|
|
262
262
|
# - each_strongly_connected_component() { |nodes| ... }
|
|
263
263
|
# -->
|
|
264
264
|
# The iterator version of the #strongly_connected_components method.
|
|
265
|
-
#
|
|
266
|
-
#
|
|
267
|
-
# the iteration may lead to unexpected results.
|
|
265
|
+
# <code><em>obj</em>.each_strongly_connected_component</code> is similar to
|
|
266
|
+
# <code><em>obj</em>.strongly_connected_components.each</code>, but modification
|
|
267
|
+
# of *obj* during the iteration may lead to unexpected results.
|
|
268
268
|
#
|
|
269
269
|
# #each_strongly_connected_component returns `nil`.
|
|
270
270
|
#
|
|
@@ -382,9 +382,10 @@ module TSort[Node] : TSort::_Sortable[Node]
|
|
|
382
382
|
# rdoc-file=lib/tsort.rb
|
|
383
383
|
# - tsort_each() { |node| ... }
|
|
384
384
|
# -->
|
|
385
|
-
# The iterator version of the #tsort method.
|
|
386
|
-
#
|
|
387
|
-
#
|
|
385
|
+
# The iterator version of the #tsort method.
|
|
386
|
+
# <code><em>obj</em>.tsort_each</code> is similar to
|
|
387
|
+
# <code><em>obj</em>.tsort.each</code>, but modification of *obj* during the
|
|
388
|
+
# iteration may lead to unexpected results.
|
|
388
389
|
#
|
|
389
390
|
# #tsort_each returns `nil`. If there is a cycle, TSort::Cyclic is raised.
|
|
390
391
|
#
|
data/stdlib/uri/0/common.rbs
CHANGED
|
@@ -119,7 +119,7 @@ module URI
|
|
|
119
119
|
# rdoc-file=lib/uri/common.rb
|
|
120
120
|
# - decode_uri_component(str, enc=Encoding::UTF_8)
|
|
121
121
|
# -->
|
|
122
|
-
# Like URI.decode_www_form_component, except that
|
|
122
|
+
# Like URI.decode_www_form_component, except that <code>'+'</code> is preserved.
|
|
123
123
|
#
|
|
124
124
|
def self.decode_uri_component: (String str, ?encoding enc) -> String
|
|
125
125
|
|
|
@@ -131,7 +131,8 @@ module URI
|
|
|
131
131
|
# ASCII string.
|
|
132
132
|
#
|
|
133
133
|
# The method may be used to decode the body of Net::HTTPResponse object `res`
|
|
134
|
-
# for which
|
|
134
|
+
# for which <code>res['Content-Type']</code> is
|
|
135
|
+
# <code>'application/x-www-form-urlencoded'</code>.
|
|
135
136
|
#
|
|
136
137
|
# The returned data is an array of 2-element subarrays; each subarray is a
|
|
137
138
|
# name/value pair (both are strings). Each returned string has encoding `enc`,
|
|
@@ -175,8 +176,10 @@ module URI
|
|
|
175
176
|
#
|
|
176
177
|
# * Preserves:
|
|
177
178
|
#
|
|
178
|
-
# * Characters
|
|
179
|
-
#
|
|
179
|
+
# * Characters <code>'*'</code>, <code>'.'</code>, <code>'-'</code>, and
|
|
180
|
+
# <code>'_'</code>.
|
|
181
|
+
# * Character in ranges <code>'a'..'z'</code>, <code>'A'..'Z'</code>, and
|
|
182
|
+
# <code>'0'..'9'</code>.
|
|
180
183
|
#
|
|
181
184
|
# Example:
|
|
182
185
|
#
|
|
@@ -185,7 +188,7 @@ module URI
|
|
|
185
188
|
#
|
|
186
189
|
# * Converts:
|
|
187
190
|
#
|
|
188
|
-
# * Character
|
|
191
|
+
# * Character <code>'+'</code> to character <code>' '</code>.
|
|
189
192
|
# * Each "percent notation" to an ASCII character.
|
|
190
193
|
#
|
|
191
194
|
# Example:
|
|
@@ -193,7 +196,7 @@ module URI
|
|
|
193
196
|
# URI.decode_www_form_component('Here+are+some+punctuation+characters%3A+%2C%3B%3F%3A')
|
|
194
197
|
# # => "Here are some punctuation characters: ,;?:"
|
|
195
198
|
#
|
|
196
|
-
# Related: URI.decode_uri_component (preserves
|
|
199
|
+
# Related: URI.decode_uri_component (preserves <code>'+'</code>).
|
|
197
200
|
#
|
|
198
201
|
def self.decode_www_form_component: (String str, ?encoding enc) -> String
|
|
199
202
|
|
|
@@ -201,8 +204,8 @@ module URI
|
|
|
201
204
|
# rdoc-file=lib/uri/common.rb
|
|
202
205
|
# - encode_uri_component(str, enc=nil)
|
|
203
206
|
# -->
|
|
204
|
-
# Like URI.encode_www_form_component, except that
|
|
205
|
-
#
|
|
207
|
+
# Like URI.encode_www_form_component, except that <code>' '</code> (space) is
|
|
208
|
+
# encoded as <code>'%20'</code> (instead of <code>'+'</code>).
|
|
206
209
|
#
|
|
207
210
|
def self.encode_uri_component: (String str, ?encoding enc) -> String
|
|
208
211
|
|
|
@@ -214,10 +217,10 @@ module URI
|
|
|
214
217
|
# [Enumerable](rdoc-ref:Enumerable@Enumerable+in+Ruby+Classes) `enum`.
|
|
215
218
|
#
|
|
216
219
|
# The result is suitable for use as form data for an HTTP request whose
|
|
217
|
-
#
|
|
220
|
+
# <code>Content-Type</code> is <code>'application/x-www-form-urlencoded'</code>.
|
|
218
221
|
#
|
|
219
222
|
# The returned string consists of the elements of `enum`, each converted to one
|
|
220
|
-
# or more URL-encoded strings, and all joined with character
|
|
223
|
+
# or more URL-encoded strings, and all joined with character <code>'&'</code>.
|
|
221
224
|
#
|
|
222
225
|
# Simple examples:
|
|
223
226
|
#
|
|
@@ -248,7 +251,8 @@ module URI
|
|
|
248
251
|
# URI.encode_www_form([['foo', 0], ['bar', :baz, 'bat']])
|
|
249
252
|
# # => "foo=0&bar=baz"
|
|
250
253
|
#
|
|
251
|
-
# * If `ele` is an array of one element, the field is formed from
|
|
254
|
+
# * If `ele` is an array of one element, the field is formed from
|
|
255
|
+
# <code>ele[0]</code>:
|
|
252
256
|
#
|
|
253
257
|
# URI.encode_www_form_component(ele[0])
|
|
254
258
|
#
|
|
@@ -316,8 +320,10 @@ module URI
|
|
|
316
320
|
#
|
|
317
321
|
# * Preserves:
|
|
318
322
|
#
|
|
319
|
-
# * Characters
|
|
320
|
-
#
|
|
323
|
+
# * Characters <code>'*'</code>, <code>'.'</code>, <code>'-'</code>, and
|
|
324
|
+
# <code>'_'</code>.
|
|
325
|
+
# * Character in ranges <code>'a'..'z'</code>, <code>'A'..'Z'</code>, and
|
|
326
|
+
# <code>'0'..'9'</code>.
|
|
321
327
|
#
|
|
322
328
|
# Example:
|
|
323
329
|
#
|
|
@@ -326,9 +332,9 @@ module URI
|
|
|
326
332
|
#
|
|
327
333
|
# * Converts:
|
|
328
334
|
#
|
|
329
|
-
# * Character
|
|
335
|
+
# * Character <code>' '</code> to character <code>'+'</code>.
|
|
330
336
|
# * Any other character to "percent notation"; the percent notation for
|
|
331
|
-
# character *c* is
|
|
337
|
+
# character *c* is <code>'%%%X' % c.ord</code>.
|
|
332
338
|
#
|
|
333
339
|
# Example:
|
|
334
340
|
#
|
|
@@ -343,7 +349,8 @@ module URI
|
|
|
343
349
|
#
|
|
344
350
|
# In either case, the returned string has forced encoding Encoding::US_ASCII.
|
|
345
351
|
#
|
|
346
|
-
# Related: URI.encode_uri_component (encodes
|
|
352
|
+
# Related: URI.encode_uri_component (encodes <code>' '</code> as
|
|
353
|
+
# <code>'%20'</code>).
|
|
347
354
|
#
|
|
348
355
|
def self.encode_www_form_component: (_ToS str, ?encoding? enc) -> String
|
|
349
356
|
|
|
@@ -420,8 +427,8 @@ module URI
|
|
|
420
427
|
# URI.parse('http://john.doe@www.example.com:123/forum/questions/?tag=networking&order=newest#top')
|
|
421
428
|
# # => #<URI::HTTP http://john.doe@www.example.com:123/forum/questions/?tag=networking&order=newest#top>
|
|
422
429
|
#
|
|
423
|
-
# It's recommended to first ::escape string `uri` if it may
|
|
424
|
-
# characters.
|
|
430
|
+
# It's recommended to first URI::RFC2396_PARSER.escape string `uri` if it may
|
|
431
|
+
# contain invalid URI characters.
|
|
425
432
|
#
|
|
426
433
|
def self.parse: (_ToStr uri) -> (File | FTP | HTTP | HTTPS | LDAP | LDAPS | MailTo | WS | WSS | Generic)
|
|
427
434
|
|
|
@@ -491,7 +498,8 @@ module URI
|
|
|
491
498
|
# Returns a new object constructed from the given `scheme`, `arguments`, and
|
|
492
499
|
# `default`:
|
|
493
500
|
#
|
|
494
|
-
# * The new object is an instance of
|
|
501
|
+
# * The new object is an instance of
|
|
502
|
+
# <code>URI.scheme_list[scheme.upcase]</code>.
|
|
495
503
|
# * The object is initialized by calling the class initializer using `scheme`
|
|
496
504
|
# and `arguments`. See URI::Generic.new.
|
|
497
505
|
#
|
|
@@ -535,6 +543,9 @@ URI::ABS_URI: Regexp
|
|
|
535
543
|
|
|
536
544
|
URI::ABS_URI_REF: Regexp
|
|
537
545
|
|
|
546
|
+
# <!-- rdoc-file=lib/uri/common.rb -->
|
|
547
|
+
# The default parser instance.
|
|
548
|
+
#
|
|
538
549
|
URI::DEFAULT_PARSER: URI::RFC2396_Parser
|
|
539
550
|
|
|
540
551
|
URI::ESCAPED: Regexp
|
|
@@ -557,6 +568,14 @@ URI::REL_URI: Regexp
|
|
|
557
568
|
|
|
558
569
|
URI::REL_URI_REF: Regexp
|
|
559
570
|
|
|
571
|
+
# <!-- rdoc-file=lib/uri/common.rb -->
|
|
572
|
+
# The default parser instance for RFC 2396.
|
|
573
|
+
#
|
|
574
|
+
URI::RFC2396_PARSER: URI::RFC2396_Parser
|
|
575
|
+
|
|
576
|
+
# <!-- rdoc-file=lib/uri/common.rb -->
|
|
577
|
+
# The default parser instance for RFC 3986.
|
|
578
|
+
#
|
|
560
579
|
URI::RFC3986_PARSER: URI::RFC3986_Parser
|
|
561
580
|
|
|
562
581
|
URI::SCHEME: Regexp
|
|
@@ -588,6 +607,7 @@ module Kernel
|
|
|
588
607
|
# Returns a URI object derived from the given `uri`, which may be a URI string
|
|
589
608
|
# or an existing URI object:
|
|
590
609
|
#
|
|
610
|
+
# require 'uri'
|
|
591
611
|
# # Returns a new URI.
|
|
592
612
|
# uri = URI('http://github.com/ruby/ruby')
|
|
593
613
|
# # => #<URI::HTTP http://github.com/ruby/ruby>
|
|
@@ -595,5 +615,7 @@ module Kernel
|
|
|
595
615
|
# URI(uri)
|
|
596
616
|
# # => #<URI::HTTP http://github.com/ruby/ruby>
|
|
597
617
|
#
|
|
598
|
-
|
|
618
|
+
# You must require 'uri' to use this method.
|
|
619
|
+
#
|
|
620
|
+
def self?.URI: (URI::Generic | string uri) -> URI::Generic
|
|
599
621
|
end
|