From d15550aeccd5c10d7c734c523116e3da9f4b13e8 Mon Sep 17 00:00:00 2001 From: David Heinemeier Hansson <david@loudthinking.com> Date: Mon, 20 Mar 2006 18:53:52 +0000 Subject: Fixed the hash.delete :sym (closes #2176) [Stefan Kaes] git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@4005 5ecf4fe2-1ee6-0310-87b1-e25e094e27de --- .../lib/active_support/core_ext/hash/indifferent_access.rb | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) (limited to 'activesupport/lib') diff --git a/activesupport/lib/active_support/core_ext/hash/indifferent_access.rb b/activesupport/lib/active_support/core_ext/hash/indifferent_access.rb index 80012aa17d..d60b605942 100644 --- a/activesupport/lib/active_support/core_ext/hash/indifferent_access.rb +++ b/activesupport/lib/active_support/core_ext/hash/indifferent_access.rb @@ -1,4 +1,6 @@ -# This implementation is HODEL-HASH-9600 compliant +# this class has dubious semantics and we only have it so that +# people can write params[:key] instead of params['key'] + class HashWithIndifferentAccess < Hash def initialize(constructor = {}) if constructor.is_a?(Hash) @@ -24,6 +26,7 @@ class HashWithIndifferentAccess < Hash other_hash.each_pair { |key, value| regular_writer(convert_key(key), convert_value(value)) } self end + alias_method :merge!, :update def key?(key) @@ -49,7 +52,11 @@ class HashWithIndifferentAccess < Hash def merge(hash) self.dup.update(hash) end - + + def delete(key) + super(convert_key(key)) + end + protected def convert_key(key) key.kind_of?(Symbol) ? key.to_s : key -- cgit v1.2.3