aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/associations
diff options
context:
space:
mode:
Diffstat (limited to 'activerecord/lib/active_record/associations')
-rw-r--r--activerecord/lib/active_record/associations/belongs_to_association.rb12
-rw-r--r--activerecord/lib/active_record/associations/has_one_association.rb14
2 files changed, 15 insertions, 11 deletions
diff --git a/activerecord/lib/active_record/associations/belongs_to_association.rb b/activerecord/lib/active_record/associations/belongs_to_association.rb
index 4558872a2b..2eb56e5cd3 100644
--- a/activerecord/lib/active_record/associations/belongs_to_association.rb
+++ b/activerecord/lib/active_record/associations/belongs_to_association.rb
@@ -49,12 +49,16 @@ module ActiveRecord
else
"find"
end
+
+ options = @reflection.options.dup
+ (options.keys - [:select, :include, :readonly]).each do |key|
+ options.delete key
+ end
+ options[:conditions] = conditions
+
the_target = @reflection.klass.send(find_method,
@owner[@reflection.primary_key_name],
- :select => @reflection.options[:select],
- :conditions => conditions,
- :include => @reflection.options[:include],
- :readonly => @reflection.options[:readonly]
+ options
) if @owner[@reflection.primary_key_name]
set_inverse_instance(the_target, @owner)
the_target
diff --git a/activerecord/lib/active_record/associations/has_one_association.rb b/activerecord/lib/active_record/associations/has_one_association.rb
index 68b8b792ad..a6e6bfa356 100644
--- a/activerecord/lib/active_record/associations/has_one_association.rb
+++ b/activerecord/lib/active_record/associations/has_one_association.rb
@@ -79,13 +79,13 @@ module ActiveRecord
private
def find_target
- the_target = @reflection.klass.find(:first,
- :conditions => @finder_sql,
- :select => @reflection.options[:select],
- :order => @reflection.options[:order],
- :include => @reflection.options[:include],
- :readonly => @reflection.options[:readonly]
- )
+ options = @reflection.options.dup
+ (options.keys - [:select, :order, :include, :readonly]).each do |key|
+ options.delete key
+ end
+ options[:conditions] = @finder_sql
+
+ the_target = @reflection.klass.find(:first, options)
set_inverse_instance(the_target, @owner)
the_target
end