summaryrefslogtreecommitdiff
path: root/variable.c
diff options
context:
space:
mode:
authorshyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-08-15 20:56:20 +0000
committershyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-08-15 20:56:20 +0000
commit6afb98b298fa61de96d24395ef5f133af814d62e (patch)
treed1b6faf15b76fe426b67a02f0a0350e265019cf5 /variable.c
parentd10ee17ba71098ed3b372d337eb8d42a158550b8 (diff)
parent59e55b2b8e43ed773f5b5ad58b4d53a8b673b93f (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.c11
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;