instance method
define_method_attribute
Ruby on Rails 4.0.13
Since v3.0.20 Last seen in v4.2.9Signature
define_method_attribute(name)
We want to generate the methods via module_eval rather than define_method, because define_method is slower on dispatch. Evaluating many similar methods may use more memory as the instruction sequences are duplicated and cached (in MRI). define_method may be slower on dispatch, but if you’re careful about the closure created, then define_method will consume much less memory.
But sometimes the database might return columns with characters that are not allowed in normal method names (like ‘my_column(omg)’. So to work around this we first define with the __temp__ identifier, and then use alias method to rename it to what we want.
We are also defining a constant to hold the frozen string of the attribute name. Using a constant means that we do not have to allocate an object on each call to the attribute method. Making it frozen means that it doesn’t get duped when used to key the @attributes_cache in read_attribute.
Parameters
-
namereq
Source
# File activerecord/lib/active_record/attribute_methods/read.rb, line 53
def define_method_attribute(name)
safe_name = name.unpack('h*').first
generated_attribute_methods::AttrNames.set_name_cache safe_name, name
generated_attribute_methods.module_eval <<-STR, __FILE__, __LINE__ + 1
def __temp__#{safe_name}
read_attribute(AttrNames::ATTR_#{safe_name}) { |n| missing_attribute(n, caller) }
end
alias_method #{name.inspect}, :__temp__#{safe_name}
undef_method :__temp__#{safe_name}
STR
end
Defined in activerecord/lib/active_record/attribute_methods/read.rb line 53
· View on GitHub
· Improve this page
· Find usages on GitHub
Defined in ActiveRecord::AttributeMethods::Read::ClassMethods