diff options
| author | KOBAYASHI Shuji <[email protected]> | 2019-11-22 18:29:38 +0900 |
|---|---|---|
| committer | KOBAYASHI Shuji <[email protected]> | 2019-11-22 18:29:38 +0900 |
| commit | d81e4d71c17f9d65ea87f0e66a4338411863f7bf (patch) | |
| tree | d45d17de774311c5f4fed5705e3e91c6ca44b0d1 /mrbgems/mruby-exit | |
| parent | 1bb1df19d861de82239d9b41405061503a8fc157 (diff) | |
| download | mruby-d81e4d71c17f9d65ea87f0e66a4338411863f7bf.tar.gz mruby-d81e4d71c17f9d65ea87f0e66a4338411863f7bf.zip | |
Allow `true`/`false` argument to `Kernel#exit`
Diffstat (limited to 'mrbgems/mruby-exit')
| -rw-r--r-- | mrbgems/mruby-exit/src/mruby-exit.c | 13 |
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 |
