Skip to content

Commit

Permalink
RUBY-265 semantics should == Hash#reject!
Browse files Browse the repository at this point in the history
  • Loading branch information
banker committed Apr 15, 2011
1 parent d0a4483 commit af6552e
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 4 deletions.
13 changes: 10 additions & 3 deletions lib/bson/ordered_hash.rb
Expand Up @@ -125,11 +125,11 @@ def delete(key, &block)
end

def delete_if(&block)
self.each { |k,v|
self.each do |k,v|
if yield k, v
delete(k)
end
}
end
end

def reject(&block)
Expand All @@ -139,7 +139,14 @@ def reject(&block)
end

def reject!(&block)
delete_if(&block)
changed = false
self.each do |k,v|
if yield k, v
changed = true
delete(k)
end
end
changed ? self : nil
end

def clear
Expand Down
3 changes: 2 additions & 1 deletion test/bson/ordered_hash_test.rb
Expand Up @@ -189,7 +189,8 @@ def test_reject

def test_reject_bang
@oh.reject! { |k, v| k == 'z' }
assert !@ok.keys.include?('z')
assert !@oh.keys.include?('z')
assert_nil @oh.reject! { |k, v| k == 'z' }
end

def test_clone
Expand Down

0 comments on commit af6552e

Please sign in to comment.