Commit 526dd09b authored by Yukihiro Matsumoto's avatar Yukihiro Matsumoto

add Module#ancestors 15.2.2.4.9

parent 5495ee96
...@@ -720,6 +720,26 @@ mrb_mod_include(mrb_state *mrb, mrb_value klass) ...@@ -720,6 +720,26 @@ mrb_mod_include(mrb_state *mrb, mrb_value klass)
return klass; return 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 static mrb_value
mrb_mod_included_modules(mrb_state *mrb, mrb_value self) mrb_mod_included_modules(mrb_state *mrb, mrb_value self)
{ {
...@@ -1400,6 +1420,7 @@ mrb_init_class(mrb_state *mrb) ...@@ -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, "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, "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, "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_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 */ mrb_define_method(mrb, mod, "const_get", mrb_mod_const_get, ARGS_REQ(1)); /* 15.2.2.4.21 */
......
...@@ -13,6 +13,12 @@ end ...@@ -13,6 +13,12 @@ end
# TODO not implemented ATM assert('Module.nesting', '15.2.2.3.2') do # 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 assert('Module#append_features', '15.2.2.4.10') do
module Test4AppendFeatures module Test4AppendFeatures
def self.append_features(mod) def self.append_features(mod)
...@@ -100,14 +106,12 @@ assert('Module#included', '15.2.2.4.29') do ...@@ -100,14 +106,12 @@ assert('Module#included', '15.2.2.4.29') do
end end
assert('Module#included_modules', '15.2.2.4.30') do assert('Module#included_modules', '15.2.2.4.30') do
r1 = true
module Test4includedModules module Test4includedModules
Const4Included = 42
end end
module Test4includedModules2 module Test4includedModules2
r1 = included Test4includedModules include Test4includedModules
end end
Test4includedModules2.included_modules.class == Array r = Test4includedModules2.included_modules
r.class == Array and r.include?(Test4includedModules)
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment