From 16a68369d2c12dd6aae1b902aac5fe72b9ee9ec9 Mon Sep 17 00:00:00 2001 From: ko1 Date: Tue, 7 Jul 2015 02:27:41 +0000 Subject: * iseq.c, internal.h (rb_iseq_clone): removed because we don't need to clone iseq any more. * class.c (clone_method): share iseq between cloned methods. All of method dependent information are able to refer from method entry. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@51171 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- class.c | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) (limited to 'class.c') diff --git a/class.c b/class.c index 0521cf96c3..46a0d617ad 100644 --- a/class.c +++ b/class.c @@ -244,11 +244,9 @@ static void clone_method(VALUE old_klass, VALUE new_klass, ID mid, const rb_method_entry_t *me) { if (me->def->type == VM_METHOD_TYPE_ISEQ) { - VALUE newiseqval; rb_cref_t *new_cref; - newiseqval = rb_iseq_clone(me->def->body.iseq.iseqptr->self, new_klass); rb_vm_rewrite_cref(me->def->body.iseq.cref, old_klass, new_klass, &new_cref); - rb_add_method_iseq(new_klass, mid, newiseqval, new_cref, METHOD_ENTRY_VISI(me)); + rb_add_method_iseq(new_klass, mid, me->def->body.iseq.iseqptr->self, new_cref, METHOD_ENTRY_VISI(me)); } else { rb_method_entry_set(new_klass, mid, me, METHOD_ENTRY_VISI(me)); -- cgit v1.2.3