From 00f34f92741b4092a5f53afff0b9f01679325247 Mon Sep 17 00:00:00 2001 From: usa Date: Mon, 4 Feb 2008 05:01:00 +0000 Subject: * lib/delegate.rb (Delegator.preserved, DelegateClass.methods): extend shouldn't be delegated. [ruby-dev:32987], etc. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@15372 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ lib/delegate.rb | 8 +++++--- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/ChangeLog b/ChangeLog index 6a936c17bd..50509f77ce 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Mon Feb 4 13:58:42 2008 NAKAMURA Usaku + + * lib/delegate.rb (Delegator.preserved, DelegateClass.methods): extend + shouldn't be delegated. [ruby-dev:32987], etc. + Mon Feb 4 08:59:31 2008 Yukihiro Matsumoto * lib/cgi.rb (CGI::QueryExtension::[]): no more transition diff --git a/lib/delegate.rb b/lib/delegate.rb index f4068f1b32..970bb9d342 100644 --- a/lib/delegate.rb +++ b/lib/delegate.rb @@ -115,9 +115,10 @@ # implementation, see SimpleDelegator. # class Delegator - preserved = [:__id__, :object_id, :__send__, :public_send, :respond_to?, :send, - :instance_eval, :instance_exec, - ] + preserved = [ + :__id__, :object_id, :__send__, :public_send, :respond_to?, :send, + :instance_eval, :instance_exec, :extend, + ] instance_methods.each do |m| next if preserved.include?(m) undef_method m @@ -267,6 +268,7 @@ def DelegateClass(superclass) :__id__, :object_id, :__send__, :public_send, :respond_to?, :send, :==, :equal?, :initialize, :method_missing, :__getobj__, :__setobj__, :clone, :dup, :marshal_dump, :marshal_load, :instance_eval, :instance_exec, + :extend, ] klass.module_eval { include Delegator::MethodDelegation -- cgit v1.2.3