From f9cb645dfcb5cc89f59d2f8b58a019486c828c73 Mon Sep 17 00:00:00 2001 From: Carlos Antonio da Silva Date: Thu, 24 May 2012 20:50:44 -0300 Subject: Yield only one argument instead of splatting. Add Changelog entry. Closes #4003 --- activerecord/CHANGELOG.md | 7 +++++++ activerecord/lib/active_record/relation/calculations.rb | 4 ++-- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/activerecord/CHANGELOG.md b/activerecord/CHANGELOG.md index 1a8e233a51..4f4e087acd 100644 --- a/activerecord/CHANGELOG.md +++ b/activerecord/CHANGELOG.md @@ -1,5 +1,12 @@ ## Rails 4.0.0 (unreleased) ## +* Allow blocks for `count` with `ActiveRecord::Relation`, to work similar as + `Array#count`: + + Person.where("age > 26").count { |person| gender == 'female' } + + *Chris Finne & Carlos Antonio da Silva* + * Added support to `CollectionAssociation#delete` for passing `fixnum` or `string` values as record ids. This finds the records responding to the `id` and executes delete on them. diff --git a/activerecord/lib/active_record/relation/calculations.rb b/activerecord/lib/active_record/relation/calculations.rb index a0d24f28d0..04b4fcf379 100644 --- a/activerecord/lib/active_record/relation/calculations.rb +++ b/activerecord/lib/active_record/relation/calculations.rb @@ -21,7 +21,7 @@ module ActiveRecord # # => queries people where "age > 26" then count the loaded results filtering by gender def count(column_name = nil, options = {}) if block_given? - self.to_a.count { |*block_args| yield(*block_args) } + self.to_a.count { |item| yield item } else column_name, options = nil, column_name if column_name.is_a?(Hash) calculate(:count, column_name, options) @@ -65,7 +65,7 @@ module ActiveRecord # # queries people where "age > 100" then perform a sum calculation with the block returns def sum(*args) if block_given? - self.to_a.sum(*args) { |*block_args| yield(*block_args) } + self.to_a.sum(*args) { |item| yield item } else calculate(:sum, *args) end -- cgit v1.2.3