summaryrefslogtreecommitdiffhomepage
path: root/src/vm.c
diff options
context:
space:
mode:
authorYukihiro Matsumoto <[email protected]>2012-05-06 00:18:46 +0900
committerYukihiro Matsumoto <[email protected]>2012-05-06 00:18:46 +0900
commit55da4cdc86d7c766c78a3f4c980a63eb7d991aa1 (patch)
tree96bca7246f704b55bb3b29f6246e42fc34dd009b /src/vm.c
parent803dcb512e2d01eae2fda0fa2db8953a3c485956 (diff)
parent91a90540737ddc233d0c68dea05d779fafc32e8e (diff)
downloadmruby-55da4cdc86d7c766c78a3f4c980a63eb7d991aa1.tar.gz
mruby-55da4cdc86d7c766c78a3f4c980a63eb7d991aa1.zip
Merge branch 'master' of github.com:mruby/mruby
Diffstat (limited to 'src/vm.c')
-rw-r--r--src/vm.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/src/vm.c b/src/vm.c
index 9915200de..f2f59cfbb 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -268,7 +268,7 @@ localjump_error(mrb_state *mrb, const char *kind)
mrb_value exc;
snprintf(buf, 256, "unexpected %s", kind);
- exc = mrb_exc_new(mrb, E_LOCALJUMP_ERROR, buf, sizeof(buf));
+ exc = mrb_exc_new(mrb, E_LOCALJUMP_ERROR, buf, strlen(buf));
mrb->exc = mrb_object(exc);
}
@@ -992,6 +992,7 @@ mrb_run(mrb_state *mrb, struct RProc *proc, mrb_value self)
case OP_R_RETURN:
if (proc->env->cioff < 0) {
localjump_error(mrb, "return");
+ goto L_RAISE;
}
ci = mrb->ci = mrb->cibase + proc->env->cioff;
break;