mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
use polymorphic proxies to remove duplicate code
This commit is contained in:
parent
ea55d86eb1
commit
a9da99ee5f
1 changed files with 44 additions and 25 deletions
|
@ -625,10 +625,10 @@ module ActiveRecord
|
||||||
end
|
end
|
||||||
when :has_many
|
when :has_many
|
||||||
if association.options[:through]
|
if association.options[:through]
|
||||||
handle_hmt(rows, row, association)
|
add_join_records(rows, row, HasManyThroughProxy.new(association))
|
||||||
end
|
end
|
||||||
when :has_and_belongs_to_many
|
when :has_and_belongs_to_many
|
||||||
handle_habtm(rows, row, association)
|
add_join_records(rows, row, HABTMProxy.new(association))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -638,38 +638,57 @@ module ActiveRecord
|
||||||
rows
|
rows
|
||||||
end
|
end
|
||||||
|
|
||||||
|
class ReflectionProxy # :nodoc:
|
||||||
|
def initialize(association)
|
||||||
|
@association = association
|
||||||
|
end
|
||||||
|
|
||||||
|
def join_table
|
||||||
|
@association.join_table
|
||||||
|
end
|
||||||
|
|
||||||
|
def name
|
||||||
|
@association.name
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
class HasManyThroughProxy < ReflectionProxy # :nodoc:
|
||||||
|
def rhs_key
|
||||||
|
@association.foreign_key
|
||||||
|
end
|
||||||
|
|
||||||
|
def lhs_key
|
||||||
|
@association.through_reflection.foreign_key
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
class HABTMProxy < ReflectionProxy # :nodoc:
|
||||||
|
def rhs_key
|
||||||
|
@association.association_foreign_key
|
||||||
|
end
|
||||||
|
|
||||||
|
def lhs_key
|
||||||
|
@association.foreign_key
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
def primary_key_name
|
def primary_key_name
|
||||||
@primary_key_name ||= model_class && model_class.primary_key
|
@primary_key_name ||= model_class && model_class.primary_key
|
||||||
end
|
end
|
||||||
|
|
||||||
def join_rows(targets, row, lhs_key, rhs_key)
|
def add_join_records(rows, row, association)
|
||||||
targets = targets.is_a?(Array) ? targets : targets.split(/\s*,\s*/)
|
|
||||||
targets.map { |target|
|
|
||||||
{ lhs_key => row[primary_key_name],
|
|
||||||
rhs_key => ActiveRecord::FixtureSet.identify(target) }
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
def handle_hmt(rows, row, association)
|
|
||||||
# This is the case when the join table has no fixtures file
|
# This is the case when the join table has no fixtures file
|
||||||
if (targets = row.delete(association.name.to_s))
|
if (targets = row.delete(association.name.to_s))
|
||||||
table_name = association.join_table
|
table_name = association.join_table
|
||||||
lhs_key = association.through_reflection.foreign_key
|
lhs_key = association.lhs_key
|
||||||
rhs_key = association.foreign_key
|
rhs_key = association.rhs_key
|
||||||
|
|
||||||
rows[table_name].concat join_rows(targets, row, lhs_key, rhs_key)
|
targets = targets.is_a?(Array) ? targets : targets.split(/\s*,\s*/)
|
||||||
end
|
rows[table_name].concat targets.map { |target|
|
||||||
end
|
{ lhs_key => row[primary_key_name],
|
||||||
|
rhs_key => ActiveRecord::FixtureSet.identify(target) }
|
||||||
def handle_habtm(rows, row, association)
|
}
|
||||||
# This is the case when the join table has no fixtures file
|
|
||||||
if (targets = row.delete(association.name.to_s))
|
|
||||||
table_name = association.join_table
|
|
||||||
lhs_key = association.foreign_key
|
|
||||||
rhs_key = association.association_foreign_key
|
|
||||||
|
|
||||||
rows[table_name].concat join_rows(targets, row, lhs_key, rhs_key)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue