diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2012-10-16 02:30:20 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2012-10-16 02:30:20 +0000 |
commit | 37b8f7b84fedff7937598273fb65c7fb4f8390f1 (patch) | |
tree | 0d924868d60c8bca6a2e785a37fcac7c09edcc56 | |
parent | a583f4206210cfccd9228d6f1f0cef0f2fdb5b92 (diff) |
file.c: hide result
* file.c (rb_file_join): hide the result under construction until
return.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@37213 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | file.c | 2 |
2 files changed, 6 insertions, 1 deletions
@@ -1,4 +1,7 @@ -Tue Oct 16 11:27:04 2012 Nobuyoshi Nakada <nobu@ruby-lang.org> +Tue Oct 16 11:30:18 2012 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * file.c (rb_file_join): hide the result under construction until + return. * file.c (rb_file_join): check nul-byte only for strings, since FilePathStringValue() does it. [ruby-core:48012] [Bug #7168] @@ -3936,6 +3936,7 @@ rb_file_join(VALUE ary, VALUE sep) len += RSTRING_LEN(sep) * (RARRAY_LEN(ary) - 1); } result = rb_str_buf_new(len); + RBASIC(result)->klass = 0; OBJ_INFECT(result, ary); for (i=0; i<RARRAY_LEN(ary); i++) { tmp = RARRAY_PTR(ary)[i]; @@ -3973,6 +3974,7 @@ rb_file_join(VALUE ary, VALUE sep) } rb_str_buf_append(result, tmp); } + RBASIC(result)->klass = rb_cString; return result; } |