diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-04-24 21:56:03 -0700 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-04-24 21:56:03 -0700 |
| commit | f0bea86437e46cec11d1fe5f9c3ab7ab8933161d (patch) | |
| tree | 341314a55f834f1edf71f21b3de6947ffbbbbbbe | |
| parent | e70b2721a627dee19349431619ec13693095c7e0 (diff) | |
| parent | 8d778d9860792d9af81d97db25d9f8000327bee9 (diff) | |
| download | mruby-f0bea86437e46cec11d1fe5f9c3ab7ab8933161d.tar.gz mruby-f0bea86437e46cec11d1fe5f9c3ab7ab8933161d.zip | |
Merge pull request #1211 from skandhas/pr-fix-Module-ancestors
fix the behavior of Module#ancestors
| -rw-r--r-- | src/class.c | 2 | ||||
| -rw-r--r-- | test/t/module.rb | 6 |
2 files changed, 6 insertions, 2 deletions
diff --git a/src/class.c b/src/class.c index e71ebc60b..69dc42534 100644 --- a/src/class.c +++ b/src/class.c @@ -793,7 +793,7 @@ mrb_mod_ancestors(mrb_state *mrb, mrb_value self) if (c->tt == MRB_TT_ICLASS) { mrb_ary_push(mrb, result, mrb_obj_value(c->c)); } - else { + else if (c->tt != MRB_TT_SCLASS) { mrb_ary_push(mrb, result, mrb_obj_value(c)); } c = c->super; diff --git a/test/t/module.rb b/test/t/module.rb index 23dacb44d..41ee8d8df 100644 --- a/test/t/module.rb +++ b/test/t/module.rb @@ -14,8 +14,12 @@ end # TODO not implemented ATM assert('Module.nesting', '15.2.2.3.2') do assert('Module#ancestors', '15.2.2.4.9') do + class Test4ModuleAncestors + end + sc = Test4ModuleAncestors.singleton_class r = String.ancestors - r.class == Array and r.include?(String) and r.include?(Object) + r.class == Array and r.include?(String) and r.include?(Object) and + ! sc.ancestors.include?(sc) end assert('Module#append_features', '15.2.2.4.10') do |
