2007-01-22 14:43:50 +01:00
|
|
|
module ActiveRecord
|
|
|
|
module Associations
|
|
|
|
class BelongsToAssociation < AssociationProxy #:nodoc:
|
|
|
|
def create(attributes = {})
|
2008-10-27 07:47:01 +01:00
|
|
|
replace(@reflection.create_association(attributes))
|
2007-01-22 14:43:50 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def build(attributes = {})
|
2008-10-27 07:47:01 +01:00
|
|
|
replace(@reflection.build_association(attributes))
|
2007-01-22 14:43:50 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def replace(record)
|
|
|
|
counter_cache_name = @reflection.counter_cache_column
|
|
|
|
|
|
|
|
if record.nil?
|
2008-05-18 06:22:34 +02:00
|
|
|
if counter_cache_name && !@owner.new_record?
|
2009-08-04 17:16:03 +02:00
|
|
|
@reflection.klass.decrement_counter(counter_cache_name, previous_record_id) if @owner[@reflection.primary_key_name]
|
2007-01-22 14:43:50 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
@target = @owner[@reflection.primary_key_name] = nil
|
|
|
|
else
|
|
|
|
raise_on_type_mismatch(record)
|
|
|
|
|
|
|
|
if counter_cache_name && !@owner.new_record?
|
|
|
|
@reflection.klass.increment_counter(counter_cache_name, record.id)
|
|
|
|
@reflection.klass.decrement_counter(counter_cache_name, @owner[@reflection.primary_key_name]) if @owner[@reflection.primary_key_name]
|
|
|
|
end
|
|
|
|
|
|
|
|
@target = (AssociationProxy === record ? record.target : record)
|
2009-08-04 17:16:03 +02:00
|
|
|
@owner[@reflection.primary_key_name] = record_id(record) unless record.new_record?
|
2007-01-22 14:43:50 +01:00
|
|
|
@updated = true
|
|
|
|
end
|
|
|
|
|
2010-05-25 19:45:45 +02:00
|
|
|
set_inverse_instance(record, @owner)
|
|
|
|
|
2007-01-22 14:43:50 +01:00
|
|
|
loaded
|
|
|
|
record
|
|
|
|
end
|
|
|
|
|
|
|
|
def updated?
|
|
|
|
@updated
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
def find_target
|
2009-08-04 17:16:03 +02:00
|
|
|
find_method = if @reflection.options[:primary_key]
|
|
|
|
"find_by_#{@reflection.options[:primary_key]}"
|
|
|
|
else
|
|
|
|
"find"
|
|
|
|
end
|
2010-05-25 19:45:45 +02:00
|
|
|
the_target = @reflection.klass.send(find_method,
|
2008-06-02 08:35:38 +02:00
|
|
|
@owner[@reflection.primary_key_name],
|
|
|
|
:select => @reflection.options[:select],
|
2007-01-22 14:43:50 +01:00
|
|
|
:conditions => conditions,
|
2008-05-18 06:22:34 +02:00
|
|
|
:include => @reflection.options[:include],
|
2008-06-02 08:35:38 +02:00
|
|
|
:readonly => @reflection.options[:readonly]
|
2009-08-04 17:16:03 +02:00
|
|
|
) if @owner[@reflection.primary_key_name]
|
2010-05-25 19:45:45 +02:00
|
|
|
set_inverse_instance(the_target, @owner)
|
|
|
|
the_target
|
2007-01-22 14:43:50 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def foreign_key_present
|
|
|
|
!@owner[@reflection.primary_key_name].nil?
|
|
|
|
end
|
2009-08-04 17:16:03 +02:00
|
|
|
|
|
|
|
def record_id(record)
|
|
|
|
record.send(@reflection.options[:primary_key] || :id)
|
|
|
|
end
|
|
|
|
|
|
|
|
def previous_record_id
|
|
|
|
@previous_record_id ||= if @reflection.options[:primary_key]
|
|
|
|
previous_record = @owner.send(@reflection.name)
|
|
|
|
previous_record.nil? ? nil : previous_record.id
|
|
|
|
else
|
|
|
|
@owner[@reflection.primary_key_name]
|
|
|
|
end
|
|
|
|
end
|
2010-05-25 19:45:45 +02:00
|
|
|
|
|
|
|
# NOTE - for now, we're only supporting inverse setting from belongs_to back onto
|
|
|
|
# has_one associations.
|
|
|
|
def we_can_set_the_inverse_on_this?(record)
|
|
|
|
@reflection.has_inverse? && @reflection.inverse_of.macro == :has_one
|
|
|
|
end
|
2007-01-22 14:43:50 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|