Class: ActiveRecord::Reflection::MacroReflection
Relationships & Source Files | |
Extension / Inclusion / Inheritance Descendants | |
Subclasses:
ActiveRecord::Reflection::AggregateReflection, ActiveRecord::Reflection::AssociationReflection, ActiveRecord::Reflection::BelongsToReflection, ActiveRecord::Reflection::HasAndBelongsToManyReflection, ActiveRecord::Reflection::HasManyReflection, ActiveRecord::Reflection::HasOneReflection, ActiveStorage::Reflection::HasAttachedReflection, ActiveStorage::Reflection::HasManyAttachedReflection, ActiveStorage::Reflection::HasOneAttachedReflection
|
|
Inherits: |
ActiveRecord::Reflection::AbstractReflection
|
Defined in: | activerecord/lib/active_record/reflection.rb |
Overview
::ActiveRecord::Base
class for AggregateReflection
and AssociationReflection
. Objects of AggregateReflection
and AssociationReflection
are returned by the ClassMethods
.
Class Method Summary
Instance Attribute Summary
- #active_record readonly
- #autosave=(autosave) writeonly
-
#name
readonly
Returns the name of the macro.
-
#options
readonly
Returns the hash of options used for the macro.
- #scope readonly
Instance Method Summary
-
#==(other_aggregation)
Returns
true
ifself
andother_aggregation
have the same #name attribute, #active_record attribute, andother_aggregation
has an options hash assigned to it. - #compute_class(name)
-
#klass
Returns the class for the macro.
- #scope_for(relation, owner = nil)
Constructor Details
.new(name, scope, options, active_record) ⇒ MacroReflection
# File 'activerecord/lib/active_record/reflection.rb', line 388
def initialize(name, scope, , active_record) super() @name = name @scope = scope @options = ( ) @active_record = active_record @klass = [:anonymous_class] @plural_name = active_record.pluralize_table_names ? name.to_s.pluralize : name.to_s end
Instance Attribute Details
#active_record (readonly)
[ GitHub ]# File 'activerecord/lib/active_record/reflection.rb', line 384
attr_reader :active_record
#autosave=(autosave) (writeonly)
[ GitHub ]# File 'activerecord/lib/active_record/reflection.rb', line 399
def autosave=(autosave) @options[:autosave] = autosave parent_reflection = self.parent_reflection if parent_reflection parent_reflection.autosave = autosave end end
#name (readonly)
Returns the name of the macro.
composed_of :balance, class_name: 'Money'
returns :balance
has_many :clients
returns :clients
# File 'activerecord/lib/active_record/reflection.rb', line 374
attr_reader :name
#options (readonly)
Returns the hash of options used for the macro.
composed_of :balance, class_name: 'Money'
returns { class_name: "Money" }
has_many :clients
returns {}
# File 'activerecord/lib/active_record/reflection.rb', line 382
attr_reader :
#scope (readonly)
[ GitHub ]# File 'activerecord/lib/active_record/reflection.rb', line 376
attr_reader :scope
Instance Method Details
#==(other_aggregation)
Returns true
if self
and other_aggregation
have the same #name attribute, #active_record attribute, and other_aggregation
has an options hash assigned to it.
# File 'activerecord/lib/active_record/reflection.rb', line 440
def ==(other_aggregation) super || other_aggregation.kind_of?(self.class) && name == other_aggregation.name && !other_aggregation. .nil? && active_record == other_aggregation.active_record end
#compute_class(name)
[ GitHub ]#klass
Returns the class for the macro.
composed_of :balance, class_name: 'Money'
returns the Money class has_many :clients
returns the Client class
class Company < ActiveRecord::Base
has_many :clients
end
Company.reflect_on_association(:clients).klass
# => Client
Note: Do not call klass.new
or klass.create
to instantiate a new association object. Use build_association
or create_association
instead. This allows plugins to hook into association object creation.
# File 'activerecord/lib/active_record/reflection.rb', line 422
def klass @klass ||= _klass(class_name) end
#scope_for(relation, owner = nil)
[ GitHub ]# File 'activerecord/lib/active_record/reflection.rb', line 448
def scope_for(relation, owner = nil) relation.instance_exec(owner, &scope) || relation end