summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2018-11-19 09:50:31 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2018-11-19 09:50:31 +0900
commit31a961acf16b7a9454ccb0f0ece91b79e95f7078 (patch)
treeafcdd93fa0d733b8fa1ba1cc86f13197fe963710 /src
parentcab6b0f39b77098425b1c3c80e8e1d193d5882c8 (diff)
downloadmruby-31a961acf16b7a9454ccb0f0ece91b79e95f7078.tar.gz
mruby-31a961acf16b7a9454ccb0f0ece91b79e95f7078.zip
The current context may be changed in `mrb_vm_exec`; ref #3668 #4104
Diffstat (limited to 'src')
-rw-r--r--src/vm.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/vm.c b/src/vm.c
index b899a2d70..2d12df4ba 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -973,15 +973,15 @@ mrb_vm_run(mrb_state *mrb, struct RProc *proc, mrb_value self, unsigned int stac
stack_clear(c->stack + stack_keep, nregs - stack_keep);
c->stack[0] = self;
result = mrb_vm_exec(mrb, proc, irep->iseq);
- if (c->ci - c->cibase > cioff) {
- c->ci = c->cibase + cioff;
- }
if (mrb->c != c) {
if (mrb->c->fib) {
mrb_write_barrier(mrb, (struct RBasic*)mrb->c->fib);
}
mrb->c = c;
}
+ else if (c->ci - c->cibase > cioff) {
+ c->ci = c->cibase + cioff;
+ }
return result;
}