Method: Dnsimple::Extra.deep_merge
- Defined in:
- lib/dnsimple/extra.rb
.deep_merge(this, other, &block) ⇒ Object
Returns a new hash with self and other merged recursively.
h1 = { a: true, b: { c: [1, 2, 3] } }
h2 = { a: false, b: { x: [3, 4, 5] } }
Extra.deep_merge(h1, h2) #=> { a: false, b: { c: [1, 2, 3], x: [3, 4, 5] } }
Like with Hash#merge in the standard library, a block can be provided to merge values:
h1 = { a: 100, b: 200, c: { c1: 100 } }
h2 = { b: 250, c: { c1: 200 } }
Extra.deep_merge(h1, h2) { |key, this_val, other_val| this_val + other_val }
# => { a: 100, b: 450, c: { c1: 300 } }
27 28 29 |
# File 'lib/dnsimple/extra.rb', line 27 def self.deep_merge(this, other, &block) deep_merge!(this.dup, other, &block) end |