diff options
| author | Jun Hiroe <[email protected]> | 2014-04-21 01:35:00 +0900 |
|---|---|---|
| committer | Jun Hiroe <[email protected]> | 2014-04-21 01:40:39 +0900 |
| commit | 931414305ade73e3fa100a7bbf463db6c48881e4 (patch) | |
| tree | 3743b6d715125ffe1ac25d46a4cf1113cb7521dc /mrbgems | |
| parent | 791631ad4e8224475604322600a805f3cdae65f9 (diff) | |
| download | mruby-931414305ade73e3fa100a7bbf463db6c48881e4.tar.gz mruby-931414305ade73e3fa100a7bbf463db6c48881e4.zip | |
Add Array#delete_if
Diffstat (limited to 'mrbgems')
| -rw-r--r-- | mrbgems/mruby-array-ext/mrblib/array.rb | 31 | ||||
| -rw-r--r-- | mrbgems/mruby-array-ext/test/array.rb | 14 |
2 files changed, 45 insertions, 0 deletions
diff --git a/mrbgems/mruby-array-ext/mrblib/array.rb b/mrbgems/mruby-array-ext/mrblib/array.rb index 6c47235fe..43d77b5f6 100644 --- a/mrbgems/mruby-array-ext/mrblib/array.rb +++ b/mrbgems/mruby-array-ext/mrblib/array.rb @@ -425,4 +425,35 @@ class Array def rotate!(count=1) self.replace(self.rotate(count)) end + + ## + # call-seq: + # ary.delete_if { |item| block } -> ary + # ary.delete_if -> Enumerator + # + # Deletes every element of +self+ for which block evaluates to +true+. + # + # The array is changed instantly every time the block is called, not after + # the iteration is over. + # + # See also Array#reject! + # + # If no block is given, an Enumerator is returned instead. + # + # scores = [ 97, 42, 75 ] + # scores.delete_if {|score| score < 80 } #=> [97] + + def delete_if(&block) + return to_enum :delete_if unless block_given? + + idx = 0 + while idx < self.size do + if block.call(self[idx]) + self.delete_at(idx) + else + idx += 1 + end + end + self + end end diff --git a/mrbgems/mruby-array-ext/test/array.rb b/mrbgems/mruby-array-ext/test/array.rb index d157a5b4d..1fdfabe49 100644 --- a/mrbgems/mruby-array-ext/test/array.rb +++ b/mrbgems/mruby-array-ext/test/array.rb @@ -169,3 +169,17 @@ assert("Array#rotate!") do assert_equal ["c", "d", "a", "b"], a.rotate(10) assert_equal [], [].rotate! end + +assert("Array#delete_if") do + a = [1, 2, 3, 4, 5] + assert_equal [1, 2, 3, 4, 5], a.delete_if { false } + assert_equal [1, 2, 3, 4, 5], a + + a = [1, 2, 3, 4, 5] + assert_equal [], a.delete_if { true } + assert_equal [], a + + a = [1, 2, 3, 4, 5] + assert_equal [1, 2, 3], a.delete_if { |i| i > 3 } + assert_equal [1, 2, 3], a +end |
