diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2014-01-30 10:32:32 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2014-01-30 10:32:32 +0000 |
commit | 0cc7cd22cf71bdc3a1e9291187bdfda13257cff9 (patch) | |
tree | fb6c3ad98ccc97688036f4e7af77e09955b3d6e3 /vm_eval.c | |
parent | e10bc03520f85364db117a0e40efd1b8ef6e271c (diff) |
vm_eval.c: fix NoMethodError message
* vm_eval.c (vm_call0_body): reuse method type.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@44763 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'vm_eval.c')
-rw-r--r-- | vm_eval.c | 5 |
1 files changed, 3 insertions, 2 deletions
@@ -188,8 +188,8 @@ vm_call0_body(rb_thread_t* th, rb_call_info_t *ci, const VALUE *argv) case VM_METHOD_TYPE_ZSUPER: case VM_METHOD_TYPE_REFINED: { - int ex = ci->me->def->type == VM_METHOD_TYPE_ZSUPER ? NOEX_SUPER : 0; - if (ci->me->def->type == VM_METHOD_TYPE_REFINED && + const rb_method_type_t type = ci->me->def->type; + if (type == VM_METHOD_TYPE_REFINED && ci->me->def->body.orig_me) { ci->me = ci->me->def->body.orig_me; goto again; @@ -198,6 +198,7 @@ vm_call0_body(rb_thread_t* th, rb_call_info_t *ci, const VALUE *argv) ci->defined_class = RCLASS_SUPER(ci->defined_class); if (!ci->defined_class || !(ci->me = rb_method_entry(ci->defined_class, ci->mid, &ci->defined_class))) { + int ex = VM_METHOD_TYPE_ZSUPER ? NOEX_SUPER : 0; ret = method_missing(ci->recv, ci->mid, ci->argc, argv, ex); goto success; } |