diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-03-01 12:58:31 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-03-01 12:58:31 +0900 |
| commit | 8e170ce915626bb57ecad7e54d8fe207676d593e (patch) | |
| tree | 9e0e4e01e68a7255c32f63bcc6df0a47e1bfe767 /src/vm.c | |
| parent | bed4dcb1622051282cca55b2c92dec9058688d86 (diff) | |
| download | mruby-8e170ce915626bb57ecad7e54d8fe207676d593e.tar.gz mruby-8e170ce915626bb57ecad7e54d8fe207676d593e.zip | |
exception in fiber should make resume to raise in parent fiber context; close #1765
Diffstat (limited to 'src/vm.c')
| -rw-r--r-- | src/vm.c | 13 |
1 files changed, 11 insertions, 2 deletions
@@ -1300,8 +1300,17 @@ mrb_context_run(mrb_state *mrb, struct RProc *proc, mrb_value self, unsigned int } else if (ci == mrb->c->cibase) { if (ci->ridx == 0) { - regs = mrb->c->stack = mrb->c->stbase; - goto L_STOP; + if (mrb->c == mrb->root_c) { + regs = mrb->c->stack = mrb->c->stbase; + goto L_STOP; + } + else { + struct mrb_context *c = mrb->c; + + mrb->c = c->prev; + c->prev = NULL; + goto L_RAISE; + } } break; } |
