mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
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
This commit is contained in:
parent
e10bc03520
commit
0cc7cd22cf
1 changed files with 3 additions and 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;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue