aboutsummaryrefslogblamecommitdiffstats
path: root/activesupport/lib/active_support/core_ext/hash/reverse_merge.rb
blob: 01863a162b95e6cfe48480a72c46130445a83f30 (plain) (tree)
1
2
3
4
5
6
7
8
9
          
                                                     
   
                                                                   
   
                    
   
                                                             
   

                                                                


                               
 
                                
                                

                                                
     

                                               
   
class Hash
  # Merges the caller into +other_hash+. For example,
  #
  #   options = options.reverse_merge(:size => 25, :velocity => 10)
  #
  # is equivalent to
  #
  #   options = {:size => 25, :velocity => 10}.merge(options)
  #
  # This is particularly useful for initializing an options hash
  # with default values.
  def reverse_merge(other_hash)
    other_hash.merge(self)
  end

  # Destructive +reverse_merge+.
  def reverse_merge!(other_hash)
    # right wins if there is no left
    merge!( other_hash ){|key,left,right| left }
  end

  alias_method :reverse_update, :reverse_merge!
end