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