aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2014-06-13 19:33:24 -0300
committerRafael Mendonça França <rafaelmfranca@gmail.com>2014-06-13 19:33:24 -0300
commit2324495d5f39fbbb83e035bdc2210f46e9cbd6c6 (patch)
treedb52727afbcad39c1b54da30480bf4aa165c6eb0
parentbcb0b99fe94d7f8ad5404cb0d90b9348a68e1d23 (diff)
parent84cf156e2428551069d6fba5547fc41bc42182b2 (diff)
downloadrails-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.rb35
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.