diff options
| author | take_cheeze <[email protected]> | 2014-06-02 22:38:02 +0900 |
|---|---|---|
| committer | take_cheeze <[email protected]> | 2014-06-02 22:38:02 +0900 |
| commit | acec9d1ff19e2dbea9a4ff7b0030f74b9d42aa17 (patch) | |
| tree | 586077e89765dda630c6bb69255b0cc2be3998a0 /src | |
| parent | f370a0f0fd7111ca946a15a1f5641a4ef60a3859 (diff) | |
| download | mruby-acec9d1ff19e2dbea9a4ff7b0030f74b9d42aa17.tar.gz mruby-acec9d1ff19e2dbea9a4ff7b0030f74b9d42aa17.zip | |
Implement `NoMethodError#args`.
Diffstat (limited to 'src')
| -rw-r--r-- | src/class.c | 3 | ||||
| -rw-r--r-- | src/error.c | 14 |
2 files changed, 15 insertions, 2 deletions
diff --git a/src/class.c b/src/class.c index db9a8ac26..ba078911b 100644 --- a/src/class.c +++ b/src/class.c @@ -1216,8 +1216,7 @@ mrb_bob_missing(mrb_state *mrb, mrb_value mod) repr = mrb_any_to_s(mrb, mod); } - mrb_raisef(mrb, E_NOMETHOD_ERROR, "undefined method '%S' for %S", - mrb_sym2str(mrb, name), repr); + mrb_no_method_error(mrb, name, alen, a, "undefined method '%S' for %S", mrb_sym2str(mrb, name), repr); /* not reached */ return mrb_nil_value(); } diff --git a/src/error.c b/src/error.c index 360df8f2e..c60fff10d 100644 --- a/src/error.c +++ b/src/error.c @@ -442,6 +442,20 @@ mrb_sys_fail(mrb_state *mrb, const char *mesg) } } +mrb_noreturn void +mrb_no_method_error(mrb_state *mrb, mrb_sym id, mrb_int argc, const mrb_value *argv, char const* fmt, ...) +{ + mrb_value exc; + va_list ap; + + va_start(ap, fmt); + exc = mrb_funcall(mrb, mrb_obj_value(E_NOMETHOD_ERROR), "new", 3, + mrb_vformat(mrb, fmt, ap), mrb_symbol_value(id), + mrb_ary_new_from_values(mrb, argc, argv)); + va_end(ap); + mrb_exc_raise(mrb, exc); +} + void mrb_init_exception(mrb_state *mrb) { |
