diff options
author | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-08-15 20:56:20 +0000 |
---|---|---|
committer | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-08-15 20:56:20 +0000 |
commit | 6afb98b298fa61de96d24395ef5f133af814d62e (patch) | |
tree | d1b6faf15b76fe426b67a02f0a0350e265019cf5 /variable.c | |
parent | d10ee17ba71098ed3b372d337eb8d42a158550b8 (diff) | |
parent | 59e55b2b8e43ed773f5b5ad58b4d53a8b673b93f (diff) |
sorry. I made wrong tags.v1_8_5_59
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/tags/v1_8_5_59@13005 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'variable.c')
-rw-r--r-- | variable.c | 11 |
1 files changed, 3 insertions, 8 deletions
diff --git a/variable.c b/variable.c index 4231a75827..a51dd9ea58 100644 --- a/variable.c +++ b/variable.c @@ -241,21 +241,16 @@ rb_path2class(path) const char *pbeg, *p; ID id; VALUE c = rb_cObject; - VALUE str = 0; if (path[0] == '#') { rb_raise(rb_eArgError, "can't retrieve anonymous class %s", path); } pbeg = p = path; while (*p) { + VALUE str; + while (*p && *p != ':') p++; - if (str) { - RSTRING(str)->len = 0; - rb_str_cat(str, pbeg, p-pbeg); - } - else { - str = rb_str_new(pbeg, p-pbeg); - } + str = rb_str_new(pbeg, p-pbeg); id = rb_intern(RSTRING(str)->ptr); if (p[0] == ':') { if (p[1] != ':') goto undefined_class; |