diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2018-09-21 10:27:09 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2018-09-26 12:17:38 +0900 |
| commit | 78195eb2aeb6dbb9eea7d10cd4d5ac7caaa1bab7 (patch) | |
| tree | 60e087645c3c16578d11c12f74bb76a333b67000 | |
| parent | 09a99154c03919c71e5ea195c88c1a0251218cb2 (diff) | |
| download | mruby-78195eb2aeb6dbb9eea7d10cd4d5ac7caaa1bab7.tar.gz mruby-78195eb2aeb6dbb9eea7d10cd4d5ac7caaa1bab7.zip | |
Small refactoring in vm.c
| -rw-r--r-- | src/vm.c | 9 |
1 files changed, 4 insertions, 5 deletions
@@ -2054,22 +2054,21 @@ RETRY_TRY_BLOCK: case OP_R_NORMAL: NORMAL_RETURN: if (ci == mrb->c->cibase) { - struct mrb_context *c; + struct mrb_context *c = mrb->c; - if (!mrb->c->prev) { /* toplevel return */ + if (!c->prev) { /* toplevel return */ regs[irep->nlocals] = v; goto L_STOP; } - if (mrb->c->prev->ci == mrb->c->prev->cibase) { + if (c->prev->ci == c->prev->cibase) { mrb_value exc = mrb_exc_new_str_lit(mrb, E_FIBER_ERROR, "double resume"); mrb_exc_set(mrb, exc); goto L_RAISE; } - while (mrb->c->eidx > 0) { + while (c->eidx > 0) { ecall(mrb); } /* automatic yield at the end */ - c = mrb->c; c->status = MRB_FIBER_TERMINATED; mrb->c = c->prev; c->prev = NULL; |
