aboutsummaryrefslogtreecommitdiffstats
path: root/vm_insnhelper.c
diff options
context:
space:
mode:
Diffstat (limited to 'vm_insnhelper.c')
-rw-r--r--vm_insnhelper.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/vm_insnhelper.c b/vm_insnhelper.c
index ae6195ef4c..9a615df26f 100644
--- a/vm_insnhelper.c
+++ b/vm_insnhelper.c
@@ -2246,11 +2246,12 @@ vm_super_outside(void)
static void
vm_search_super_method(rb_thread_t *th, rb_control_frame_t *reg_cfp,
- struct rb_calling_info *calling, struct rb_call_info *ci, struct rb_call_cache *cc)
+ struct rb_calling_info *calling, const struct rb_call_info *ci, struct rb_call_cache *cc)
{
VALUE current_defined_class, klass;
VALUE sigval = TOPN(calling->argc);
const rb_callable_method_entry_t *me = rb_vm_frame_method_entry(reg_cfp);
+ ID mid;
if (!me) {
vm_super_outside();
@@ -2282,7 +2283,7 @@ vm_search_super_method(rb_thread_t *th, rb_control_frame_t *reg_cfp,
" Specify all arguments explicitly.");
}
- ci->mid = me->def->original_id;
+ mid = me->def->original_id;
klass = vm_search_normal_superclass(me->defined_class);
if (!klass) {
@@ -2292,7 +2293,7 @@ vm_search_super_method(rb_thread_t *th, rb_control_frame_t *reg_cfp,
}
else {
/* TODO: use inline cache */
- cc->me = rb_callable_method_entry(klass, ci->mid);
+ cc->me = rb_callable_method_entry(klass, mid);
CI_SET_FASTPATH(cc, vm_call_super_method, 1);
}
}