diff options
| author | Tomasz Dąbrowski <[email protected]> | 2017-04-24 23:57:39 +0200 |
|---|---|---|
| committer | Tomasz Dąbrowski <[email protected]> | 2017-04-24 23:57:39 +0200 |
| commit | b1120464e0b0cd1dc2f90e790249e78c4843bee9 (patch) | |
| tree | 04f94c352fb1d80e574896de9387c435f689bc64 /src/vm.c | |
| parent | 6088276cc833c104d0228f5c03140601c7fc06df (diff) | |
| download | mruby-b1120464e0b0cd1dc2f90e790249e78c4843bee9.tar.gz mruby-b1120464e0b0cd1dc2f90e790249e78c4843bee9.zip | |
Revert "Simplify pointer calculation in `envadjust`."
This reverts commit a1d32af91692c2b624e9c04fcd94aa958dbba626.
Diffstat (limited to 'src/vm.c')
| -rw-r--r-- | src/vm.c | 8 |
1 files changed, 4 insertions, 4 deletions
@@ -118,16 +118,16 @@ static inline void envadjust(mrb_state *mrb, mrb_value *oldbase, mrb_value *newbase) { mrb_callinfo *ci = mrb->c->cibase; - ptrdiff_t off; if (newbase == oldbase) return; - off = newbase - oldbase; while (ci <= mrb->c->ci) { struct REnv *e = ci->env; if (e && MRB_ENV_STACK_SHARED_P(e)) { - e->stack += off; + ptrdiff_t off = e->stack - oldbase; + + e->stack = newbase + off; } - ci->stackent += off; + ci->stackent = newbase + (ci->stackent - oldbase); ci++; } } |
