diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2019-09-02 16:50:47 +0900 |
|---|---|---|
| committer | GitHub <[email protected]> | 2019-09-02 16:50:47 +0900 |
| commit | 148fffa21ad5cbf42526ce393d24cb214167a82e (patch) | |
| tree | 25de63eda5eff0df6402921efbbc354c511f8c9b /mrbgems/mruby-enum-chain/mrblib | |
| parent | aea5880c10af262957e597cf875f38461c2c54e3 (diff) | |
| parent | 66211394e1597e403f14aada81a993f5b1429066 (diff) | |
| download | mruby-148fffa21ad5cbf42526ce393d24cb214167a82e.tar.gz mruby-148fffa21ad5cbf42526ce393d24cb214167a82e.zip | |
Merge pull request #4683 from shuujii/enumeratorChain-rewind-shouldnt-rewind-elements-arent-iterated
`Enumerator::Chain#rewind` shouldn't rewind elements aren't iterated
Diffstat (limited to 'mrbgems/mruby-enum-chain/mrblib')
| -rw-r--r-- | mrbgems/mruby-enum-chain/mrblib/chain.rb | 19 |
1 files changed, 12 insertions, 7 deletions
diff --git a/mrbgems/mruby-enum-chain/mrblib/chain.rb b/mrbgems/mruby-enum-chain/mrblib/chain.rb index 55474eb92..43d0926c8 100644 --- a/mrbgems/mruby-enum-chain/mrblib/chain.rb +++ b/mrbgems/mruby-enum-chain/mrblib/chain.rb @@ -17,13 +17,19 @@ class Enumerator include Enumerable def initialize(*args) - @enums = args + @enums = args.freeze + @pos = -1 end def each(&block) - return to_enum unless block_given? + return to_enum unless block - @enums.each { |e| e.each(&block) } + i = 0 + while i < @enums.size + @pos = i + @enums[i].each(&block) + i += 1 + end self end @@ -36,11 +42,10 @@ class Enumerator end def rewind - i = @enums.size - 1 - while 0 <= i - e = @enums[i] + while 0 <= @pos && @pos < @enums.size + e = @enums[@pos] e.rewind if e.respond_to?(:rewind) - i -= 1 + @pos -= 1 end self |
