summaryrefslogtreecommitdiffhomepage
path: root/src/class.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2016-11-11 22:57:52 +0900
committerGitHub <[email protected]>2016-11-11 22:57:52 +0900
commitfeb9b3debd1ce75795e8eaf31641f2a485ec3e33 (patch)
treec89e05a9e867222fb8dda2a57af10810893cafe5 /src/class.c
parent752ca514f6e3d9435a8af345fa2481e733a5ddca (diff)
parentefe4f30b3982e8ff85a9142933955d6fa0bdebc7 (diff)
downloadmruby-feb9b3debd1ce75795e8eaf31641f2a485ec3e33.tar.gz
mruby-feb9b3debd1ce75795e8eaf31641f2a485ec3e33.zip
Merge pull request #3224 from ksss/define_method
Module#define_method supports proc argument
Diffstat (limited to 'src/class.c')
-rw-r--r--src/class.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/src/class.c b/src/class.c
index b81859ab8..7097a593a 100644
--- a/src/class.c
+++ b/src/class.c
@@ -1783,9 +1783,21 @@ mod_define_method(mrb_state *mrb, mrb_value self)
struct RClass *c = mrb_class_ptr(self);
struct RProc *p;
mrb_sym mid;
+ mrb_value proc = mrb_undef_value();
mrb_value blk;
- mrb_get_args(mrb, "n&", &mid, &blk);
+ mrb_get_args(mrb, "n|o&", &mid, &proc, &blk);
+ switch (mrb_type(proc)) {
+ case MRB_TT_PROC:
+ blk = proc;
+ break;
+ case MRB_TT_UNDEF:
+ /* ignored */
+ break;
+ default:
+ mrb_raisef(mrb, E_TYPE_ERROR, "wrong argument type %S (expected Proc)", mrb_obj_value(mrb_obj_class(mrb, proc)));
+ break;
+ }
if (mrb_nil_p(blk)) {
mrb_raise(mrb, E_ARGUMENT_ERROR, "no block given");
}