summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorKOBAYASHI Shuji <[email protected]>2019-11-22 18:29:38 +0900
committerKOBAYASHI Shuji <[email protected]>2019-11-22 18:29:38 +0900
commitd81e4d71c17f9d65ea87f0e66a4338411863f7bf (patch)
treed45d17de774311c5f4fed5705e3e91c6ca44b0d1
parent1bb1df19d861de82239d9b41405061503a8fc157 (diff)
downloadmruby-d81e4d71c17f9d65ea87f0e66a4338411863f7bf.tar.gz
mruby-d81e4d71c17f9d65ea87f0e66a4338411863f7bf.zip
Allow `true`/`false` argument to `Kernel#exit`
-rw-r--r--mrbgems/mruby-exit/src/mruby-exit.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/mrbgems/mruby-exit/src/mruby-exit.c b/mrbgems/mruby-exit/src/mruby-exit.c
index 05c929622..4ff2f932c 100644
--- a/mrbgems/mruby-exit/src/mruby-exit.c
+++ b/mrbgems/mruby-exit/src/mruby-exit.c
@@ -4,12 +4,17 @@
static mrb_value
f_exit(mrb_state *mrb, mrb_value self)
{
- mrb_int i = EXIT_SUCCESS;
+ mrb_value status = mrb_true_value();
+ int istatus;
+
+ mrb_get_args(mrb, "|o", &status);
+ istatus = mrb_true_p(status) ? EXIT_SUCCESS :
+ mrb_false_p(status) ? EXIT_FAILURE :
+ (int)mrb_int(mrb, status);
+ exit(istatus);
- mrb_get_args(mrb, "|i", &i);
- exit((int)i);
/* not reached */
- return mrb_nil_value();
+ return status;
}
void