summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorskandhas <[email protected]>2012-11-24 16:04:11 +0800
committerskandhas <[email protected]>2012-11-24 16:04:11 +0800
commit59035eb33d5e1b276a1269a38f2cce421a528470 (patch)
tree71d731783d7d21d290ec3e81a3a4571fea3095f8 /src
parent32bacb21a2d51e9466b54bc5e30a832e68077c78 (diff)
downloadmruby-59035eb33d5e1b276a1269a38f2cce421a528470.tar.gz
mruby-59035eb33d5e1b276a1269a38f2cce421a528470.zip
add Module#include?
Diffstat (limited to 'src')
-rw-r--r--src/class.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/src/class.c b/src/class.c
index fe2baa4f2..3912dfe28 100644
--- a/src/class.c
+++ b/src/class.c
@@ -723,6 +723,24 @@ mrb_mod_include(mrb_state *mrb, mrb_value klass)
}
static mrb_value
+mrb_mod_include_p(mrb_state *mrb, mrb_value mod)
+{
+ mrb_value mod2;
+ struct RClass *c = mrb_class_ptr(mod);
+
+ mrb_get_args(mrb, "o", &mod2);
+ mrb_check_type(mrb, mod2, MRB_TT_MODULE);
+
+ while (c) {
+ if (c->tt == MRB_TT_ICLASS) {
+ if (c->c == mrb_class_ptr(mod2)) return mrb_true_value();
+ }
+ c = c->super;
+ }
+ return mrb_false_value();
+}
+
+static mrb_value
mrb_mod_ancestors(mrb_state *mrb, mrb_value self)
{
mrb_value result;
@@ -1424,6 +1442,7 @@ mrb_init_class(mrb_state *mrb)
mrb_define_method(mrb, mod, "extend_object", mrb_mod_extend_object, ARGS_REQ(1)); /* 15.2.2.4.25 */
mrb_define_method(mrb, mod, "extended", mrb_bob_init, ARGS_REQ(1)); /* 15.2.2.4.26 */
mrb_define_method(mrb, mod, "include", mrb_mod_include, ARGS_ANY()); /* 15.2.2.4.27 */
+ mrb_define_method(mrb, mod, "include?", mrb_mod_include_p, ARGS_REQ(1)); /* 15.2.2.4.28 */
mrb_define_method(mrb, mod, "append_features", mrb_mod_append_features, ARGS_REQ(1)); /* 15.2.2.4.10 */
mrb_define_method(mrb, mod, "included", mrb_bob_init, ARGS_REQ(1)); /* 15.2.2.4.29 */
mrb_define_method(mrb, mod, "included_modules", mrb_mod_included_modules, ARGS_NONE()); /* 15.2.2.4.30 */