summaryrefslogtreecommitdiffhomepage
path: root/mrbgems/mruby-array-ext/mrblib
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2014-04-21 14:49:03 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2014-04-21 14:49:03 +0900
commit6ec04a4e782589266105fdaef6b61bd98e0d5851 (patch)
tree9500ec081bb607778c2bb8b005128f9f3ee2ff3f /mrbgems/mruby-array-ext/mrblib
parente7f5cd7d4e21fe70aac62297c97e4ae70fad1e5f (diff)
parentfcfab845602e25520e51f60ad33e4eb16dd58395 (diff)
downloadmruby-6ec04a4e782589266105fdaef6b61bd98e0d5851.tar.gz
mruby-6ec04a4e782589266105fdaef6b61bd98e0d5851.zip
Merge pull request #2098 from suzukaze/add-array.reject_bang
Add Array#reject!
Diffstat (limited to 'mrbgems/mruby-array-ext/mrblib')
-rw-r--r--mrbgems/mruby-array-ext/mrblib/array.rb34
1 files changed, 34 insertions, 0 deletions
diff --git a/mrbgems/mruby-array-ext/mrblib/array.rb b/mrbgems/mruby-array-ext/mrblib/array.rb
index 43d77b5f6..78d9ff78a 100644
--- a/mrbgems/mruby-array-ext/mrblib/array.rb
+++ b/mrbgems/mruby-array-ext/mrblib/array.rb
@@ -456,4 +456,38 @@ class Array
end
self
end
+
+ ##
+ # call-seq:
+ # ary.reject! { |item| block } -> ary or nil
+ # ary.reject! -> Enumerator
+ #
+ # Equivalent to Array#delete_if, deleting elements from +self+ for which the
+ # block evaluates to +true+, but returns +nil+ if no changes were made.
+ #
+ # The array is changed instantly every time the block is called, not after
+ # the iteration is over.
+ #
+ # See also Enumerable#reject and Array#delete_if.
+ #
+ # If no block is given, an Enumerator is returned instead.
+
+ def reject!(&block)
+ return to_enum :reject! unless block_given?
+
+ len = self.size
+ idx = 0
+ while idx < self.size do
+ if block.call(self[idx])
+ self.delete_at(idx)
+ else
+ idx += 1
+ end
+ end
+ if self.size == len
+ nil
+ else
+ self
+ end
+ end
end