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
data/core/enumerable.rbs
CHANGED
|
@@ -16,8 +16,8 @@
|
|
|
16
16
|
# These methods return information about the Enumerable other than the elements
|
|
17
17
|
# themselves:
|
|
18
18
|
#
|
|
19
|
-
# * #member? (aliased as #include?): Returns `true` if
|
|
20
|
-
# `false` otherwise.
|
|
19
|
+
# * #member? (aliased as #include?): Returns `true` if <code>self ==
|
|
20
|
+
# object</code>, `false` otherwise.
|
|
21
21
|
# * #all?: Returns `true` if all elements meet a specified criterion; `false`
|
|
22
22
|
# otherwise.
|
|
23
23
|
# * #any?: Returns `true` if any element meets a specified criterion; `false`
|
|
@@ -35,7 +35,7 @@
|
|
|
35
35
|
#
|
|
36
36
|
# These methods return entries from the Enumerable, without modifying it:
|
|
37
37
|
#
|
|
38
|
-
#
|
|
38
|
+
# <em>Leading, trailing, or all elements</em>:
|
|
39
39
|
#
|
|
40
40
|
# * #to_a (aliased as #entries): Returns all elements.
|
|
41
41
|
# * #first: Returns the first element or leading elements.
|
|
@@ -47,9 +47,9 @@
|
|
|
47
47
|
# *Minimum and maximum value elements*:
|
|
48
48
|
#
|
|
49
49
|
# * #min: Returns the elements whose values are smallest among the elements,
|
|
50
|
-
# as determined by
|
|
50
|
+
# as determined by <code>#<=></code> or a given block.
|
|
51
51
|
# * #max: Returns the elements whose values are largest among the elements, as
|
|
52
|
-
# determined by
|
|
52
|
+
# determined by <code>#<=></code> or a given block.
|
|
53
53
|
# * #minmax: Returns a 2-element Array containing the smallest and largest
|
|
54
54
|
# elements.
|
|
55
55
|
# * #min_by: Returns the smallest element, as determined by the given block.
|
|
@@ -57,7 +57,7 @@
|
|
|
57
57
|
# * #minmax_by: Returns the smallest and largest elements, as determined by
|
|
58
58
|
# the given block.
|
|
59
59
|
#
|
|
60
|
-
#
|
|
60
|
+
# <em>Groups, slices, and partitions</em>:
|
|
61
61
|
#
|
|
62
62
|
# * #group_by: Returns a Hash that partitions the elements into groups.
|
|
63
63
|
# * #partition: Returns elements partitioned into two new Arrays, as
|
|
@@ -89,7 +89,8 @@
|
|
|
89
89
|
#
|
|
90
90
|
# These methods return elements in sorted order:
|
|
91
91
|
#
|
|
92
|
-
# * #sort: Returns the elements, sorted by
|
|
92
|
+
# * #sort: Returns the elements, sorted by <code>#<=></code> or the given
|
|
93
|
+
# block.
|
|
93
94
|
# * #sort_by: Returns the elements, sorted by the given block.
|
|
94
95
|
#
|
|
95
96
|
# ### Methods for Iterating
|
|
@@ -114,11 +115,11 @@
|
|
|
114
115
|
# by the block.
|
|
115
116
|
# * #grep: Returns elements selected by a given object or objects returned by
|
|
116
117
|
# a given block.
|
|
117
|
-
# * #grep_v: Returns elements selected by a given object or objects
|
|
118
|
-
# by a given block.
|
|
118
|
+
# * #grep_v: Returns elements not selected by a given object or objects
|
|
119
|
+
# returned by a given block.
|
|
119
120
|
# * #inject (aliased as #reduce): Returns the object formed by combining all
|
|
120
121
|
# elements.
|
|
121
|
-
# * #sum: Returns the sum of the elements, using method
|
|
122
|
+
# * #sum: Returns the sum of the elements, using method <code>+</code>.
|
|
122
123
|
# * #zip: Combines each element with elements from other enumerables; returns
|
|
123
124
|
# the n-tuples or calls the block with each.
|
|
124
125
|
# * #cycle: Calls the block with each element, cycling repeatedly.
|
|
@@ -131,8 +132,9 @@
|
|
|
131
132
|
#
|
|
132
133
|
# include Enumerable
|
|
133
134
|
#
|
|
134
|
-
# * Implement method
|
|
135
|
-
# collection. The method will be called by almost any Enumerable
|
|
135
|
+
# * Implement method <code>#each</code> which must yield successive elements
|
|
136
|
+
# of the collection. The method will be called by almost any Enumerable
|
|
137
|
+
# method.
|
|
136
138
|
#
|
|
137
139
|
# Example:
|
|
138
140
|
#
|
|
@@ -173,13 +175,15 @@
|
|
|
173
175
|
# * CSV::Row
|
|
174
176
|
# * Set
|
|
175
177
|
#
|
|
176
|
-
# Virtually all methods in Enumerable call method
|
|
177
|
-
# class:
|
|
178
|
+
# Virtually all methods in Enumerable call method <code>#each</code> in the
|
|
179
|
+
# including class:
|
|
178
180
|
#
|
|
179
|
-
# *
|
|
180
|
-
#
|
|
181
|
-
# *
|
|
182
|
-
#
|
|
181
|
+
# * <code>Hash#each</code> yields the next key-value pair as a 2-element
|
|
182
|
+
# Array.
|
|
183
|
+
# * <code>Struct#each</code> yields the next name-value pair as a 2-element
|
|
184
|
+
# Array.
|
|
185
|
+
# * For the other classes above, <code>#each</code> yields the next object
|
|
186
|
+
# from the collection.
|
|
183
187
|
#
|
|
184
188
|
# ## About the Examples
|
|
185
189
|
#
|
|
@@ -191,6 +195,82 @@
|
|
|
191
195
|
# usage would not make sense, and so it is not shown. Example: #tally would
|
|
192
196
|
# find exactly one of each Hash entry.
|
|
193
197
|
#
|
|
198
|
+
# ## Extended Methods
|
|
199
|
+
#
|
|
200
|
+
# A Enumerable class may define extended methods. This section describes the
|
|
201
|
+
# standard behavior of extension methods for reference purposes.
|
|
202
|
+
#
|
|
203
|
+
# ### #size
|
|
204
|
+
#
|
|
205
|
+
# Enumerator has a #size method. It uses the size function argument passed to
|
|
206
|
+
# <code>Enumerator.new</code>.
|
|
207
|
+
#
|
|
208
|
+
# e = Enumerator.new(-> { 3 }) {|y| p y; y.yield :a; y.yield :b; y.yield :c; :z }
|
|
209
|
+
# p e.size #=> 3
|
|
210
|
+
# p e.next #=> :a
|
|
211
|
+
# p e.next #=> :b
|
|
212
|
+
# p e.next #=> :c
|
|
213
|
+
# begin
|
|
214
|
+
# e.next
|
|
215
|
+
# rescue StopIteration
|
|
216
|
+
# p $!.result #=> :z
|
|
217
|
+
# end
|
|
218
|
+
#
|
|
219
|
+
# The result of the size function should represent the number of iterations
|
|
220
|
+
# (i.e., the number of times Enumerator::Yielder#yield is called). In the above
|
|
221
|
+
# example, the block calls #yield three times, and the size function, +-> { 3
|
|
222
|
+
# }+, returns 3 accordingly. The result of the size function can be an integer,
|
|
223
|
+
# <code>Float::INFINITY</code>, or `nil`. An integer means the exact number of
|
|
224
|
+
# times #yield will be called, as shown above. <code>Float::INFINITY</code>
|
|
225
|
+
# indicates an infinite number of #yield calls. `nil` means the number of #yield
|
|
226
|
+
# calls is difficult or impossible to determine.
|
|
227
|
+
#
|
|
228
|
+
# Many iteration methods return an Enumerator object with an appropriate size
|
|
229
|
+
# function if no block is given.
|
|
230
|
+
#
|
|
231
|
+
# Examples:
|
|
232
|
+
#
|
|
233
|
+
# ["a", "b", "c"].each.size #=> 3
|
|
234
|
+
# {a: "x", b: "y", c: "z"}.each.size #=> 3
|
|
235
|
+
# (0..20).to_a.permutation.size #=> 51090942171709440000
|
|
236
|
+
# loop.size #=> Float::INFINITY
|
|
237
|
+
# (1..100).drop_while.size #=> nil # size depends on the block's behavior
|
|
238
|
+
# STDIN.each.size #=> nil # cannot be computed without consuming input
|
|
239
|
+
# File.open("/etc/resolv.conf").each.size #=> nil # cannot be computed without reading the file
|
|
240
|
+
#
|
|
241
|
+
# The behavior of #size for Range-based enumerators depends on the #begin
|
|
242
|
+
# element:
|
|
243
|
+
#
|
|
244
|
+
# * If the #begin element is an Integer, the #size method returns an Integer
|
|
245
|
+
# or <code>Float::INFINITY</code>.
|
|
246
|
+
# * If the #begin element is an object with a #succ method (other than
|
|
247
|
+
# Integer), #size returns `nil`. (Computing the size would require
|
|
248
|
+
# repeatedly calling #succ, which may be too slow.)
|
|
249
|
+
# * If the #begin element does not have a #succ method, #size raises a
|
|
250
|
+
# TypeError.
|
|
251
|
+
#
|
|
252
|
+
# Examples:
|
|
253
|
+
#
|
|
254
|
+
# (10..42).each.size #=> 33
|
|
255
|
+
# (10..42.9).each.size #=> 33 (the #end element may be a non-integer numeric)
|
|
256
|
+
# (10..).each.size #=> Float::INFINITY
|
|
257
|
+
# ("a".."z").each.size #=> nil
|
|
258
|
+
# ("a"..).each.size #=> nil
|
|
259
|
+
# (1.0..9.0).each.size # raises TypeError (Float does not have #succ)
|
|
260
|
+
# (..10).each.size # raises TypeError (beginless range has nil as its #begin)
|
|
261
|
+
#
|
|
262
|
+
# The Enumerable module itself does not define a #size method. A class that
|
|
263
|
+
# includes Enumerable may define its own #size method. It is recommended that
|
|
264
|
+
# such a #size method be consistent with Enumerator#size.
|
|
265
|
+
#
|
|
266
|
+
# Array and Hash implement #size and return values consistent with
|
|
267
|
+
# Enumerator#size. IO and Dir do not define #size, which is also consistent
|
|
268
|
+
# because the corresponding enumerator's size function returns `nil`.
|
|
269
|
+
#
|
|
270
|
+
# However, it is not strictly required for a class's #size method to match
|
|
271
|
+
# Enumerator#size. For example, File#size returns the number of bytes in the
|
|
272
|
+
# file, not the number of lines.
|
|
273
|
+
#
|
|
194
274
|
module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
195
275
|
%a{private}
|
|
196
276
|
interface _Pattern
|
|
@@ -216,7 +296,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
216
296
|
# [].all? # => true
|
|
217
297
|
#
|
|
218
298
|
# With argument `pattern` and no block, returns whether for each element
|
|
219
|
-
# `element`,
|
|
299
|
+
# `element`, <code>pattern === element</code>:
|
|
220
300
|
#
|
|
221
301
|
# (1..4).all?(Integer) # => true
|
|
222
302
|
# (1..4).all?(Numeric) # => true
|
|
@@ -260,7 +340,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
260
340
|
# [].any? # => false
|
|
261
341
|
#
|
|
262
342
|
# With argument `pattern` and no block, returns whether for any element
|
|
263
|
-
# `element`,
|
|
343
|
+
# `element`, <code>pattern === element</code>:
|
|
264
344
|
#
|
|
265
345
|
# [nil, false, 0].any?(Integer) # => true
|
|
266
346
|
# [nil, false, 0].any?(Numeric) # => true
|
|
@@ -347,8 +427,8 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
347
427
|
# [0, 1, 2].count # => 3
|
|
348
428
|
# {foo: 0, bar: 1, baz: 2}.count # => 3
|
|
349
429
|
#
|
|
350
|
-
# With argument `object` given, returns the number of elements that are
|
|
351
|
-
# `object`:
|
|
430
|
+
# With argument `object` given, returns the number of elements that are
|
|
431
|
+
# <code>==</code> to `object`:
|
|
352
432
|
#
|
|
353
433
|
# [0, 1, 2, 1].count(1) # => 2
|
|
354
434
|
#
|
|
@@ -445,6 +525,17 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
445
525
|
#
|
|
446
526
|
# With no block given, returns an Enumerator.
|
|
447
527
|
#
|
|
528
|
+
# e = (1..4).drop_while
|
|
529
|
+
# p e #=> #<Enumerator: 1..4:drop_while>
|
|
530
|
+
# i = e.next; p i; e.feed(i < 3) #=> 1
|
|
531
|
+
# i = e.next; p i; e.feed(i < 3) #=> 2
|
|
532
|
+
# i = e.next; p i; e.feed(i < 3) #=> 3
|
|
533
|
+
# begin
|
|
534
|
+
# e.next
|
|
535
|
+
# rescue StopIteration
|
|
536
|
+
# p $!.result #=> [3, 4]
|
|
537
|
+
# end
|
|
538
|
+
#
|
|
448
539
|
def drop_while: () { (Elem) -> boolish } -> ::Array[Elem]
|
|
449
540
|
| () -> ::Enumerator[Elem, ::Array[Elem]]
|
|
450
541
|
|
|
@@ -475,8 +566,8 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
475
566
|
# - each_with_index(*args) {|element, i| ..... } -> self
|
|
476
567
|
# - each_with_index(*args) -> enumerator
|
|
477
568
|
# -->
|
|
478
|
-
# Invoke
|
|
479
|
-
# element and its index; returns `self`:
|
|
569
|
+
# Invoke <code>self.each</code> with <code>*args</code>. With a block given, the
|
|
570
|
+
# block receives each element and its index; returns `self`:
|
|
480
571
|
#
|
|
481
572
|
# h = {}
|
|
482
573
|
# (1..4).each_with_index {|element, i| h[element] = i } # => 1..4
|
|
@@ -593,7 +684,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
593
684
|
# `nil` if no such element is found.
|
|
594
685
|
#
|
|
595
686
|
# With argument `object` given, returns the index of the first element that is
|
|
596
|
-
#
|
|
687
|
+
# <code>==</code> `object`:
|
|
597
688
|
#
|
|
598
689
|
# ['a', 'b', 'c', 'b'].find_index('b') # => 1
|
|
599
690
|
#
|
|
@@ -644,7 +735,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
644
735
|
# pattern.
|
|
645
736
|
#
|
|
646
737
|
# With no block given, returns an array containing each element for which
|
|
647
|
-
#
|
|
738
|
+
# <code>pattern === element</code> is `true`:
|
|
648
739
|
#
|
|
649
740
|
# a = ['foo', 'bar', 'car', 'moo']
|
|
650
741
|
# a.grep(/ar/) # => ["bar", "car"]
|
|
@@ -667,11 +758,11 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
667
758
|
# - grep_v(pattern) -> array
|
|
668
759
|
# - grep_v(pattern) {|element| ... } -> array
|
|
669
760
|
# -->
|
|
670
|
-
# Returns an array of objects based on elements of `self` that
|
|
671
|
-
# given pattern.
|
|
761
|
+
# Returns an array of objects based on elements of `self` that <em>don't</em>
|
|
762
|
+
# match the given pattern.
|
|
672
763
|
#
|
|
673
764
|
# With no block given, returns an array containing each element for which
|
|
674
|
-
#
|
|
765
|
+
# <code>pattern === element</code> is `false`:
|
|
675
766
|
#
|
|
676
767
|
# a = ['foo', 'bar', 'car', 'moo']
|
|
677
768
|
# a.grep_v(/ar/) # => ["foo", "moo"]
|
|
@@ -714,7 +805,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
714
805
|
| () -> ::Enumerator[Elem, ::Array[Elem]]
|
|
715
806
|
|
|
716
807
|
# <!-- rdoc-file=enum.c -->
|
|
717
|
-
# Returns whether for any element
|
|
808
|
+
# Returns whether for any element <code>object == element</code>:
|
|
718
809
|
#
|
|
719
810
|
# (1..4).include?(2) # => true
|
|
720
811
|
# (1..4).include?(5) # => false
|
|
@@ -725,7 +816,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
725
816
|
# {foo: 0, bar: 1, baz: 2}.include?('foo') # => false
|
|
726
817
|
# {foo: 0, bar: 1, baz: 2}.include?(0) # => false
|
|
727
818
|
#
|
|
728
|
-
def include?: (
|
|
819
|
+
def include?: (top arg0) -> bool
|
|
729
820
|
|
|
730
821
|
# <!--
|
|
731
822
|
# rdoc-file=enum.c
|
|
@@ -772,13 +863,13 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
772
863
|
# product #=> 24
|
|
773
864
|
#
|
|
774
865
|
# When this runs, the block is first called with `1` (the initial value) and `2`
|
|
775
|
-
# (the first element of the array). The block returns
|
|
776
|
-
# iteration the block is called with `2` (the previous result) and `3`.
|
|
777
|
-
# block returns `6`, and is called one last time with `6` and `4`. The
|
|
778
|
-
# the block, `24` becomes the value returned by `inject`. This code
|
|
779
|
-
# product of the elements in the enumerable.
|
|
866
|
+
# (the first element of the array). The block returns <code>1*2</code>, so on
|
|
867
|
+
# the next iteration the block is called with `2` (the previous result) and `3`.
|
|
868
|
+
# The block returns `6`, and is called one last time with `6` and `4`. The
|
|
869
|
+
# result of the block, `24` becomes the value returned by `inject`. This code
|
|
870
|
+
# returns the product of the elements in the enumerable.
|
|
780
871
|
#
|
|
781
|
-
#
|
|
872
|
+
# <strong>First Shortcut: Default Initial value</strong>
|
|
782
873
|
#
|
|
783
874
|
# In the case of the previous example, the initial value, `1`, wasn't really
|
|
784
875
|
# necessary: the calculation of the product of a list of numbers is
|
|
@@ -815,7 +906,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
815
906
|
# Note that the last line of the block is just the word `counts`. This ensures
|
|
816
907
|
# the return value of the block is the result that's being calculated.
|
|
817
908
|
#
|
|
818
|
-
#
|
|
909
|
+
# <strong>Second Shortcut: a Reducer function</strong>
|
|
819
910
|
#
|
|
820
911
|
# A *reducer function* is a function that takes a partial result and the next
|
|
821
912
|
# value, returning the next partial result. The block that is given to `inject`
|
|
@@ -860,11 +951,11 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
860
951
|
# position = "nnneesw".chars.reduce(Turtle.new, :move)
|
|
861
952
|
# position #=>> #<Turtle:0x00000001052f4698 @y=2, @x=1>
|
|
862
953
|
#
|
|
863
|
-
#
|
|
954
|
+
# <strong>Third Shortcut: Reducer With no Initial Value</strong>
|
|
864
955
|
#
|
|
865
956
|
# If your reducer returns a value that it can accept as a parameter, then you
|
|
866
|
-
# don't have to pass in an initial value. Here
|
|
867
|
-
# function:
|
|
957
|
+
# don't have to pass in an initial value. Here <code>:*</code> is the name of
|
|
958
|
+
# the *times* function:
|
|
868
959
|
#
|
|
869
960
|
# product = [ 2, 3, 4 ].inject(:*)
|
|
870
961
|
# product # => 24
|
|
@@ -895,7 +986,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
895
986
|
# The ordering of equal elements is indeterminate and may be unstable.
|
|
896
987
|
#
|
|
897
988
|
# With no argument and no block, returns the maximum element, using the
|
|
898
|
-
# elements' own method
|
|
989
|
+
# elements' own method <code>#<=></code> for comparison:
|
|
899
990
|
#
|
|
900
991
|
# (1..4).max # => 4
|
|
901
992
|
# (-4..-1).max # => -1
|
|
@@ -915,9 +1006,9 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
915
1006
|
# With a block given, the block determines the maximum elements. The block is
|
|
916
1007
|
# called with two elements `a` and `b`, and must return:
|
|
917
1008
|
#
|
|
918
|
-
# * A negative integer if
|
|
919
|
-
# * Zero if
|
|
920
|
-
# * A positive integer if
|
|
1009
|
+
# * A negative integer if <code>a < b</code>.
|
|
1010
|
+
# * Zero if <code>a == b</code>.
|
|
1011
|
+
# * A positive integer if <code>a > b</code>.
|
|
921
1012
|
#
|
|
922
1013
|
# With a block given and no argument, returns the maximum element as determined
|
|
923
1014
|
# by the block:
|
|
@@ -993,7 +1084,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
993
1084
|
# The ordering of equal elements is indeterminate and may be unstable.
|
|
994
1085
|
#
|
|
995
1086
|
# With no argument and no block, returns the minimum element, using the
|
|
996
|
-
# elements' own method
|
|
1087
|
+
# elements' own method <code>#<=></code> for comparison:
|
|
997
1088
|
#
|
|
998
1089
|
# (1..4).min # => 1
|
|
999
1090
|
# (-4..-1).min # => -4
|
|
@@ -1013,9 +1104,9 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1013
1104
|
# With a block given, the block determines the minimum elements. The block is
|
|
1014
1105
|
# called with two elements `a` and `b`, and must return:
|
|
1015
1106
|
#
|
|
1016
|
-
# * A negative integer if
|
|
1017
|
-
# * Zero if
|
|
1018
|
-
# * A positive integer if
|
|
1107
|
+
# * A negative integer if <code>a < b</code>.
|
|
1108
|
+
# * Zero if <code>a == b</code>.
|
|
1109
|
+
# * A positive integer if <code>a > b</code>.
|
|
1019
1110
|
#
|
|
1020
1111
|
# With a block given and no argument, returns the minimum element as determined
|
|
1021
1112
|
# by the block:
|
|
@@ -1090,7 +1181,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1090
1181
|
# indeterminate and may be unstable.
|
|
1091
1182
|
#
|
|
1092
1183
|
# With no argument and no block, returns the minimum and maximum elements, using
|
|
1093
|
-
# the elements' own method
|
|
1184
|
+
# the elements' own method <code>#<=></code> for comparison:
|
|
1094
1185
|
#
|
|
1095
1186
|
# (1..4).minmax # => [1, 4]
|
|
1096
1187
|
# (-4..-1).minmax # => [-4, -1]
|
|
@@ -1153,7 +1244,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1153
1244
|
# [].none? # => true
|
|
1154
1245
|
#
|
|
1155
1246
|
# With argument `pattern` and no block, returns whether for no element
|
|
1156
|
-
# `element`,
|
|
1247
|
+
# `element`, <code>pattern === element</code>:
|
|
1157
1248
|
#
|
|
1158
1249
|
# [nil, false, 1.1].none?(Integer) # => true
|
|
1159
1250
|
# %w[bar baz bat bam].none?(/m/) # => false
|
|
@@ -1195,7 +1286,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1195
1286
|
# [].one? # => false
|
|
1196
1287
|
#
|
|
1197
1288
|
# With argument `pattern` and no block, returns whether for exactly one element
|
|
1198
|
-
# `element`,
|
|
1289
|
+
# `element`, <code>pattern === element</code>:
|
|
1199
1290
|
#
|
|
1200
1291
|
# [nil, false, 0].one?(Integer) # => true
|
|
1201
1292
|
# [nil, false, 0].one?(Numeric) # => true
|
|
@@ -1306,7 +1397,8 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1306
1397
|
# Returns an array containing the sorted elements of `self`. The ordering of
|
|
1307
1398
|
# equal elements is indeterminate and may be unstable.
|
|
1308
1399
|
#
|
|
1309
|
-
# With no block given, the sort compares using the elements' own method
|
|
1400
|
+
# With no block given, the sort compares using the elements' own method
|
|
1401
|
+
# <code>#<=></code>:
|
|
1310
1402
|
#
|
|
1311
1403
|
# %w[b c a d].sort # => ["a", "b", "c", "d"]
|
|
1312
1404
|
# {foo: 0, bar: 1, baz: 2}.sort # => [[:bar, 1], [:baz, 2], [:foo, 0]]
|
|
@@ -1314,9 +1406,9 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1314
1406
|
# With a block given, comparisons in the block determine the ordering. The block
|
|
1315
1407
|
# is called with two elements `a` and `b`, and must return:
|
|
1316
1408
|
#
|
|
1317
|
-
# * A negative integer if
|
|
1318
|
-
# * Zero if
|
|
1319
|
-
# * A positive integer if
|
|
1409
|
+
# * A negative integer if <code>a < b</code>.
|
|
1410
|
+
# * Zero if <code>a == b</code>.
|
|
1411
|
+
# * A positive integer if <code>a > b</code>.
|
|
1320
1412
|
#
|
|
1321
1413
|
# Examples:
|
|
1322
1414
|
#
|
|
@@ -1364,7 +1456,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1364
1456
|
# b.report("Sort by") { a.sort_by { |a| a } }
|
|
1365
1457
|
# end
|
|
1366
1458
|
#
|
|
1367
|
-
#
|
|
1459
|
+
# <em>produces:</em>
|
|
1368
1460
|
#
|
|
1369
1461
|
# user system total real
|
|
1370
1462
|
# Sort 0.180000 0.000000 0.180000 ( 0.175469)
|
|
@@ -1560,7 +1652,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1560
1652
|
# rdoc-file=enum.c
|
|
1561
1653
|
# - include?(object) -> true or false
|
|
1562
1654
|
# -->
|
|
1563
|
-
# Returns whether for any element
|
|
1655
|
+
# Returns whether for any element <code>object == element</code>:
|
|
1564
1656
|
#
|
|
1565
1657
|
# (1..4).include?(2) # => true
|
|
1566
1658
|
# (1..4).include?(5) # => false
|
|
@@ -1571,7 +1663,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1571
1663
|
# {foo: 0, bar: 1, baz: 2}.include?('foo') # => false
|
|
1572
1664
|
# {foo: 0, bar: 1, baz: 2}.include?(0) # => false
|
|
1573
1665
|
#
|
|
1574
|
-
def member?: (
|
|
1666
|
+
def member?: (top arg0) -> bool
|
|
1575
1667
|
|
|
1576
1668
|
# <!-- rdoc-file=enum.c -->
|
|
1577
1669
|
# Returns the result of applying a reducer to an initial value and the first
|
|
@@ -1612,13 +1704,13 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1612
1704
|
# product #=> 24
|
|
1613
1705
|
#
|
|
1614
1706
|
# When this runs, the block is first called with `1` (the initial value) and `2`
|
|
1615
|
-
# (the first element of the array). The block returns
|
|
1616
|
-
# iteration the block is called with `2` (the previous result) and `3`.
|
|
1617
|
-
# block returns `6`, and is called one last time with `6` and `4`. The
|
|
1618
|
-
# the block, `24` becomes the value returned by `inject`. This code
|
|
1619
|
-
# product of the elements in the enumerable.
|
|
1707
|
+
# (the first element of the array). The block returns <code>1*2</code>, so on
|
|
1708
|
+
# the next iteration the block is called with `2` (the previous result) and `3`.
|
|
1709
|
+
# The block returns `6`, and is called one last time with `6` and `4`. The
|
|
1710
|
+
# result of the block, `24` becomes the value returned by `inject`. This code
|
|
1711
|
+
# returns the product of the elements in the enumerable.
|
|
1620
1712
|
#
|
|
1621
|
-
#
|
|
1713
|
+
# <strong>First Shortcut: Default Initial value</strong>
|
|
1622
1714
|
#
|
|
1623
1715
|
# In the case of the previous example, the initial value, `1`, wasn't really
|
|
1624
1716
|
# necessary: the calculation of the product of a list of numbers is
|
|
@@ -1655,7 +1747,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1655
1747
|
# Note that the last line of the block is just the word `counts`. This ensures
|
|
1656
1748
|
# the return value of the block is the result that's being calculated.
|
|
1657
1749
|
#
|
|
1658
|
-
#
|
|
1750
|
+
# <strong>Second Shortcut: a Reducer function</strong>
|
|
1659
1751
|
#
|
|
1660
1752
|
# A *reducer function* is a function that takes a partial result and the next
|
|
1661
1753
|
# value, returning the next partial result. The block that is given to `inject`
|
|
@@ -1700,11 +1792,11 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1700
1792
|
# position = "nnneesw".chars.reduce(Turtle.new, :move)
|
|
1701
1793
|
# position #=>> #<Turtle:0x00000001052f4698 @y=2, @x=1>
|
|
1702
1794
|
#
|
|
1703
|
-
#
|
|
1795
|
+
# <strong>Third Shortcut: Reducer With no Initial Value</strong>
|
|
1704
1796
|
#
|
|
1705
1797
|
# If your reducer returns a value that it can accept as a parameter, then you
|
|
1706
|
-
# don't have to pass in an initial value. Here
|
|
1707
|
-
# function:
|
|
1798
|
+
# don't have to pass in an initial value. Here <code>:*</code> is the name of
|
|
1799
|
+
# the *times* function:
|
|
1708
1800
|
#
|
|
1709
1801
|
# product = [ 2, 3, 4 ].inject(:*)
|
|
1710
1802
|
# product # => 24
|
|
@@ -1767,7 +1859,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1767
1859
|
# - uniq {|element| ... } -> array
|
|
1768
1860
|
# -->
|
|
1769
1861
|
# With no block, returns a new array containing only unique elements; the array
|
|
1770
|
-
# has no two elements `e0` and `e1` such that
|
|
1862
|
+
# has no two elements `e0` and `e1` such that <code>e0.eql?(e1)</code>:
|
|
1771
1863
|
#
|
|
1772
1864
|
# %w[a b c c b a a b c].uniq # => ["a", "b", "c"]
|
|
1773
1865
|
# [0, 1, 2, 2, 1, 0, 0, 1, 2].uniq # => [0, 1, 2]
|
|
@@ -1794,12 +1886,12 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1794
1886
|
# (1..100).sum(1) # => 5051
|
|
1795
1887
|
# ('a'..'d').sum('foo') # => "fooabcd"
|
|
1796
1888
|
#
|
|
1797
|
-
# Generally, the sum is computed using methods
|
|
1798
|
-
# optimizations, those methods may not be used, and so any
|
|
1799
|
-
# methods may not have effect here.
|
|
1889
|
+
# Generally, the sum is computed using methods <code>+</code> and `each`; for
|
|
1890
|
+
# performance optimizations, those methods may not be used, and so any
|
|
1891
|
+
# redefinition of those methods may not have effect here.
|
|
1800
1892
|
#
|
|
1801
1893
|
# One such optimization: When possible, computes using Gauss's summation formula
|
|
1802
|
-
#
|
|
1894
|
+
# <em>n(n+1)/2</em>:
|
|
1803
1895
|
#
|
|
1804
1896
|
# 100 * (100 + 1) / 2 # => 5050
|
|
1805
1897
|
#
|
|
@@ -1938,8 +2030,8 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1938
2030
|
# - zip(*other_enums) {|array| ... } -> nil
|
|
1939
2031
|
# -->
|
|
1940
2032
|
# With no block given, returns a new array `new_array` of size self.size whose
|
|
1941
|
-
# elements are arrays. Each nested array
|
|
1942
|
-
#
|
|
2033
|
+
# elements are arrays. Each nested array <code>new_array[n]</code> is of size
|
|
2034
|
+
# <code>other_enums.size+1</code>, and contains:
|
|
1943
2035
|
#
|
|
1944
2036
|
# * The `n`-th element of self.
|
|
1945
2037
|
# * The `n`-th element of each of the `other_enums`.
|
|
@@ -1963,8 +2055,8 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
1963
2055
|
# # [[:baz, 2], [:gaz, 5], [:haz, 8]]
|
|
1964
2056
|
# # ]
|
|
1965
2057
|
#
|
|
1966
|
-
# If any enumerable in other_enums is smaller than self, fills to
|
|
1967
|
-
# with `nil`:
|
|
2058
|
+
# If any enumerable in other_enums is smaller than self, fills to
|
|
2059
|
+
# <code>self.size</code> with `nil`:
|
|
1968
2060
|
#
|
|
1969
2061
|
# a = [:a0, :a1, :a2, :a3]
|
|
1970
2062
|
# b = [:b0, :b1, :b2]
|
|
@@ -2048,8 +2140,8 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
2048
2140
|
# ["E", 8736]
|
|
2049
2141
|
# ["F", 6860]
|
|
2050
2142
|
#
|
|
2051
|
-
# You can use the special symbol
|
|
2052
|
-
# separate
|
|
2143
|
+
# You can use the special symbol <code>:_alone</code> to force an element into
|
|
2144
|
+
# its own separate chunk:
|
|
2053
2145
|
#
|
|
2054
2146
|
# a = [0, 0, 1, 1]
|
|
2055
2147
|
# e = a.chunk{|i| i.even? ? :_alone : true }
|
|
@@ -2064,8 +2156,8 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
2064
2156
|
# }
|
|
2065
2157
|
# }
|
|
2066
2158
|
#
|
|
2067
|
-
# You can use the special symbol
|
|
2068
|
-
# be ignored (not included in any chunk):
|
|
2159
|
+
# You can use the special symbol <code>:_separator</code> or `nil` to force an
|
|
2160
|
+
# element to be ignored (not included in any chunk):
|
|
2069
2161
|
#
|
|
2070
2162
|
# a = [0, 0, -1, 1, 1]
|
|
2071
2163
|
# e = a.chunk{|i| i < 0 ? :_separator : true }
|
|
@@ -2227,11 +2319,11 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
2227
2319
|
# Creates an enumerator for each chunked elements. The ends of chunks are
|
|
2228
2320
|
# defined by *pattern* and the block.
|
|
2229
2321
|
#
|
|
2230
|
-
# If
|
|
2231
|
-
# element, the element is end of a chunk.
|
|
2322
|
+
# If <code>_pattern_ === _elt_</code> returns `true` or the block returns `true`
|
|
2323
|
+
# for the element, the element is end of a chunk.
|
|
2232
2324
|
#
|
|
2233
|
-
# The
|
|
2234
|
-
# *enum*.
|
|
2325
|
+
# The <code>===</code> and *block* is called from the first element to the last
|
|
2326
|
+
# element of *enum*.
|
|
2235
2327
|
#
|
|
2236
2328
|
# The result enumerator yields the chunked elements as an array. So `each`
|
|
2237
2329
|
# method can be called as follows:
|
|
@@ -2262,7 +2354,7 @@ module Enumerable[unchecked out Elem] : _Each[Elem]
|
|
|
2262
2354
|
# -->
|
|
2263
2355
|
# With argument `pattern`, returns an enumerator that uses the pattern to
|
|
2264
2356
|
# partition elements into arrays ("slices"). An element begins a new slice if
|
|
2265
|
-
#
|
|
2357
|
+
# <code>element === pattern</code> (or if it is the first element).
|
|
2266
2358
|
#
|
|
2267
2359
|
# a = %w[foo bar fop for baz fob fog bam foy]
|
|
2268
2360
|
# e = a.slice_before(/ba/) # => #<Enumerator: ...>
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
# <!-- rdoc-file=enumerator.c -->
|
|
2
|
+
# Enumerator::ArithmeticSequence is a subclass of Enumerator, that is a
|
|
3
|
+
# representation of sequences of numbers with common difference. Instances of
|
|
4
|
+
# this class can be generated by the Range#step and Numeric#step methods.
|
|
5
|
+
#
|
|
6
|
+
# The class can be used for slicing Array (see Array#slice) or custom
|
|
7
|
+
# collections.
|
|
8
|
+
#
|
|
9
|
+
class Enumerator::ArithmeticSequence < Enumerator[Numeric]
|
|
10
|
+
# <!--
|
|
11
|
+
# rdoc-file=enumerator.c
|
|
12
|
+
# - aseq.begin -> num or nil
|
|
13
|
+
# -->
|
|
14
|
+
# Returns the number that defines the first element of this arithmetic sequence.
|
|
15
|
+
#
|
|
16
|
+
def begin: () -> Numeric?
|
|
17
|
+
|
|
18
|
+
# <!--
|
|
19
|
+
# rdoc-file=enumerator.c
|
|
20
|
+
# - aseq.end -> num or nil
|
|
21
|
+
# -->
|
|
22
|
+
# Returns the number that defines the end of this arithmetic sequence.
|
|
23
|
+
#
|
|
24
|
+
def end: () -> Numeric?
|
|
25
|
+
|
|
26
|
+
# <!--
|
|
27
|
+
# rdoc-file=enumerator.c
|
|
28
|
+
# - aseq.each {|i| block } -> aseq
|
|
29
|
+
# - aseq.each -> aseq
|
|
30
|
+
# -->
|
|
31
|
+
#
|
|
32
|
+
def each: () ?{ (Numeric) -> void } -> self
|
|
33
|
+
|
|
34
|
+
# <!--
|
|
35
|
+
# rdoc-file=enumerator.c
|
|
36
|
+
# - aseq.exclude_end? -> true or false
|
|
37
|
+
# -->
|
|
38
|
+
# Returns `true` if this arithmetic sequence excludes its end value.
|
|
39
|
+
#
|
|
40
|
+
def exclude_end?: () -> bool
|
|
41
|
+
|
|
42
|
+
# <!--
|
|
43
|
+
# rdoc-file=enumerator.c
|
|
44
|
+
# - aseq.last -> num or nil
|
|
45
|
+
# - aseq.last(n) -> an_array
|
|
46
|
+
# -->
|
|
47
|
+
# Returns the last number in this arithmetic sequence, or an array of the last
|
|
48
|
+
# `n` elements.
|
|
49
|
+
#
|
|
50
|
+
def last: () -> Numeric?
|
|
51
|
+
| (Integer n) -> Array[Numeric]
|
|
52
|
+
|
|
53
|
+
# <!--
|
|
54
|
+
# rdoc-file=enumerator.c
|
|
55
|
+
# - aseq.size -> num or nil
|
|
56
|
+
# -->
|
|
57
|
+
# Returns the number of elements in this arithmetic sequence if it is a finite
|
|
58
|
+
# sequence. Otherwise, returns `nil`.
|
|
59
|
+
#
|
|
60
|
+
def size: () -> (Integer | Float)
|
|
61
|
+
|
|
62
|
+
# <!--
|
|
63
|
+
# rdoc-file=enumerator.c
|
|
64
|
+
# - aseq.step -> num
|
|
65
|
+
# -->
|
|
66
|
+
# Returns the number that defines the common difference between two adjacent
|
|
67
|
+
# elements in this arithmetic sequence.
|
|
68
|
+
#
|
|
69
|
+
def step: () -> Numeric
|
|
70
|
+
end
|