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
|
|
| 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
trueifselfandother_aggregationhave the same #name attribute, #active_record attribute, andother_aggregationhas 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 341
def initialize(name, scope, , active_record) @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 337
attr_reader :active_record
#autosave=(autosave) (writeonly)
[ GitHub ]# File 'activerecord/lib/active_record/reflection.rb', line 351
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 327
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 335
attr_reader :
#scope (readonly)
[ GitHub ]# File 'activerecord/lib/active_record/reflection.rb', line 329
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 384
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 374
def klass @klass ||= compute_class(class_name) end
#scope_for(relation, owner = nil)
[ GitHub ]# File 'activerecord/lib/active_record/reflection.rb', line 392
def scope_for(relation, owner = nil) relation.instance_exec(owner, &scope) || relation end