summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2013-02-26 23:31:38 -0800
committerYukihiro "Matz" Matsumoto <[email protected]>2013-02-26 23:31:38 -0800
commit01274bcc4685a8adeacffa01e5ec5230bedc79ab (patch)
tree6d4e61de0505806995a42e4aac364e8dd4cd9618
parentdfafa59c0a79d77c1d00d5dd2ad29c5ab4c6a006 (diff)
parent5de62ac23ddd35d027567aec9b7a023ed6698577 (diff)
downloadmruby-01274bcc4685a8adeacffa01e5ec5230bedc79ab.tar.gz
mruby-01274bcc4685a8adeacffa01e5ec5230bedc79ab.zip
Merge pull request #890 from cremno/mrb_funcall--adjust-ci-and-sp-after-error
mrb_funcall_with_block: raised exception corrupts ci and stack
-rw-r--r--src/vm.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/src/vm.c b/src/vm.c
index e4b283849..febb4dbd2 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -316,8 +316,13 @@ mrb_funcall_with_block(mrb_state *mrb, mrb_value self, mrb_sym mid, int argc, mr
if (!mrb->jmp) {
jmp_buf c_jmp;
+ mrb_callinfo *old_ci = mrb->ci;
if (setjmp(c_jmp) != 0) { /* error */
+ while (old_ci != mrb->ci) {
+ mrb->stack = mrb->stbase + mrb->ci->stackidx;
+ cipop(mrb);
+ }
mrb->jmp = 0;
return mrb_nil_value();
}