From 959d5febcf0cdd2f4d81a1bb91bcd8d9fee83f2f Mon Sep 17 00:00:00 2001 From: matz Date: Mon, 22 Oct 2001 06:48:18 +0000 Subject: * class.c (rb_mod_clone): should not copy class name, since clone should remain anonymous. * eval.c (rb_call0): self in a block given to define_method now be switched to the receiver of the method. * eval.c (proc_invoke): added new parameter to allow self switching. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@1795 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- class.c | 6 ++++++ 1 file changed, 6 insertions(+) (limited to 'class.c') diff --git a/class.c b/class.c index a7911e8b96..4701054383 100644 --- a/class.c +++ b/class.c @@ -66,7 +66,13 @@ rb_mod_clone(module) RCLASS(clone)->super = RCLASS(module)->super; if (RCLASS(module)->iv_tbl) { + ID id; + RCLASS(clone)->iv_tbl = st_copy(RCLASS(module)->iv_tbl); + id = rb_intern("__classpath__"); + st_delete(RCLASS(clone)->iv_tbl, &id, 0); + id = rb_intern("__classid__"); + st_delete(RCLASS(clone)->iv_tbl, &id, 0); } if (RCLASS(module)->m_tbl) { RCLASS(clone)->m_tbl = st_init_numtable(); -- cgit v1.2.3