summaryrefslogtreecommitdiff
path: root/insns.def
diff options
context:
space:
mode:
authorshugo <shugo@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-08-23 04:00:25 +0000
committershugo <shugo@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-08-23 04:00:25 +0000
commit55cf24d3789486328e9a2ea734f42fb9122056e9 (patch)
treeb0432f19ef5949373e2885b7d5adfd606154cd73 /insns.def
parent742a0d164e127394b438d6b83a8d65b4c16f1981 (diff)
* insns.def (invokesuper): reverted r36640 partially to make super
in a thread work correctly. [ruby-core:47284] [Bug #6907] * test/ruby/test_super.rb: related test. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@36795 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'insns.def')
-rw-r--r--insns.def19
1 files changed, 3 insertions, 16 deletions
diff --git a/insns.def b/insns.def
index f9e582efb0..7c9dd6ae6c 100644
--- a/insns.def
+++ b/insns.def
@@ -1026,8 +1026,6 @@ invokesuper
int num = caller_setup_args(th, GET_CFP(), flag,
(int)op_argc, blockiseq, &blockptr);
VALUE recv, klass;
- rb_control_frame_t *cfp = GET_CFP();
- rb_control_frame_t *end_cfp = RUBY_VM_END_CONTROL_FRAME(th);
ID id;
const rb_method_entry_t *me;
rb_iseq_t *ip;
@@ -1038,20 +1036,9 @@ invokesuper
if (!NIL_P(RCLASS_REFINED_CLASS(klass))) {
klass = RCLASS_REFINED_CLASS(klass);
}
-
- recv = Qundef;
- while (RUBY_VM_VALID_CONTROL_FRAME_P(cfp, end_cfp)) {
- if (((VM_EP_LEP_P(cfp->ep) && cfp->iseq &&
- cfp->iseq->type == ISEQ_TYPE_METHOD) ||
- (cfp->me && cfp->me->def->type == VM_METHOD_TYPE_BMETHOD)) &&
- rb_obj_is_kind_of(cfp->self, klass)) {
- recv = cfp->self;
- break;
- }
- cfp = RUBY_VM_PREVIOUS_CONTROL_FRAME(cfp);
- }
- if (recv == Qundef) {
- rb_raise(rb_eNoMethodError, "super called outside of method");
+ recv = GET_SELF();
+ if (!rb_obj_is_kind_of(recv, klass)) {
+ rb_raise(rb_eNotImpError, "super from singleton method that is defined to multiple classes is not supported; this will be fixed in 2.0.0 or later");
}
vm_search_superclass(GET_CFP(), GET_ISEQ(), TOPN(num), &id, &klass);