summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--src/class.c21
-rw-r--r--test/t/module.rb14
2 files changed, 30 insertions, 5 deletions
diff --git a/src/class.c b/src/class.c
index 1409c0b33..976642224 100644
--- a/src/class.c
+++ b/src/class.c
@@ -721,6 +721,26 @@ mrb_mod_include(mrb_state *mrb, mrb_value klass)
}
static mrb_value
+mrb_mod_ancestors(mrb_state *mrb, mrb_value self)
+{
+ mrb_value result;
+ struct RClass *c = mrb_class_ptr(self);
+
+ result = mrb_ary_new(mrb);
+ while (c) {
+ if (c->tt == MRB_TT_ICLASS) {
+ mrb_ary_push(mrb, result, mrb_obj_value(c->c));
+ }
+ else {
+ mrb_ary_push(mrb, result, mrb_obj_value(c));
+ }
+ c = c->super;
+ }
+
+ return result;
+}
+
+static mrb_value
mrb_mod_included_modules(mrb_state *mrb, mrb_value self)
{
mrb_value result;
@@ -1400,6 +1420,7 @@ mrb_init_class(mrb_state *mrb)
mrb_define_method(mrb, mod, "to_s", mrb_mod_to_s, ARGS_NONE());
mrb_define_method(mrb, mod, "alias_method", mrb_mod_alias, ARGS_ANY()); /* 15.2.2.4.8 */
+ mrb_define_method(mrb, mod, "ancestors", mrb_mod_ancestors, ARGS_NONE()); /* 15.2.2.4.9 */
mrb_define_method(mrb, mod, "undef_method", mrb_mod_undef, ARGS_ANY()); /* 15.2.2.4.41 */
mrb_define_method(mrb, mod, "const_defined?", mrb_mod_const_defined, ARGS_REQ(1)); /* 15.2.2.4.20 */
mrb_define_method(mrb, mod, "const_get", mrb_mod_const_get, ARGS_REQ(1)); /* 15.2.2.4.21 */
diff --git a/test/t/module.rb b/test/t/module.rb
index 63c2e7dc8..0e5abff81 100644
--- a/test/t/module.rb
+++ b/test/t/module.rb
@@ -13,6 +13,12 @@ end
# TODO not implemented ATM assert('Module.nesting', '15.2.2.3.2') do
+assert('Module#ancestors', '15.2.2.4.9') do
+
+ r = String.ancestors
+ r.class == Array and r.include?(String) and r.include?(Object)
+end
+
assert('Module#append_features', '15.2.2.4.10') do
module Test4AppendFeatures
def self.append_features(mod)
@@ -100,14 +106,12 @@ assert('Module#included', '15.2.2.4.29') do
end
assert('Module#included_modules', '15.2.2.4.30') do
- r1 = true
module Test4includedModules
- Const4Included = 42
end
module Test4includedModules2
- r1 = included Test4includedModules
+ include Test4includedModules
end
- Test4includedModules2.included_modules.class == Array
+ r = Test4includedModules2.included_modules
+ r.class == Array and r.include?(Test4includedModules)
end
-