summaryrefslogtreecommitdiffhomepage
path: root/src/vm.c
diff options
context:
space:
mode:
authorTomasz Dąbrowski <[email protected]>2017-04-24 23:57:39 +0200
committerTomasz Dąbrowski <[email protected]>2017-04-24 23:57:39 +0200
commitb1120464e0b0cd1dc2f90e790249e78c4843bee9 (patch)
tree04f94c352fb1d80e574896de9387c435f689bc64 /src/vm.c
parent6088276cc833c104d0228f5c03140601c7fc06df (diff)
downloadmruby-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.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/src/vm.c b/src/vm.c
index 47ad9a9cc..8b14566c1 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -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++;
}
}