diff options
| author | sasaki takeru <[email protected]> | 2014-05-04 22:39:51 +0900 |
|---|---|---|
| committer | sasaki takeru <[email protected]> | 2014-05-04 22:39:51 +0900 |
| commit | b59ac841af654179f27e3d19026eafe7638a1ee8 (patch) | |
| tree | 548da6319bec2ad85347126d82529d595655f9fd /src | |
| parent | e9e4c13390eb5f135182449a951d6b6eec05b2e9 (diff) | |
| download | mruby-b59ac841af654179f27e3d19026eafe7638a1ee8.tar.gz mruby-b59ac841af654179f27e3d19026eafe7638a1ee8.zip | |
Don't reset ridx,eidx. And fix for #1949
Diffstat (limited to 'src')
| -rw-r--r-- | src/vm.c | 10 |
1 files changed, 4 insertions, 6 deletions
@@ -2251,10 +2251,10 @@ RETRY_TRY_BLOCK: /* stop VM */ L_STOP: { - int n = mrb->c->ci->eidx; - - while (n--) { - ecall(mrb, n); + int eidx_stop = mrb->c->ci == mrb->c->cibase ? 0 : mrb->c->ci[-1].eidx; + int eidx = mrb->c->ci->eidx; + while (eidx > eidx_stop) { + ecall(mrb, --eidx); } } ERR_PC_CLR(mrb); @@ -2307,8 +2307,6 @@ mrb_toplevel_run(mrb_state *mrb, struct RProc *proc) } ci = cipush(mrb); ci->acc = CI_ACC_SKIP; - ci->eidx = 0; - ci->ridx = 0; ci->target_class = mrb->object_class; v = mrb_context_run(mrb, proc, mrb_top_self(mrb), 0); cipop(mrb); |
