aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2008-01-23 07:25:20 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2008-01-23 07:25:20 +0000
commit8273280a637a5e40de2c37dd1da507c749b11aab (patch)
tree47f6a1cfceccd4811b45a8722a874ec60ad88088
parentfc71a07edb214a7f8c08ef69b6e6f4284761de5d (diff)
downloadrails-8273280a637a5e40de2c37dd1da507c749b11aab.tar.gz
rails-8273280a637a5e40de2c37dd1da507c749b11aab.tar.bz2
rails-8273280a637a5e40de2c37dd1da507c749b11aab.zip
Enumerable#group_by uses ActiveSupport::OrderedHash
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@8700 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
-rw-r--r--activesupport/lib/active_support/core_ext/enumerable.rb17
-rw-r--r--activesupport/test/core_ext/enumerable_test.rb2
2 files changed, 3 insertions, 16 deletions
diff --git a/activesupport/lib/active_support/core_ext/enumerable.rb b/activesupport/lib/active_support/core_ext/enumerable.rb
index 35a8e0538c..c448d0454d 100644
--- a/activesupport/lib/active_support/core_ext/enumerable.rb
+++ b/activesupport/lib/active_support/core_ext/enumerable.rb
@@ -15,23 +15,10 @@ module Enumerable
# "2006-02-24 -> Transcript, Transcript"
# "2006-02-23 -> Transcript"
def group_by
- groups = []
-
- inject({}) do |grouped, element|
- index = yield(element)
-
- if group = grouped[index]
- group << element
- else
- group = [element]
- groups << [index, group]
- grouped[index] = group
- end
-
+ inject ActiveSupport::OrderedHash.new do |grouped, element|
+ (grouped[yield(element)] ||= []) << element
grouped
end
-
- groups
end if RUBY_VERSION < '1.9'
# Calculates a sum from the elements. Examples:
diff --git a/activesupport/test/core_ext/enumerable_test.rb b/activesupport/test/core_ext/enumerable_test.rb
index 234dc98de8..9567f22e9a 100644
--- a/activesupport/test/core_ext/enumerable_test.rb
+++ b/activesupport/test/core_ext/enumerable_test.rb
@@ -21,7 +21,7 @@ class EnumerableTests < Test::Unit::TestCase
assert group.all? { |person| person.name == name }
end
- assert_equal objects.uniq.map(&:name), grouped.map { |name, group| name }
+ assert_equal objects.uniq.map(&:name), grouped.keys
end
def test_sums