diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-01-11 15:36:52 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-01-11 15:36:52 +0000 |
commit | 480d6b8afc0e03bb291c91541295f253c0289aef (patch) | |
tree | 261a79eade48bdd75cf381e749e18bd8ee372a57 | |
parent | 712a9f3729e9bd38b0e62b63b00830e7a80cfc3c (diff) |
* object.c (rb_class_superclass): superclass of singleton class also
should be a singleton class. fixed: [ruby-list:40519]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@7768 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | object.c | 3 |
2 files changed, 8 insertions, 0 deletions
@@ -1,3 +1,8 @@ +Wed Jan 12 00:36:29 2005 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * object.c (rb_class_superclass): superclass of singleton class also + should be a singleton class. fixed: [ruby-list:40519] + Tue Jan 11 09:44:40 2005 Hirokazu Yamamoto <ocean@m2.ccsnet.ne.jp> * numeric.c (Init_Numeric): turn off floating point exceptions @@ -1624,6 +1624,9 @@ rb_class_superclass(klass) if (!super) { rb_raise(rb_eTypeError, "uninitialized class"); } + if (FL_TEST(klass, FL_SINGLETON)) { + super = RBASIC(klass)->klass; + } while (TYPE(super) == T_ICLASS) { super = RCLASS(super)->super; } |