summaryrefslogtreecommitdiff
path: root/string.c
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-26 11:16:35 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-26 11:16:35 +0000
commita8b2bda76008b5ff5f58cd60276c6f5d1f2b2538 (patch)
treecbe78c9e0ff343bb028c1ae1894ba20816535bf4 /string.c
parentcad814b5485493a5db2543bcf876bc117055cbf7 (diff)
merges r20952 from trunk into ruby_1_9_1.
* string.c (rb_external_str_new_with_enc): set ASCII-8BIT if encoding is US-ASCII and string contains 8bit characters. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_1@21072 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'string.c')
-rw-r--r--string.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/string.c b/string.c
index c1f14a8525..236980e25b 100644
--- a/string.c
+++ b/string.c
@@ -538,6 +538,11 @@ rb_external_str_new_with_enc(const char *ptr, long len, rb_encoding *eenc)
VALUE str;
str = rb_tainted_str_new(ptr, len);
+ if (rb_enc_str_coderange(str) != ENC_CODERANGE_7BIT &&
+ eenc == rb_usascii_encoding()) {
+ rb_enc_associate(str, rb_ascii8bit_encoding());
+ return str;
+ }
rb_enc_associate(str, eenc);
return rb_str_conv_enc(str, eenc, rb_default_internal_encoding());
}