summaryrefslogtreecommitdiffhomepage
path: root/src/vm.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2013-10-15 15:34:33 -0700
committerYukihiro "Matz" Matsumoto <[email protected]>2013-10-15 15:34:33 -0700
commitdef683ae72827a20b99ef1129dd59ea8f0c891dd (patch)
tree2ac9e802dbe37ddd949eaf67a1712eaf9dd9536f /src/vm.c
parenta7c9a71684fccf8121f16803f8e3d758f0dea001 (diff)
parent11c4d81539eca8198bc702a91c8607c06e04e61e (diff)
downloadmruby-def683ae72827a20b99ef1129dd59ea8f0c891dd.tar.gz
mruby-def683ae72827a20b99ef1129dd59ea8f0c891dd.zip
Merge pull request #1538 from carsonmcdonald/conststackfix
Set regs to stack on return of const_get calls before use
Diffstat (limited to 'src/vm.c')
-rw-r--r--src/vm.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/src/vm.c b/src/vm.c
index 9b673cd0f..1cb2a83e9 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -702,7 +702,9 @@ mrb_run(mrb_state *mrb, struct RProc *proc, mrb_value self)
CASE(OP_GETCONST) {
/* A B R(A) := constget(Sym(B)) */
ERR_PC_HOOK(mrb, pc);
- regs[GETARG_A(i)] = mrb_vm_const_get(mrb, syms[GETARG_Bx(i)]);
+ mrb_value val = mrb_vm_const_get(mrb, syms[GETARG_Bx(i)]);
+ regs = mrb->c->stack;
+ regs[GETARG_A(i)] = val;
NEXT;
}
@@ -717,7 +719,9 @@ mrb_run(mrb_state *mrb, struct RProc *proc, mrb_value self)
int a = GETARG_A(i);
ERR_PC_HOOK(mrb, pc);
- regs[a] = mrb_const_get(mrb, regs[a], syms[GETARG_Bx(i)]);
+ mrb_value val = mrb_const_get(mrb, regs[a], syms[GETARG_Bx(i)]);
+ regs = mrb->c->stack;
+ regs[a] = val;
NEXT;
}