aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJosé Valim <jose.valim@gmail.com>2009-08-09 13:22:06 +0200
committerPratik Naik <pratiknaik@gmail.com>2009-08-09 15:56:10 +0100
commit1bd4d1c67459a91415ee73a8f55d2309c0d62a87 (patch)
tree4862a97d1187ee76c64df4083792af0bfcd1a363
parentd811864e880580549bc1ab73a1ab0be886598e6e (diff)
downloadrails-1bd4d1c67459a91415ee73a8f55d2309c0d62a87.tar.gz
rails-1bd4d1c67459a91415ee73a8f55d2309c0d62a87.tar.bz2
rails-1bd4d1c67459a91415ee73a8f55d2309c0d62a87.zip
Optimize Range#sum to use arithmetic progression when a block is not given [#2489].
Signed-off-by: Pratik Naik <pratiknaik@gmail.com>
-rw-r--r--activesupport/lib/active_support/core_ext/enumerable.rb9
-rw-r--r--activesupport/test/core_ext/enumerable_test.rb2
2 files changed, 11 insertions, 0 deletions
diff --git a/activesupport/lib/active_support/core_ext/enumerable.rb b/activesupport/lib/active_support/core_ext/enumerable.rb
index e89b7e392e..d68eef8c23 100644
--- a/activesupport/lib/active_support/core_ext/enumerable.rb
+++ b/activesupport/lib/active_support/core_ext/enumerable.rb
@@ -111,3 +111,12 @@ module Enumerable
!any?(&block)
end unless [].respond_to?(:none?)
end
+
+class Range #:nodoc:
+ # Optimize range sum to use arithmetic progression if a block is not given.
+ def sum(identity=0, &block)
+ return super if block_given?
+ actual_last = exclude_end? ? (last - 1) : last
+ (actual_last - first + 1) * (actual_last + first) / 2
+ end
+end
diff --git a/activesupport/test/core_ext/enumerable_test.rb b/activesupport/test/core_ext/enumerable_test.rb
index 1927a0ad0d..6512754e53 100644
--- a/activesupport/test/core_ext/enumerable_test.rb
+++ b/activesupport/test/core_ext/enumerable_test.rb
@@ -61,7 +61,9 @@ class EnumerableTests < Test::Unit::TestCase
end
def test_enumerable_sums
+ assert_equal 20, (1..4).sum { |i| i * 2 }
assert_equal 10, (1..4).sum
+ assert_equal 6, (1...4).sum
end
def test_each_with_object