Method: Hash#delete_if
- Defined in:
- hash.c
#delete_if {|key, value| ... } ⇒ self #delete_if ⇒ Object
If a block given, calls the block with each key-value pair; deletes each entry for which the block returns a truthy value; returns self:
h = {foo: 0, bar: 1, baz: 2}
h.delete_if {|key, value| value > 0 } # => {:foo=>0}
If no block given, returns a new Enumerator:
h = {foo: 0, bar: 1, baz: 2}
e = h.delete_if # => #<Enumerator: {:foo=>0, :bar=>1, :baz=>2}:delete_if>
e.each { |key, value| value > 0 } # => {:foo=>0}
2547 2548 2549 2550 2551 2552 2553 2554 2555 2556 2557 |
# File 'hash.c', line 2547 VALUE rb_hash_delete_if(VALUE hash) { RETURN_SIZED_ENUMERATOR(hash, 0, 0, hash_enum_size); rb_hash_modify_check(hash); if (!RHASH_TABLE_EMPTY_P(hash)) { rb_hash_foreach(hash, delete_if_i, hash); compact_after_delete(hash); } return hash; } |