Module: Fusu::Hash::DeepMerge
- Included in:
- Fusu::Hash
- Defined in:
- lib/fusu/hash/deep_merge.rb
Instance Method Summary collapse
-
#deep_merge(hash, other_hash, &block) ⇒ Object
Returns a new hash with
self
andother_hash
merged recursively. -
#deep_merge!(hash, other_hash, &block) ⇒ Object
Same as
deep_merge
, but modifiesself
.
Instance Method Details
#deep_merge(hash, other_hash, &block) ⇒ Object
Returns a new hash with self
and other_hash
merged recursively.
h1 = { a: true, b: { c: [1, 2, 3] } }
h2 = { a: false, b: { x: [3, 4, 5] } }
Fusu::Hash.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 } }
Fusu::Hash.deep_merge(h1, h2) { |key, this_val, other_val| this_val + other_val }
# => { a: 100, b: 450, c: { c1: 300 } }
19 20 21 |
# File 'lib/fusu/hash/deep_merge.rb', line 19 def deep_merge(hash, other_hash, &block) deep_merge!(hash.dup, other_hash, &block) end |
#deep_merge!(hash, other_hash, &block) ⇒ Object
Same as deep_merge
, but modifies self
.
24 25 26 27 28 29 30 31 32 33 34 |
# File 'lib/fusu/hash/deep_merge.rb', line 24 def deep_merge!(hash, other_hash, &block) hash.merge!(other_hash) do |key, this_val, other_val| if this_val.class <= ::Hash && other_val.class <= ::Hash deep_merge(this_val, other_val, &block) elsif block_given? block.call(key, this_val, other_val) else other_val end end end |