summaryrefslogtreecommitdiff
path: root/variable.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>1998-04-07 08:41:26 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>1998-04-07 08:41:26 +0000
commit14b9d586fa1fabb695f06c5b9c1d0785207d77ef (patch)
tree7dbbcd3b404423b4148864ec8232c17da601bcf4 /variable.c
parentba06b1a81f81e089849c7c877eba7b1d3618b126 (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.c17
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;