summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorMasamitsu MURASE <[email protected]>2012-08-21 01:16:56 +0900
committerMasamitsu MURASE <[email protected]>2012-08-21 01:16:56 +0900
commit345ba3a66fb8460008c1ae7b9cf6b1bfc95f3dc0 (patch)
treeeb6c5d66975ee8cf87cd8b5def7e8c56ec1bcf2e /src
parent72bc9c8e46931abafb22f70f4b6a755766a773aa (diff)
downloadmruby-345ba3a66fb8460008c1ae7b9cf6b1bfc95f3dc0.tar.gz
mruby-345ba3a66fb8460008c1ae7b9cf6b1bfc95f3dc0.zip
Refer to mrb->ci instead of local variable `ci` after m->body.func is called,
because mrb->ci may be changed in m->body.func.
Diffstat (limited to 'src')
-rw-r--r--src/vm.c12
1 files changed, 6 insertions, 6 deletions
diff --git a/src/vm.c b/src/vm.c
index cff09c96e..736b69b67 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -287,7 +287,7 @@ mrb_funcall_with_block(mrb_state *mrb, mrb_value self, mrb_sym mid, int argc, mr
val = p->body.func(mrb, self);
mrb->arena_idx = ai;
mrb_gc_protect(mrb, val);
- mrb->stack = mrb->stbase + ci->stackidx;
+ mrb->stack = mrb->stbase + mrb->ci->stackidx;
cipop(mrb);
}
else {
@@ -331,7 +331,7 @@ mrb_yield_internal(mrb_state *mrb, mrb_value b, int argc, mrb_value *argv, mrb_v
if (MRB_PROC_CFUNC_P(p)) {
val = p->body.func(mrb, self);
- mrb->stack = mrb->stbase + ci->stackidx;
+ mrb->stack = mrb->stbase + mrb->ci->stackidx;
cipop(mrb);
}
else {
@@ -772,7 +772,7 @@ mrb_run(mrb_state *mrb, struct RProc *proc, mrb_value self)
mrb->arena_idx = ai;
if (mrb->exc) goto L_RAISE;
/* pop stackpos */
- regs = mrb->stack = mrb->stbase + ci->stackidx;
+ regs = mrb->stack = mrb->stbase + mrb->ci->stackidx;
cipop(mrb);
NEXT;
}
@@ -830,7 +830,7 @@ mrb_run(mrb_state *mrb, struct RProc *proc, mrb_value self)
mrb->arena_idx = ai;
if (mrb->exc) goto L_RAISE;
/* pop stackpos */
- regs = mrb->stack = mrb->stbase + ci->stackidx;
+ regs = mrb->stack = mrb->stbase + mrb->ci->stackidx;
cipop(mrb);
NEXT;
}
@@ -903,7 +903,7 @@ mrb_run(mrb_state *mrb, struct RProc *proc, mrb_value self)
mrb->arena_idx = ai;
if (mrb->exc) goto L_RAISE;
/* pop stackpos */
- regs = mrb->stack = mrb->stbase + ci->stackidx;
+ regs = mrb->stack = mrb->stbase + mrb->ci->stackidx;
cipop(mrb);
NEXT;
}
@@ -1619,7 +1619,7 @@ mrb_run(mrb_state *mrb, struct RProc *proc, mrb_value self)
mrb->arena_idx = ai;
if (mrb->exc) goto L_RAISE;
/* pop stackpos */
- regs = mrb->stack = mrb->stbase + ci->stackidx;
+ regs = mrb->stack = mrb->stbase + mrb->ci->stackidx;
cipop(mrb);
NEXT;
}