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.
Files changed (281) hide show
  1. checksums.yaml +4 -4
  2. data/.github/dependabot.yml +14 -14
  3. data/.github/workflows/bundle-update.yml +60 -0
  4. data/.github/workflows/c-check.yml +18 -11
  5. data/.github/workflows/comments.yml +5 -3
  6. data/.github/workflows/dependabot.yml +2 -2
  7. data/.github/workflows/ruby.yml +27 -34
  8. data/.github/workflows/rust.yml +95 -0
  9. data/.github/workflows/typecheck.yml +2 -2
  10. data/.github/workflows/windows.yml +2 -2
  11. data/.rubocop.yml +1 -1
  12. data/CHANGELOG.md +323 -0
  13. data/README.md +1 -1
  14. data/Rakefile +43 -33
  15. data/Steepfile +1 -0
  16. data/config.yml +426 -24
  17. data/core/array.rbs +307 -227
  18. data/core/basic_object.rbs +9 -8
  19. data/core/binding.rbs +0 -2
  20. data/core/builtin.rbs +2 -2
  21. data/core/class.rbs +6 -5
  22. data/core/comparable.rbs +55 -34
  23. data/core/complex.rbs +104 -78
  24. data/core/dir.rbs +61 -49
  25. data/core/encoding.rbs +12 -15
  26. data/core/enumerable.rbs +179 -87
  27. data/core/enumerator/arithmetic_sequence.rbs +70 -0
  28. data/core/enumerator.rbs +65 -2
  29. data/core/errno.rbs +11 -2
  30. data/core/errors.rbs +58 -29
  31. data/core/exception.rbs +13 -13
  32. data/core/fiber.rbs +74 -54
  33. data/core/file.rbs +280 -177
  34. data/core/file_test.rbs +3 -3
  35. data/core/float.rbs +257 -92
  36. data/core/gc.rbs +425 -281
  37. data/core/hash.rbs +1045 -739
  38. data/core/integer.rbs +135 -137
  39. data/core/io/buffer.rbs +53 -42
  40. data/core/io/wait.rbs +13 -35
  41. data/core/io.rbs +192 -144
  42. data/core/kernel.rbs +216 -155
  43. data/core/marshal.rbs +4 -4
  44. data/core/match_data.rbs +15 -13
  45. data/core/math.rbs +107 -66
  46. data/core/method.rbs +69 -33
  47. data/core/module.rbs +244 -106
  48. data/core/nil_class.rbs +7 -6
  49. data/core/numeric.rbs +74 -63
  50. data/core/object.rbs +9 -11
  51. data/core/object_space.rbs +30 -23
  52. data/core/pathname.rbs +1322 -0
  53. data/core/proc.rbs +95 -58
  54. data/core/process.rbs +222 -202
  55. data/core/ractor.rbs +371 -515
  56. data/core/random.rbs +21 -3
  57. data/core/range.rbs +159 -57
  58. data/core/rational.rbs +60 -89
  59. data/core/rbs/unnamed/argf.rbs +60 -53
  60. data/core/rbs/unnamed/env_class.rbs +19 -14
  61. data/core/rbs/unnamed/main_class.rbs +123 -0
  62. data/core/rbs/unnamed/random.rbs +11 -118
  63. data/core/regexp.rbs +258 -214
  64. data/core/ruby.rbs +53 -0
  65. data/core/ruby_vm.rbs +38 -34
  66. data/core/rubygems/config_file.rbs +5 -5
  67. data/core/rubygems/errors.rbs +4 -71
  68. data/core/rubygems/requirement.rbs +5 -5
  69. data/core/rubygems/rubygems.rbs +16 -82
  70. data/core/rubygems/version.rbs +2 -3
  71. data/core/set.rbs +490 -360
  72. data/core/signal.rbs +26 -16
  73. data/core/string.rbs +3234 -1285
  74. data/core/struct.rbs +27 -26
  75. data/core/symbol.rbs +41 -34
  76. data/core/thread.rbs +135 -67
  77. data/core/time.rbs +81 -50
  78. data/core/trace_point.rbs +41 -35
  79. data/core/true_class.rbs +2 -2
  80. data/core/unbound_method.rbs +24 -16
  81. data/core/warning.rbs +7 -7
  82. data/docs/aliases.md +79 -0
  83. data/docs/collection.md +3 -3
  84. data/docs/config.md +171 -0
  85. data/docs/encoding.md +56 -0
  86. data/docs/gem.md +0 -1
  87. data/docs/inline.md +576 -0
  88. data/docs/sigs.md +3 -3
  89. data/docs/syntax.md +46 -16
  90. data/docs/type_fingerprint.md +21 -0
  91. data/exe/rbs +1 -1
  92. data/ext/rbs_extension/ast_translation.c +544 -116
  93. data/ext/rbs_extension/ast_translation.h +3 -0
  94. data/ext/rbs_extension/class_constants.c +16 -2
  95. data/ext/rbs_extension/class_constants.h +8 -0
  96. data/ext/rbs_extension/extconf.rb +5 -1
  97. data/ext/rbs_extension/legacy_location.c +33 -56
  98. data/ext/rbs_extension/legacy_location.h +37 -0
  99. data/ext/rbs_extension/main.c +44 -35
  100. data/include/rbs/ast.h +448 -173
  101. data/include/rbs/defines.h +27 -0
  102. data/include/rbs/lexer.h +30 -11
  103. data/include/rbs/location.h +25 -44
  104. data/include/rbs/parser.h +6 -6
  105. data/include/rbs/string.h +0 -2
  106. data/include/rbs/util/rbs_allocator.h +34 -13
  107. data/include/rbs/util/rbs_assert.h +12 -1
  108. data/include/rbs/util/rbs_constant_pool.h +0 -3
  109. data/include/rbs/util/rbs_encoding.h +2 -0
  110. data/include/rbs/util/rbs_unescape.h +2 -1
  111. data/include/rbs.h +8 -0
  112. data/lib/rbs/ast/annotation.rb +1 -1
  113. data/lib/rbs/ast/comment.rb +1 -1
  114. data/lib/rbs/ast/declarations.rb +10 -10
  115. data/lib/rbs/ast/members.rb +14 -14
  116. data/lib/rbs/ast/ruby/annotations.rb +293 -3
  117. data/lib/rbs/ast/ruby/comment_block.rb +24 -0
  118. data/lib/rbs/ast/ruby/declarations.rb +198 -3
  119. data/lib/rbs/ast/ruby/helpers/constant_helper.rb +4 -0
  120. data/lib/rbs/ast/ruby/members.rb +532 -22
  121. data/lib/rbs/ast/type_param.rb +24 -4
  122. data/lib/rbs/buffer.rb +20 -15
  123. data/lib/rbs/cli/diff.rb +16 -15
  124. data/lib/rbs/cli/validate.rb +38 -106
  125. data/lib/rbs/cli.rb +52 -19
  126. data/lib/rbs/collection/config/lockfile_generator.rb +14 -2
  127. data/lib/rbs/collection/sources/git.rb +1 -0
  128. data/lib/rbs/definition.rb +1 -1
  129. data/lib/rbs/definition_builder/ancestor_builder.rb +62 -9
  130. data/lib/rbs/definition_builder/method_builder.rb +20 -0
  131. data/lib/rbs/definition_builder.rb +147 -25
  132. data/lib/rbs/diff.rb +7 -1
  133. data/lib/rbs/environment.rb +227 -74
  134. data/lib/rbs/environment_loader.rb +0 -6
  135. data/lib/rbs/errors.rb +27 -18
  136. data/lib/rbs/inline_parser.rb +342 -6
  137. data/lib/rbs/location_aux.rb +1 -1
  138. data/lib/rbs/locator.rb +5 -1
  139. data/lib/rbs/method_type.rb +5 -3
  140. data/lib/rbs/parser_aux.rb +20 -7
  141. data/lib/rbs/prototype/helpers.rb +57 -0
  142. data/lib/rbs/prototype/rb.rb +3 -28
  143. data/lib/rbs/prototype/rbi.rb +3 -20
  144. data/lib/rbs/prototype/runtime.rb +8 -0
  145. data/lib/rbs/resolver/constant_resolver.rb +2 -2
  146. data/lib/rbs/resolver/type_name_resolver.rb +116 -38
  147. data/lib/rbs/subtractor.rb +3 -1
  148. data/lib/rbs/test/type_check.rb +19 -2
  149. data/lib/rbs/type_name.rb +1 -1
  150. data/lib/rbs/types.rb +88 -78
  151. data/lib/rbs/unit_test/type_assertions.rb +35 -8
  152. data/lib/rbs/validator.rb +2 -2
  153. data/lib/rbs/version.rb +1 -1
  154. data/lib/rbs.rb +1 -2
  155. data/lib/rdoc/discover.rb +1 -1
  156. data/lib/rdoc_plugin/parser.rb +1 -1
  157. data/rbs.gemspec +4 -3
  158. data/rust/.gitignore +1 -0
  159. data/rust/Cargo.lock +378 -0
  160. data/rust/Cargo.toml +7 -0
  161. data/rust/ruby-rbs/Cargo.toml +22 -0
  162. data/rust/ruby-rbs/build.rs +764 -0
  163. data/rust/ruby-rbs/examples/locations.rs +60 -0
  164. data/rust/ruby-rbs/src/lib.rs +1 -0
  165. data/rust/ruby-rbs/src/node/mod.rs +742 -0
  166. data/rust/ruby-rbs/tests/sanity.rs +47 -0
  167. data/rust/ruby-rbs/vendor/rbs/config.yml +1 -0
  168. data/rust/ruby-rbs-sys/Cargo.toml +23 -0
  169. data/rust/ruby-rbs-sys/build.rs +204 -0
  170. data/rust/ruby-rbs-sys/src/lib.rs +50 -0
  171. data/rust/ruby-rbs-sys/vendor/rbs/include +1 -0
  172. data/rust/ruby-rbs-sys/vendor/rbs/src +1 -0
  173. data/rust/ruby-rbs-sys/wrapper.h +1 -0
  174. data/schema/typeParam.json +17 -1
  175. data/sig/ast/ruby/annotations.rbs +315 -4
  176. data/sig/ast/ruby/comment_block.rbs +8 -0
  177. data/sig/ast/ruby/declarations.rbs +102 -4
  178. data/sig/ast/ruby/members.rbs +108 -2
  179. data/sig/cli/diff.rbs +5 -11
  180. data/sig/cli/validate.rbs +12 -8
  181. data/sig/cli.rbs +18 -18
  182. data/sig/definition.rbs +6 -1
  183. data/sig/definition_builder.rbs +2 -0
  184. data/sig/environment.rbs +70 -12
  185. data/sig/errors.rbs +13 -14
  186. data/sig/inline_parser.rbs +39 -2
  187. data/sig/locator.rbs +0 -2
  188. data/sig/manifest.yaml +0 -1
  189. data/sig/method_builder.rbs +3 -1
  190. data/sig/parser.rbs +31 -13
  191. data/sig/prototype/helpers.rbs +2 -0
  192. data/sig/resolver/type_name_resolver.rbs +35 -7
  193. data/sig/source.rbs +3 -3
  194. data/sig/type_param.rbs +13 -8
  195. data/sig/types.rbs +6 -7
  196. data/sig/unit_test/spy.rbs +0 -8
  197. data/sig/unit_test/type_assertions.rbs +11 -0
  198. data/src/ast.c +410 -153
  199. data/src/lexer.c +1392 -1313
  200. data/src/lexer.re +3 -0
  201. data/src/lexstate.c +58 -37
  202. data/src/location.c +8 -48
  203. data/src/parser.c +977 -516
  204. data/src/string.c +0 -48
  205. data/src/util/rbs_allocator.c +89 -71
  206. data/src/util/rbs_assert.c +1 -1
  207. data/src/util/rbs_buffer.c +2 -2
  208. data/src/util/rbs_constant_pool.c +10 -14
  209. data/src/util/rbs_encoding.c +4 -8
  210. data/src/util/rbs_unescape.c +56 -20
  211. data/stdlib/bigdecimal/0/big_decimal.rbs +116 -98
  212. data/stdlib/bigdecimal-math/0/big_math.rbs +169 -8
  213. data/stdlib/cgi/0/core.rbs +9 -393
  214. data/stdlib/cgi/0/manifest.yaml +1 -0
  215. data/stdlib/cgi-escape/0/escape.rbs +171 -0
  216. data/stdlib/coverage/0/coverage.rbs +7 -4
  217. data/stdlib/date/0/date.rbs +92 -79
  218. data/stdlib/date/0/date_time.rbs +25 -24
  219. data/stdlib/delegate/0/delegator.rbs +10 -7
  220. data/stdlib/did_you_mean/0/did_you_mean.rbs +17 -16
  221. data/stdlib/digest/0/digest.rbs +110 -0
  222. data/stdlib/erb/0/erb.rbs +748 -347
  223. data/stdlib/etc/0/etc.rbs +55 -50
  224. data/stdlib/fileutils/0/fileutils.rbs +158 -139
  225. data/stdlib/forwardable/0/forwardable.rbs +13 -10
  226. data/stdlib/io-console/0/io-console.rbs +2 -2
  227. data/stdlib/json/0/json.rbs +217 -136
  228. data/stdlib/monitor/0/monitor.rbs +3 -3
  229. data/stdlib/net-http/0/net-http.rbs +162 -134
  230. data/stdlib/objspace/0/objspace.rbs +17 -34
  231. data/stdlib/open-uri/0/open-uri.rbs +48 -8
  232. data/stdlib/open3/0/open3.rbs +469 -10
  233. data/stdlib/openssl/0/openssl.rbs +475 -357
  234. data/stdlib/optparse/0/optparse.rbs +26 -17
  235. data/stdlib/pathname/0/pathname.rbs +11 -1381
  236. data/stdlib/pp/0/pp.rbs +9 -8
  237. data/stdlib/prettyprint/0/prettyprint.rbs +7 -7
  238. data/stdlib/pstore/0/pstore.rbs +35 -30
  239. data/stdlib/psych/0/psych.rbs +65 -12
  240. data/stdlib/psych/0/store.rbs +2 -4
  241. data/stdlib/pty/0/pty.rbs +9 -6
  242. data/stdlib/random-formatter/0/random-formatter.rbs +277 -0
  243. data/stdlib/rdoc/0/code_object.rbs +2 -1
  244. data/stdlib/rdoc/0/parser.rbs +1 -1
  245. data/stdlib/rdoc/0/rdoc.rbs +1 -1
  246. data/stdlib/rdoc/0/store.rbs +1 -1
  247. data/stdlib/resolv/0/resolv.rbs +25 -68
  248. data/stdlib/ripper/0/ripper.rbs +22 -19
  249. data/stdlib/securerandom/0/manifest.yaml +2 -0
  250. data/stdlib/securerandom/0/securerandom.rbs +7 -20
  251. data/stdlib/shellwords/0/shellwords.rbs +2 -2
  252. data/stdlib/singleton/0/singleton.rbs +3 -0
  253. data/stdlib/socket/0/addrinfo.rbs +7 -7
  254. data/stdlib/socket/0/basic_socket.rbs +3 -3
  255. data/stdlib/socket/0/ip_socket.rbs +10 -8
  256. data/stdlib/socket/0/socket.rbs +23 -10
  257. data/stdlib/socket/0/tcp_server.rbs +1 -1
  258. data/stdlib/socket/0/tcp_socket.rbs +11 -3
  259. data/stdlib/socket/0/udp_socket.rbs +1 -1
  260. data/stdlib/socket/0/unix_server.rbs +1 -1
  261. data/stdlib/stringio/0/stringio.rbs +1177 -85
  262. data/stdlib/strscan/0/string_scanner.rbs +27 -25
  263. data/stdlib/tempfile/0/tempfile.rbs +25 -21
  264. data/stdlib/time/0/time.rbs +8 -6
  265. data/stdlib/timeout/0/timeout.rbs +63 -7
  266. data/stdlib/tsort/0/cyclic.rbs +3 -0
  267. data/stdlib/tsort/0/tsort.rbs +7 -6
  268. data/stdlib/uri/0/common.rbs +42 -20
  269. data/stdlib/uri/0/file.rbs +3 -3
  270. data/stdlib/uri/0/generic.rbs +26 -18
  271. data/stdlib/uri/0/http.rbs +2 -2
  272. data/stdlib/uri/0/ldap.rbs +2 -2
  273. data/stdlib/uri/0/mailto.rbs +3 -3
  274. data/stdlib/uri/0/rfc2396_parser.rbs +12 -12
  275. data/stdlib/zlib/0/deflate.rbs +4 -3
  276. data/stdlib/zlib/0/gzip_reader.rbs +6 -6
  277. data/stdlib/zlib/0/gzip_writer.rbs +14 -12
  278. data/stdlib/zlib/0/inflate.rbs +1 -1
  279. data/stdlib/zlib/0/need_dict.rbs +1 -1
  280. data/stdlib/zlib/0/zstream.rbs +1 -0
  281. 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 `self == object`,
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
- # *Leading, trailing, or all elements*:
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 `#<=>` or a given block.
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 `#<=>` or a given block.
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
- # *Groups, slices, and partitions*:
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 `#<=>` or the given block.
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 returned
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 `#each` which must yield successive elements of the
135
- # collection. The method will be called by almost any Enumerable method.
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 `#each` in the including
177
- # class:
178
+ # Virtually all methods in Enumerable call method <code>#each</code> in the
179
+ # including class:
178
180
  #
179
- # * `Hash#each` yields the next key-value pair as a 2-element Array.
180
- # * `Struct#each` yields the next name-value pair as a 2-element Array.
181
- # * For the other classes above, `#each` yields the next object from the
182
- # collection.
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`, `pattern === 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`, `pattern === 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 `==` to
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 `self.each` with `*args`. With a block given, the block receives each
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
- # `==` `object`:
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
- # `pattern === element` is `true`:
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 *don't* match the
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
- # `pattern === element` is `false`:
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 `object == 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?: (Elem arg0) -> bool
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 `1*2`, so on the next
776
- # iteration the block is called with `2` (the previous result) and `3`. The
777
- # block returns `6`, and is called one last time with `6` and `4`. The result of
778
- # the block, `24` becomes the value returned by `inject`. This code returns the
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
- # **First Shortcut: Default Initial value**
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
- # **Second Shortcut: a Reducer function**
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
- # **Third Shortcut: Reducer With no Initial Value**
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 `:*` is the name of the *times*
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 `#<=>` for comparison:
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 `a < b`.
919
- # * Zero if `a == b`.
920
- # * A positive integer if `a > b`.
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 `#<=>` for comparison:
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 `a < b`.
1017
- # * Zero if `a == b`.
1018
- # * A positive integer if `a > b`.
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 `#<=>` for comparison:
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`, `pattern === 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`, `pattern === 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 `a < b`.
1318
- # * Zero if `a == b`.
1319
- # * A positive integer if `a > b`.
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
- # *produces:*
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 `object == 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?: (Elem arg0) -> bool
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 `1*2`, so on the next
1616
- # iteration the block is called with `2` (the previous result) and `3`. The
1617
- # block returns `6`, and is called one last time with `6` and `4`. The result of
1618
- # the block, `24` becomes the value returned by `inject`. This code returns the
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
- # **First Shortcut: Default Initial value**
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
- # **Second Shortcut: a Reducer function**
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
- # **Third Shortcut: Reducer With no Initial Value**
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 `:*` is the name of the *times*
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 `e0.eql?(e1)`:
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 `+` and `each`; for performance
1798
- # optimizations, those methods may not be used, and so any redefinition of those
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
- # *n(n+1)/2*:
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 `new_array[n]` is of size
1942
- # `other_enums.size+1`, and contains:
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 `self.size`
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 `:_alone` to force an element into its own
2052
- # separate chuck:
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 `:_separator` or `nil` to force an element to
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 *`pattern* === *elt`* returns `true` or the block returns `true` for the
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 `===` and *block* is called from the first element to the last element of
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
- # `element === pattern` (or if it is the first element).
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