summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2018-09-21 10:27:09 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2018-09-26 12:17:38 +0900
commit78195eb2aeb6dbb9eea7d10cd4d5ac7caaa1bab7 (patch)
tree60e087645c3c16578d11c12f74bb76a333b67000 /src
parent09a99154c03919c71e5ea195c88c1a0251218cb2 (diff)
downloadmruby-78195eb2aeb6dbb9eea7d10cd4d5ac7caaa1bab7.tar.gz
mruby-78195eb2aeb6dbb9eea7d10cd4d5ac7caaa1bab7.zip
Small refactoring in vm.c
Diffstat (limited to 'src')
-rw-r--r--src/vm.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/src/vm.c b/src/vm.c
index cba6c3924..9eeb388fc 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -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;