From 10e8419da621fb4e6a9dd8346a6df8c707f962ba Mon Sep 17 00:00:00 2001 From: nobu Date: Wed, 3 Feb 2010 23:15:55 +0000 Subject: * lib/delegate.rb (Delegator): now inherits BasicObject. [ruby-dev:39154], [Bug #2679], [ruby-dev:40242] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@26566 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ lib/delegate.rb | 31 +++++++++++++++---------------- test/test_delegate.rb | 18 ++++++++++++++++++ 3 files changed, 38 insertions(+), 16 deletions(-) diff --git a/ChangeLog b/ChangeLog index 53184d8099..2d1ae18b46 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Thu Feb 4 08:15:53 2010 Nobuyoshi Nakada + + * lib/delegate.rb (Delegator): now inherits BasicObject. + [ruby-dev:39154], [Bug #2679], [ruby-dev:40242] + Thu Feb 4 03:00:59 2010 Yusuke Endoh * ext/bigdecimal/bigdecimal.c (BigDecimal_DoDivmod): get red of diff --git a/lib/delegate.rb b/lib/delegate.rb index b1f79582f4..473fa0cb8f 100644 --- a/lib/delegate.rb +++ b/lib/delegate.rb @@ -114,11 +114,21 @@ # subclasses. Subclasses should redefine \_\_getobj\_\_. For a concrete # implementation, see SimpleDelegator. # -class Delegator - [:to_s,:inspect,:=~,:!~,:===,:<=>].each do |m| - undef_method m +class Delegator < BasicObject + # :stopdoc: + def class + (class << self; self; end).superclass end + def extend(*mods) + (class << self; self; end).class_eval {include(*mods)} + end + + def self.const_missing(n) + ::Object.const_get(n) + end + # :startdoc: + # # Pass in the _obj_ to delegate method calls to. All methods supported by # _obj_ will be delegated to. @@ -131,12 +141,12 @@ class Delegator def method_missing(m, *args, &block) begin target = self.__getobj__ - unless target.respond_to?(m) + unless target.respond_to?(m, true) super(m, *args, &block) else target.__send__(m, *args, &block) end - rescue Exception + rescue ::Exception if i = $@.index{|s| %r"\A#{Regexp.quote(__FILE__)}:\d+:in `method_missing'\z"o =~ s} $@[0..i] = [] end @@ -248,17 +258,6 @@ class SimpleDelegator