summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-05-27 14:47:23 +0000
committernaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-05-27 14:47:23 +0000
commit84abef0fc08f7182f9c76175ef478898612b0bdf (patch)
treec1cfa14d716f76a560b12035361b844ccb2e0431
parentac8346c4c3031126b455bf71e6a7381dd0378386 (diff)
* file.c (file_expand_path): set encoding as the same of fname
when _result_ is not filesystem encoding. [ruby-dev:41429] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@28039 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--file.c2
2 files changed, 7 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index b8807054fc..86fa364fa3 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Thu May 27 23:29:18 2010 NARUSE, Yui <naruse@ruby-lang.org>
+
+ * file.c (file_expand_path): set encoding as the same of fname
+ when _result_ is not filesystem encoding. [ruby-dev:41429]
+
Thu May 27 23:07:45 2010 NARUSE, Yui <naruse@ruby-lang.org>
* file.c (file_expand_path): use rb_enc_associate_index and
diff --git a/file.c b/file.c
index 8f1a8a8c64..ed033a71af 100644
--- a/file.c
+++ b/file.c
@@ -2895,6 +2895,7 @@ file_expand_path(VALUE fname, VALUE dname, int abs_mode, VALUE result)
xfree(dir);
rb_enc_associate_index(result, rb_filesystem_encindex());
}
+ else rb_enc_copy(result, fname);
p = chompdirsep(skiproot(buf));
s += 2;
}
@@ -2904,6 +2905,7 @@ file_expand_path(VALUE fname, VALUE dname, int abs_mode, VALUE result)
if (!NIL_P(dname)) {
file_expand_path(dname, Qnil, abs_mode, result);
BUFINIT();
+ rb_enc_copy(result, fname);
}
else {
char *dir = my_getcwd();