Class: Hash
- Inherits:
-
Object
- Object
- Hash
- Defined in:
- lib/rivet/deep_merge.rb
Instance Method Summary collapse
-
#deep_merge(other_hash, &block) ⇒ Object
Returns a new hash with
selfandother_hashmerged recursively. -
#deep_merge!(other_hash, &block) ⇒ Object
Same as
deep_merge, but modifiesself.
Instance Method Details
#deep_merge(other_hash, &block) ⇒ Object
Returns a new hash with self and other_hash merged recursively.
h1 = { x: { y: [4,5,6] }, z: [7,8,9] }
h2 = { x: { y: [7,8,9] }, z: 'xyz' }
h1.deep_merge(h2) #=> {x: {y: [7, 8, 9]}, z: "xyz"}
h2.deep_merge(h1) #=> {x: {y: [4, 5, 6]}, z: [7, 8, 9]}
h1.deep_merge(h2) { |key, old, new| Array.wrap(old) + Array.wrap(new) }
#=> {:x=>{:y=>[4, 5, 6, 7, 8, 9]}, :z=>[7, 8, 9, "xyz"]}
13 14 15 |
# File 'lib/rivet/deep_merge.rb', line 13 def deep_merge(other_hash, &block) dup.deep_merge!(other_hash, &block) end |
#deep_merge!(other_hash, &block) ⇒ Object
Same as deep_merge, but modifies self.
18 19 20 21 22 23 24 25 26 27 28 |
# File 'lib/rivet/deep_merge.rb', line 18 def deep_merge!(other_hash, &block) other_hash.each_pair do |k, v| tv = self[k] if tv.is_a?(Hash) && v.is_a?(Hash) self[k] = tv.deep_merge(v, &block) else self[k] = block && tv ? block.call(k, tv, v) : v end end self end |