summaryrefslogtreecommitdiffhomepage
path: root/tools
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2012-10-31 12:26:43 -0700
committerYukihiro "Matz" Matsumoto <[email protected]>2012-10-31 12:26:43 -0700
commitc812c5c815153dc7a5028304f672ad373085edf2 (patch)
tree08d6c0176e0dbb26a5ad5b0384ff25a5659af921 /tools
parent8cf42709d1933ad450120dff145723acba1fbc68 (diff)
parent38fb8b07c6c39f42898b4e1c14a8cd524cc022b8 (diff)
downloadmruby-c812c5c815153dc7a5028304f672ad373085edf2.tar.gz
mruby-c812c5c815153dc7a5028304f672ad373085edf2.zip
Merge pull request #519 from iij/pr-mruby-exit-status-with-mrb
fix mruby exit status with mrb file.
Diffstat (limited to 'tools')
-rw-r--r--tools/mruby/mruby.c14
1 files changed, 8 insertions, 6 deletions
diff --git a/tools/mruby/mruby.c b/tools/mruby/mruby.c
index cbe170e7f..db26d23a1 100644
--- a/tools/mruby/mruby.c
+++ b/tools/mruby/mruby.c
@@ -113,7 +113,7 @@ append_cmdline:
case '-':
if (strcmp((*argv) + 2, "version") == 0) {
mrb_show_version(mrb);
- exit(0);
+ exit(0);
}
else if (strcmp((*argv) + 2, "verbose") == 0) {
args->verbose = 1;
@@ -121,7 +121,7 @@ append_cmdline:
}
else if (strcmp((*argv) + 2, "copyright") == 0) {
mrb_show_copyright(mrb);
- exit(0);
+ exit(0);
}
else return -3;
return 0;
@@ -135,8 +135,8 @@ append_cmdline:
else {
args->rfp = fopen(argv[0], args->mrbfile ? "rb" : "r");
if (args->rfp == NULL) {
- printf("%s: Cannot open program file. (%s)\n", *origargv, *argv);
- return 0;
+ printf("%s: Cannot open program file. (%s)\n", *origargv, *argv);
+ return 0;
}
args->fname = 1;
args->cmdline = argv[0];
@@ -196,8 +196,10 @@ main(int argc, char **argv)
}
else if (!args.check_syntax) {
mrb_run(mrb, mrb_proc_new(mrb, mrb->irep[n]), mrb_top_self(mrb));
+ n = 0;
if (mrb->exc) {
- p(mrb, mrb_obj_value(mrb->exc));
+ p(mrb, mrb_obj_value(mrb->exc));
+ n = -1;
}
}
}
@@ -221,7 +223,7 @@ main(int argc, char **argv)
mrbc_context_free(mrb, c);
if (mrb->exc) {
if (!mrb_undef_p(v)) {
- p(mrb, mrb_obj_value(mrb->exc));
+ p(mrb, mrb_obj_value(mrb->exc));
}
n = -1;
}