summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2017-04-12 11:01:23 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2017-04-12 11:01:23 +0900
commit4e84bdb507885bd37b4b0fa6b6359ac8c8b7b886 (patch)
tree9dabc26422c0dc570fbaea3f81d0fde71f1e1f42
parent0fb05eb55f881b3508584cb3b199bddd37dc8825 (diff)
downloadmruby-4e84bdb507885bd37b4b0fa6b6359ac8c8b7b886.tar.gz
mruby-4e84bdb507885bd37b4b0fa6b6359ac8c8b7b886.zip
Let 'mrb_vm_run()` to restore the calling fiber; ref #3537
-rw-r--r--mrbgems/mruby-bin-mirb/tools/mirb/mirb.c2
-rw-r--r--src/vm.c10
2 files changed, 7 insertions, 5 deletions
diff --git a/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c b/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c
index deabd591c..d633a09b2 100644
--- a/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c
+++ b/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c
@@ -551,8 +551,6 @@ done:
mrb_top_self(mrb),
stack_keep);
stack_keep = proc->body.irep->nlocals;
- /* restore to fiber */
- mrb->c = mrb->root_c;
/* did an exception occur? */
if (mrb->exc) {
p(mrb, mrb_obj_value(mrb->exc), 0);
diff --git a/src/vm.c b/src/vm.c
index a9c72cec5..331ea3c3c 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -816,15 +816,19 @@ MRB_API mrb_value
mrb_vm_run(mrb_state *mrb, struct RProc *proc, mrb_value self, unsigned int stack_keep)
{
mrb_irep *irep = proc->body.irep;
+ mrb_value result;
+ struct mrb_context *c = mrb->c;
- if (!mrb->c->stack) {
+ if (!c->stack) {
stack_init(mrb);
}
if (stack_keep < irep->nregs)
stack_keep = irep->nregs;
stack_extend(mrb, stack_keep);
- mrb->c->stack[0] = self;
- return mrb_vm_exec(mrb, proc, irep->iseq);
+ c->stack[0] = self;
+ result = mrb_vm_exec(mrb, proc, irep->iseq);
+ mrb->c = c;
+ return result;
}
MRB_API mrb_value