2007-01-22 14:43:50 +01:00
|
|
|
module ActiveSupport #:nodoc:
|
|
|
|
module CoreExtensions #:nodoc:
|
|
|
|
module Hash #:nodoc:
|
|
|
|
# Allows for reverse merging where its the keys in the calling hash that wins over those in the <tt>other_hash</tt>.
|
|
|
|
# This is particularly useful for initializing an incoming option hash with default values:
|
|
|
|
#
|
|
|
|
# def setup(options = {})
|
|
|
|
# options.reverse_merge! :size => 25, :velocity => 10
|
|
|
|
# end
|
|
|
|
#
|
2008-05-18 06:22:34 +02:00
|
|
|
# The default <tt>:size</tt> and <tt>:velocity</tt> is only set if the +options+ passed in doesn't already have those keys set.
|
2007-01-22 14:43:50 +01:00
|
|
|
module ReverseMerge
|
2008-05-18 06:22:34 +02:00
|
|
|
# Performs the opposite of merge, with the keys and values from the first hash taking precedence over the second.
|
2007-01-22 14:43:50 +01:00
|
|
|
def reverse_merge(other_hash)
|
|
|
|
other_hash.merge(self)
|
|
|
|
end
|
|
|
|
|
2008-05-18 06:22:34 +02:00
|
|
|
# Performs the opposite of merge, with the keys and values from the first hash taking precedence over the second.
|
|
|
|
# Modifies the receiver in place.
|
2007-01-22 14:43:50 +01:00
|
|
|
def reverse_merge!(other_hash)
|
|
|
|
replace(reverse_merge(other_hash))
|
|
|
|
end
|
|
|
|
|
2007-12-21 08:48:59 +01:00
|
|
|
alias_method :reverse_update, :reverse_merge!
|
2007-01-22 14:43:50 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2007-12-21 08:48:59 +01:00
|
|
|
end
|