class Hash

Provide deep_merge. Borrowed from rails active_support github.com/rails/rails/blob/master/activesupport/lib/active_support/core_ext/hash/deep_merge.rb

Public Instance Methods

booleanize!(true_values=['true','on'], false_values=['false','off']) click to toggle source

convert recognizable strings to booleans

# File lib/morpheus/ext/hash.rb, line 65
def booleanize!(true_values=['true','on'], false_values=['false','off'])
  self.each_pair do |k, v|
    if v.is_a?(Hash)
      self[k].booleanize!
    elsif v.is_a?(Array)
      self[k].each do |it|
        if it.is_a?(Hash)
          it.booleanize!
        elsif self[k] == nil || self[k] == ''
          # meh, preserve 'empty' array elements
        end
      end
    else
      if true_values.include?(v)
        self[k] = true
      elsif false_values.include?(v)
        self[k] = false
      end
    end
  end
  self
end
capitalize_keys!() click to toggle source
# File lib/morpheus/ext/hash.rb, line 102
def capitalize_keys!
  self.keys.each do |k|
    self[k.to_s.capitalize] = self.delete(k)
  end
  self
end
deep_compact!() click to toggle source
# File lib/morpheus/ext/hash.rb, line 43
def deep_compact!
  self.each_pair do |k, v|
    if v.is_a?(Hash)
      self[k].deep_compact!
    elsif v.is_a?(Array)
      self[k].each do |it|
        if it.is_a?(Hash)
          it.deep_compact!
        elsif self[k] == nil || self[k] == ''
          # meh, preserve 'empty' array elements
        end
      end
    else
      if self[k] == nil || self[k] == ''
        self.delete(k)
      end
    end
  end
  self
end
deep_merge(other_hash, &block) click to toggle source

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] } }

h1.deep_merge(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 } }
h1.deep_merge(h2) { |key, this_val, other_val| this_val + other_val }
# => { a: 100, b: 450, c: { c1: 300 } }
# File lib/morpheus/ext/hash.rb, line 20
def deep_merge(other_hash, &block)
  dup.deep_merge!(other_hash, &block)
end
deep_merge!(other_hash, &block) click to toggle source

Same as deep_merge, but modifies self.

# File lib/morpheus/ext/hash.rb, line 25
def deep_merge!(other_hash, &block)
  other_hash.each_pair do |current_key, other_value|
    this_value = self[current_key]

    self[current_key] = if this_value.is_a?(Hash) && other_value.is_a?(Hash)
      this_value.deep_merge(other_value, &block)
    else
      if block_given? && key?(current_key)
        block.call(current_key, this_value, other_value)
      else
        other_value
      end
    end
  end

  self
end
downcase_keys!() click to toggle source
# File lib/morpheus/ext/hash.rb, line 95
def downcase_keys!
  self.keys.each do |k|
    self[k.to_s.downcase] = self.delete(k)
  end
  self
end
upcase_keys!() click to toggle source
# File lib/morpheus/ext/hash.rb, line 88
def upcase_keys!
  self.keys.each do |k| 
    self[k.to_s.upcase] = self.delete(k)
  end
  self
end