Class: ActiveRecord::Reflection::MacroReflection
- Inherits:
-
Object
- Object
- ActiveRecord::Reflection::MacroReflection
- Defined in:
- lib/active_record/reflection.rb
Overview
Abstract base class for AggregateReflection and AssociationReflection. Objects of AggregateReflection and AssociationReflection are returned by the Reflection::ClassMethods.
Direct Known Subclasses
Instance Attribute Summary collapse
-
#active_record ⇒ Object
readonly
Returns the value of attribute active_record.
-
#macro ⇒ Object
readonly
Returns the macro type.
-
#name ⇒ Object
readonly
Returns the name of the macro.
-
#options ⇒ Object
readonly
Returns the hash of options used for the macro.
Instance Method Summary collapse
-
#==(other_aggregation) ⇒ Object
Returns
true
ifself
andother_aggregation
have the samename
attribute,active_record
attribute, andother_aggregation
has an options hash assigned to it. -
#class_name ⇒ Object
Returns the class name for the macro.
-
#initialize(macro, name, options, active_record) ⇒ MacroReflection
constructor
A new instance of MacroReflection.
-
#klass ⇒ Object
Returns the class for the macro.
-
#sanitized_conditions ⇒ Object
:nodoc:.
Constructor Details
#initialize(macro, name, options, active_record) ⇒ MacroReflection
Returns a new instance of MacroReflection.
86 87 88 |
# File 'lib/active_record/reflection.rb', line 86 def initialize(macro, name, , active_record) @macro, @name, @options, @active_record = macro, name, , active_record end |
Instance Attribute Details
#active_record ⇒ Object (readonly)
Returns the value of attribute active_record.
84 85 86 |
# File 'lib/active_record/reflection.rb', line 84 def active_record @active_record end |
#macro ⇒ Object (readonly)
Returns the macro type.
composed_of :balance, :class_name => 'Money'
returns :composed_of
has_many :clients
returns :has_many
100 101 102 |
# File 'lib/active_record/reflection.rb', line 100 def macro @macro end |
#name ⇒ Object (readonly)
Returns the name of the macro.
composed_of :balance, :class_name => 'Money'
returns :balance
has_many :clients
returns :clients
94 95 96 |
# File 'lib/active_record/reflection.rb', line 94 def name @name end |
#options ⇒ Object (readonly)
Returns the hash of options used for the macro.
composed_of :balance, :class_name => 'Money'
returns { :class_name => "Money" }
has_many :clients
returns {}
106 107 108 |
# File 'lib/active_record/reflection.rb', line 106 def @options end |
Instance Method Details
#==(other_aggregation) ⇒ Object
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.
126 127 128 |
# File 'lib/active_record/reflection.rb', line 126 def ==(other_aggregation) other_aggregation.kind_of?(self.class) && name == other_aggregation.name && other_aggregation. && active_record == other_aggregation.active_record end |
#class_name ⇒ Object
Returns the class name for the macro.
composed_of :balance, :class_name => 'Money'
returns 'Money'
has_many :clients
returns 'Client'
120 121 122 |
# File 'lib/active_record/reflection.rb', line 120 def class_name @class_name ||= [:class_name] || derive_class_name end |
#klass ⇒ Object
Returns the class for the macro.
composed_of :balance, :class_name => 'Money'
returns the Money class has_many :clients
returns the Client class
112 113 114 |
# File 'lib/active_record/reflection.rb', line 112 def klass @klass ||= class_name.constantize end |
#sanitized_conditions ⇒ Object
:nodoc:
130 131 132 |
# File 'lib/active_record/reflection.rb', line 130 def sanitized_conditions #:nodoc: @sanitized_conditions ||= klass.send(:sanitize_sql, [:conditions]) if [:conditions] end |