Hash is ordered in Ruby 1.9

git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@7817 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
This commit is contained in:
Jeremy Kemper
2007-10-09 07:48:59 +00:00
parent aa04635d8e
commit fba05826dc

View File

@@ -1,26 +1,31 @@
# OrderedHash is namespaced to prevent conflicts with other implementations
module ActiveSupport
class OrderedHash < Array #:nodoc:
def []=(key, value)
if pair = assoc(key)
pair.pop
pair << value
else
self << [key, value]
# Hash is ordered in Ruby 1.9!
if RUBY_VERSION >= '1.9'
OrderedHash = ::Hash
else
class OrderedHash < Array #:nodoc:
def []=(key, value)
if pair = assoc(key)
pair.pop
pair << value
else
self << [key, value]
end
end
end
def [](key)
pair = assoc(key)
pair ? pair.last : nil
end
def [](key)
pair = assoc(key)
pair ? pair.last : nil
end
def keys
collect { |key, value| key }
end
def keys
collect { |key, value| key }
end
def values
collect { |key, value| value }
def values
collect { |key, value| value }
end
end
end
end