aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib
diff options
context:
space:
mode:
authorEmilio Tagua <miloops@gmail.com>2009-10-07 11:57:59 -0300
committerEmilio Tagua <miloops@gmail.com>2009-10-07 11:57:59 -0300
commit1d5854826b27e5e8bfb041c57a49d1e46178b49e (patch)
tree25762234a182342cf4a64d7a715bd295239edae5 /activerecord/lib
parentc3b4da7796f0aab23b11521cf86171a83d84ad3e (diff)
downloadrails-1d5854826b27e5e8bfb041c57a49d1e46178b49e.tar.gz
rails-1d5854826b27e5e8bfb041c57a49d1e46178b49e.tar.bz2
rails-1d5854826b27e5e8bfb041c57a49d1e46178b49e.zip
Allow preload and eager_load to work on relations at the same time.
Diffstat (limited to 'activerecord/lib')
-rw-r--r--activerecord/lib/active_record/relation.rb14
1 files changed, 8 insertions, 6 deletions
diff --git a/activerecord/lib/active_record/relation.rb b/activerecord/lib/active_record/relation.rb
index 24fd29c7f3..db1c9c24de 100644
--- a/activerecord/lib/active_record/relation.rb
+++ b/activerecord/lib/active_record/relation.rb
@@ -26,9 +26,9 @@ module ActiveRecord
end
def to_a
- if @eager_load_associations.any?
- records = catch :invalid_query do
- @klass.send(:find_with_associations, {
+ records = if @eager_load_associations.any?
+ catch :invalid_query do
+ return @klass.send(:find_with_associations, {
:select => @relation.send(:select_clauses).join(', '),
:joins => @relation.joins(relation),
:group => @relation.send(:group_clauses).join(', '),
@@ -38,12 +38,14 @@ module ActiveRecord
},
ActiveRecord::Associations::ClassMethods::JoinDependency.new(@klass, @eager_load_associations, nil))
end
+ []
else
- records = @klass.find_by_sql(@relation.to_sql)
- @klass.send(:preload_associations, records, @associations_to_preload) unless @associations_to_preload.empty?
- records.each { |record| record.readonly! } if @readonly
+ @klass.find_by_sql(@relation.to_sql)
end
+ @klass.send(:preload_associations, records, @associations_to_preload) unless @associations_to_preload.empty?
+ records.each { |record| record.readonly! } if @readonly
+
records
end