Sha256: c9b41c35b3ead0c0b129a3e681f9fff5d1efe07502d5551ece7fbf7906403656

Contents?: true

Size: 1.01 KB

Versions: 7

Compression:

Stored size: 1.01 KB

Contents

class Hash
  # Allows for reverse merging two hashes where the keys in the calling hash take precedence over those
  # in the <tt>other_hash</tt>. This is particularly useful for initializing an option hash with default values:
  #
  #   def setup(options = {})
  #     options.reverse_merge! :size => 25, :velocity => 10
  #   end
  #
  # Using <tt>merge</tt>, the above example would look as follows:
  #
  #   def setup(options = {})
  #     { :size => 25, :velocity => 10 }.merge(options)
  #   end
  #
  # The default <tt>:size</tt> and <tt>:velocity</tt> are only set if the +options+ hash passed in doesn't already
  # have the respective key.
  def reverse_merge(other_hash)
    other_hash.merge(self)
  end unless method_defined?(:reverse_merge)

  # Performs the opposite of <tt>merge</tt>, with the keys and values from the first hash taking precedence over the second.
  # Modifies the receiver in place.
  def reverse_merge!(other_hash)
    merge!( other_hash ){|k,o,n| o }
  end unless method_defined?(:reverse_merge!)
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
gorillib-0.0.8 lib/gorillib/hash/reverse_merge.rb
gorillib-0.0.7 lib/gorillib/hash/reverse_merge.rb
gorillib-0.0.6 lib/gorillib/hash/reverse_merge.rb
gorillib-0.0.5 lib/gorillib/hash/reverse_merge.rb
gorillib-0.0.4 lib/gorillib/hash/reverse_merge.rb
gorillib-0.0.3 lib/gorillib/hash/reverse_merge.rb
gorillib-0.0.2 lib/gorillib/hash/reverse_merge.rb