diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 1998-04-07 08:41:26 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 1998-04-07 08:41:26 +0000 |
commit | 14b9d586fa1fabb695f06c5b9c1d0785207d77ef (patch) | |
tree | 7dbbcd3b404423b4148864ec8232c17da601bcf4 /variable.c | |
parent | ba06b1a81f81e089849c7c877eba7b1d3618b126 (diff) |
1.1b9_07
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/v1_1r@153 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'variable.c')
-rw-r--r-- | variable.c | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/variable.c b/variable.c index 0827ebbec6..24e66a6b56 100644 --- a/variable.c +++ b/variable.c @@ -131,6 +131,16 @@ classname(klass) } path = rb_iv_get(klass, "__classpath__"); if (NIL_P(path)) { + ID classid = rb_intern("__classid__"); + + path = rb_ivar_get(klass, classid); + if (!NIL_P(path)) { + path = str_new2(rb_id2name(FIX2INT(path))); + rb_ivar_set(klass, classid, path); + st_delete(RCLASS(klass)->iv_tbl, &classid, 0); + } + } + if (NIL_P(path)) { path = find_class_path(klass); if (NIL_P(path)) { return 0; @@ -203,7 +213,12 @@ rb_name_class(klass, id) { extern VALUE cString; - rb_iv_set(klass, "__classpath__", str_new2(rb_id2name(id))); + if (cString) { + rb_iv_set(klass, "__classpath__", str_new2(rb_id2name(id))); + } + else { + rb_iv_set(klass, "__classid__", INT2FIX(id)); + } } static st_table *autoload_tbl = 0; |