summaryrefslogtreecommitdiff
path: root/lib/delegate.rb
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-10-16 11:04:15 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-10-16 11:04:15 +0000
commitfbf15be35fcf26919c0709e0cd971fe68835e762 (patch)
tree749609486af2a6813e3f84d18cc91d3b2b7501db /lib/delegate.rb
parent9bcccca47a8a8800a1ac09eeb35dfe5135ca079f (diff)
* lib/delegate.rb (Delegator#respond_to_missing): warn if optional
include_private argument is not false. Delegator does (and should) not forward private methods. [ruby-core:26080] * lib/delegate.rb (Delegator#respond_to_missing): instead of redefining #respond_to?, use #respond_to_missing?. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@25372 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/delegate.rb')
-rw-r--r--lib/delegate.rb8
1 files changed, 5 insertions, 3 deletions
diff --git a/lib/delegate.rb b/lib/delegate.rb
index 57c479c61b..215ebf5e4d 100644
--- a/lib/delegate.rb
+++ b/lib/delegate.rb
@@ -146,9 +146,11 @@ class Delegator
# Checks for a method provided by this the delegate object by fowarding the
# call through \_\_getobj\_\_.
#
- def respond_to?(m, include_private = false)
- return true if super
- return self.__getobj__.respond_to?(m, include_private)
+ def respond_to_missing?(m, include_private = false)
+ if include_private
+ warn "#{caller(3)[0]}: delegator does not forward private methods"
+ end
+ self.__getobj__.respond_to?(m)
end
#