Commit e2bab8c7 authored by Yukihiro "Matz" Matsumoto's avatar Yukihiro "Matz" Matsumoto

Merge pull request #1925 from ksss/hash-reject

Hash#{reject,reject!} support return Enumerator
parents b0f10b5c d9068f05
......@@ -508,6 +508,20 @@ assert 'Hash#select!' do
assert_equal({3=>4}, h)
end
assert 'Hash#reject' do
h = {1=>2,3=>4,5=>6}
hret = h.reject.with_index {|a,b| a[1] == 4}
assert_equal({1=>2,5=>6}, hret)
assert_equal({1=>2,3=>4,5=>6}, h)
end
assert 'Hash#reject!' do
h = {1=>2,3=>4,5=>6}
hret = h.reject!.with_index {|a,b| a[1] == 4}
assert_equal h, hret
assert_equal({1=>2,5=>6}, h)
end
assert 'Range#each' do
a = (1..5)
b = a.each
......
......@@ -134,10 +134,12 @@ class Hash
# 1.8/1.9 Hash#reject! returns Hash; ISO says nothing.
def reject!(&b)
return to_enum :reject! unless block_given?
keys = []
self.each_key{|k|
v = self[k]
if b.call(k, v)
if b.call([k, v])
keys.push(k)
end
}
......@@ -150,10 +152,12 @@ class Hash
# 1.8/1.9 Hash#reject returns Hash; ISO says nothing.
def reject(&b)
return to_enum :reject unless block_given?
h = {}
self.each_key{|k|
v = self[k]
unless b.call(k, v)
unless b.call([k, v])
h[k] = v
end
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment