Class: ActiveRecord::Reflection::MacroReflection

Inherits:
Object
  • Object
show all
Defined in:
lib/gems/activerecord-2.2.2/lib/active_record/reflection.rb

Overview

Abstract base class for AggregateReflection and AssociationReflection that describes the interface available for both of those classes. Objects of AggregateReflection and AssociationReflection are returned by the Reflection::ClassMethods.

Direct Known Subclasses

AggregateReflection, AssociationReflection

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(macro, name, options, active_record) ⇒ MacroReflection

Returns a new instance of MacroReflection.



76
77
78
# File 'lib/gems/activerecord-2.2.2/lib/active_record/reflection.rb', line 76

def initialize(macro, name, options, active_record)
  @macro, @name, @options, @active_record = macro, name, options, active_record
end

Instance Attribute Details

#active_recordObject (readonly)

Returns the value of attribute active_record.



74
75
76
# File 'lib/gems/activerecord-2.2.2/lib/active_record/reflection.rb', line 74

def active_record
  @active_record
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.



112
113
114
# File 'lib/gems/activerecord-2.2.2/lib/active_record/reflection.rb', line 112

def ==(other_aggregation)
  other_aggregation.kind_of?(self.class) && name == other_aggregation.name && other_aggregation.options && active_record == other_aggregation.active_record
end

#belongs_to?Boolean

Returns true if self is a belongs_to reflection.

Returns:

  • (Boolean)


121
122
123
# File 'lib/gems/activerecord-2.2.2/lib/active_record/reflection.rb', line 121

def belongs_to?
  macro == :belongs_to
end

#class_nameObject

Returns the class name for the macro. For example, composed_of :balance, :class_name => 'Money' returns 'Money' and has_many :clients returns 'Client'.



106
107
108
# File 'lib/gems/activerecord-2.2.2/lib/active_record/reflection.rb', line 106

def class_name
  @class_name ||= options[:class_name] || derive_class_name
end

#klassObject

Returns the class for the macro. For example, composed_of :balance, :class_name => 'Money' returns the Money class and has_many :clients returns the Client class.



100
101
102
# File 'lib/gems/activerecord-2.2.2/lib/active_record/reflection.rb', line 100

def klass
  @klass ||= class_name.constantize
end

#macroObject

Returns the macro type. For example, composed_of :balance, :class_name => 'Money' will return :composed_of or for has_many :clients will return :has_many.



88
89
90
# File 'lib/gems/activerecord-2.2.2/lib/active_record/reflection.rb', line 88

def macro
  @macro
end

#nameObject

Returns the name of the macro. For example, composed_of :balance, :class_name => 'Money' will return :balance or for has_many :clients it will return :clients.



82
83
84
# File 'lib/gems/activerecord-2.2.2/lib/active_record/reflection.rb', line 82

def name
  @name
end

#optionsObject

Returns the hash of options used for the macro. For example, it would return { :class_name => "Money" } for composed_of :balance, :class_name => 'Money' or {} for has_many :clients.



94
95
96
# File 'lib/gems/activerecord-2.2.2/lib/active_record/reflection.rb', line 94

def options
  @options
end

#sanitized_conditionsObject

:nodoc:



116
117
118
# File 'lib/gems/activerecord-2.2.2/lib/active_record/reflection.rb', line 116

def sanitized_conditions #:nodoc:
  @sanitized_conditions ||= klass.send(:sanitize_sql, options[:conditions]) if options[:conditions]
end