mirror of https://github.com/rails/rails
add a specific factory method rather than using new
This commit is contained in:
parent
b017562382
commit
f38b544442
|
@ -117,7 +117,7 @@ module ActiveRecord
|
|||
# Can be overridden (i.e. in ThroughAssociation) to merge in other scopes (i.e. the
|
||||
# through association's scope)
|
||||
def target_scope
|
||||
AssociationRelation.new(klass, klass.arel_table, self).merge!(klass.all)
|
||||
AssociationRelation.create(klass, klass.arel_table, self).merge!(klass.all)
|
||||
end
|
||||
|
||||
# Loads the \target if needed and returns it.
|
||||
|
|
|
@ -34,7 +34,7 @@ module ActiveRecord
|
|||
reload
|
||||
end
|
||||
|
||||
@proxy ||= CollectionProxy.new(klass, self)
|
||||
@proxy ||= CollectionProxy.create(klass, self)
|
||||
end
|
||||
|
||||
# Implements the writer method, e.g. foo.items= for Foo.has_many :items
|
||||
|
|
|
@ -105,13 +105,13 @@ module ActiveRecord
|
|||
if item.is_a?(Relation)
|
||||
item
|
||||
else
|
||||
ActiveRecord::Relation.new(klass, table).instance_exec(self, &item)
|
||||
ActiveRecord::Relation.create(klass, table).instance_exec(self, &item)
|
||||
end
|
||||
end
|
||||
|
||||
if reflection.type
|
||||
scope_chain_items <<
|
||||
ActiveRecord::Relation.new(klass, table)
|
||||
ActiveRecord::Relation.create(klass, table)
|
||||
.where(reflection.type => foreign_klass.base_class.name)
|
||||
end
|
||||
|
||||
|
|
|
@ -85,7 +85,7 @@ module ActiveRecord
|
|||
def initialize(records, associations, preload_scope = nil)
|
||||
@records = Array.wrap(records).compact.uniq
|
||||
@associations = Array.wrap(associations)
|
||||
@preload_scope = preload_scope || Relation.new(nil, nil)
|
||||
@preload_scope = preload_scope || Relation.create(nil, nil)
|
||||
end
|
||||
|
||||
def run
|
||||
|
|
|
@ -146,7 +146,7 @@ module ActiveRecord
|
|||
private
|
||||
|
||||
def relation #:nodoc:
|
||||
relation = Relation.new(self, arel_table)
|
||||
relation = Relation.create(self, arel_table)
|
||||
|
||||
if finder_needs_type_condition?
|
||||
relation.where(type_condition).create_with(inheritance_column.to_sym => sti_name)
|
||||
|
|
|
@ -124,7 +124,7 @@ module ActiveRecord
|
|||
@quoted_table_name = nil
|
||||
@arel_table = nil
|
||||
@sequence_name = nil unless defined?(@explicit_sequence_name) && @explicit_sequence_name
|
||||
@relation = Relation.new(self, arel_table)
|
||||
@relation = Relation.create(self, arel_table)
|
||||
end
|
||||
|
||||
# Returns a quoted version of the table name, used to construct SQL statements.
|
||||
|
|
|
@ -73,10 +73,8 @@ module ActiveRecord
|
|||
module ClassMethods # :nodoc:
|
||||
@@subclasses = ThreadSafe::Cache.new(:initial_capacity => 2)
|
||||
|
||||
def new(klass, *args)
|
||||
relation = relation_class_for(klass).allocate
|
||||
relation.__send__(:initialize, klass, *args)
|
||||
relation
|
||||
def create(klass, *args)
|
||||
relation_class_for(klass).new(klass, *args)
|
||||
end
|
||||
|
||||
# This doesn't have to be thread-safe. relation_class_for guarantees that this will only be
|
||||
|
|
|
@ -22,7 +22,7 @@ module ActiveRecord
|
|||
# build a relation to merge in rather than directly merging
|
||||
# the values.
|
||||
def other
|
||||
other = Relation.new(relation.klass, relation.table)
|
||||
other = Relation.create(relation.klass, relation.table)
|
||||
hash.each { |k, v|
|
||||
if k == :joins
|
||||
if Hash === v
|
||||
|
|
|
@ -64,7 +64,7 @@ module ActiveRecord
|
|||
private
|
||||
|
||||
def relation_with(values) # :nodoc:
|
||||
result = Relation.new(klass, table, values)
|
||||
result = Relation.create(klass, table, values)
|
||||
result.extend(*extending_values) if extending_values.any?
|
||||
result
|
||||
end
|
||||
|
|
Loading…
Reference in New Issue