diff options
author | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2014-06-13 19:33:24 -0300 |
---|---|---|
committer | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2014-06-13 19:33:24 -0300 |
commit | 2324495d5f39fbbb83e035bdc2210f46e9cbd6c6 (patch) | |
tree | db52727afbcad39c1b54da30480bf4aa165c6eb0 | |
parent | bcb0b99fe94d7f8ad5404cb0d90b9348a68e1d23 (diff) | |
parent | 84cf156e2428551069d6fba5547fc41bc42182b2 (diff) | |
download | rails-2324495d5f39fbbb83e035bdc2210f46e9cbd6c6.tar.gz rails-2324495d5f39fbbb83e035bdc2210f46e9cbd6c6.tar.bz2 rails-2324495d5f39fbbb83e035bdc2210f46e9cbd6c6.zip |
Merge pull request #15694 from sgrif/sg-method-missing
Remove unused `method_missing` definition
-rw-r--r-- | activerecord/lib/active_record/attribute_methods.rb | 35 |
1 files changed, 1 insertions, 34 deletions
diff --git a/activerecord/lib/active_record/attribute_methods.rb b/activerecord/lib/active_record/attribute_methods.rb index ddccb29d09..b4d75d6556 100644 --- a/activerecord/lib/active_record/attribute_methods.rb +++ b/activerecord/lib/active_record/attribute_methods.rb @@ -156,16 +156,6 @@ module ActiveRecord end end - def find_generated_attribute_method(method_name) # :nodoc: - klass = self - until klass == Base - gen_methods = klass.generated_attribute_methods - return gen_methods.instance_method(method_name) if method_defined_within?(method_name, gen_methods, Object) - klass = klass.superclass - end - nil - end - # Returns +true+ if +attribute+ is an attribute method and table exists, # +false+ otherwise. # @@ -216,25 +206,6 @@ module ActiveRecord end end - # If we haven't generated any methods yet, generate them, then - # see if we've created the method we're looking for. - def method_missing(method, *args, &block) # :nodoc: - self.class.define_attribute_methods - if respond_to_without_attributes?(method) - # make sure to invoke the correct attribute method, as we might have gotten here via a `super` - # call in a overwritten attribute method - if attribute_method = self.class.find_generated_attribute_method(method) - # this is probably horribly slow, but should only happen at most once for a given AR class - attribute_method.bind(self).call(*args, &block) - else - return super unless respond_to_missing?(method, true) - send(method, *args, &block) - end - else - super - end - end - # A Person object with a name attribute can ask <tt>person.respond_to?(:name)</tt>, # <tt>person.respond_to?(:name=)</tt>, and <tt>person.respond_to?(:name?)</tt> # which will all return +true+. It also define the attribute methods if they have @@ -252,12 +223,8 @@ module ActiveRecord # person.respond_to('age?') # => true # person.respond_to(:nothing) # => false def respond_to?(name, include_private = false) + return false unless super name = name.to_s - self.class.define_attribute_methods - result = super - - # If the result is false the answer is false. - return false unless result # If the result is true then check for the select case. # For queries selecting a subset of columns, return false for unselected columns. |