module ActiveSupport::DeepMergeable

def deep_merge(other, &block)


# => { a: 100, b: 450, c: { c1: 300 } }
end
this_val + other_val
hash_1.deep_merge(hash_2) do |key, this_val, other_val|

hash_2 = { b: 250, c: { c1: 200 } }
hash_1 = { a: 100, b: 200, c: { c1: 100 } }

A block can be provided to merge non-DeepMergeable values:

# => { a: false, b: { c: [1, 2, 3], x: [3, 4, 5] } }
hash_1.deep_merge(hash_2)

hash_2 = { a: false, b: { x: [3, 4, 5] } }
hash_1 = { a: true, b: { c: [1, 2, 3] } }

end
include ActiveSupport::DeepMergeable
class Hash

Returns a new instance with the values from +other+ merged recursively.
:nodoc:
to provide a merge!(other, &block) method.
Provides +deep_merge+ and +deep_merge!+ methods. Expects the including class
def deep_merge(other, &block)
  dup.deep_merge!(other, &block)
end

def deep_merge!(other, &block)

Same as #deep_merge, but modifies +self+.
def deep_merge!(other, &block)
  merge!(other) do |key, this_val, other_val|
    if this_val.is_a?(DeepMergeable) && this_val.deep_merge?(other_val)
      this_val.deep_merge(other_val, &block)
    elsif block_given?
      block.call(key, this_val, other_val)
    else
      other_val
    end
  end
end

def deep_merge?(other)

values. Defaults to checking that +other+ is of type +self.class+.
override this method to restrict or expand the domain of deep mergeable
Returns true if +other+ can be deep merged into +self+. Classes may
def deep_merge?(other)
  other.is_a?(self.class)
end