summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-23 15:13:18 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-23 15:13:18 +0000
commit1fca0d5ddda6ad52618012f80b0aa0bd39763111 (patch)
tree993e53b0ea1632cee2d14158e6b7d3e919643432
parent4973c1e41c09d5110cceaa08006f1abd1109ce67 (diff)
downloadruby-1fca0d5ddda6ad52618012f80b0aa0bd39763111.tar.gz
ruby-1fca0d5ddda6ad52618012f80b0aa0bd39763111.tar.xz
ruby-1fca0d5ddda6ad52618012f80b0aa0bd39763111.zip
* string.c (rb_external_str_new_with_enc): set ASCII-8BIT if
encoding is US-ASCII and string contains 8bit characters. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@20952 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--parse.y9
-rw-r--r--string.c5
3 files changed, 12 insertions, 7 deletions
diff --git a/ChangeLog b/ChangeLog
index 715bb07e4..c32f12d5b 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -167,6 +167,11 @@ Mon Dec 22 18:00:36 2008 Hidetoshi NAGAI <nagai@ai.kyutech.ac.jp>
* ext/tk/tcltklib.c: fix wrong flag value.
+Mon Dec 22 14:35:59 2008 Yukihiro Matsumoto <matz@ruby-lang.org>
+
+ * string.c (rb_external_str_new_with_enc): set ASCII-8BIT if
+ encoding is US-ASCII and string contains 8bit characters.
+
Mon Dec 22 12:26:18 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
* cygwin/GNUmakefile.in (rubydll.def), win32/mkexports.rb
diff --git a/parse.y b/parse.y
index f99277ec9..76bf51a0a 100644
--- a/parse.y
+++ b/parse.y
@@ -7923,13 +7923,8 @@ gettable_gen(struct parser_params *parser, ID id)
return NEW_FALSE();
}
else if (id == keyword__FILE__) {
- VALUE str = rb_external_str_new_with_enc(ruby_sourcefile, strlen(ruby_sourcefile),
- rb_filesystem_encoding());
- if (rb_enc_str_coderange(str) != ENC_CODERANGE_7BIT &&
- ENCODING_GET(str) == rb_usascii_encindex()) {
- rb_enc_associate(str, rb_ascii8bit_encoding());
- }
- return NEW_STR(str);
+ return NEW_STR(rb_external_str_new_with_enc(ruby_sourcefile, strlen(ruby_sourcefile),
+ rb_filesystem_encoding()));
}
else if (id == keyword__LINE__) {
return NEW_LIT(INT2FIX(ruby_sourceline));
diff --git a/string.c b/string.c
index 9db82d4a2..7056c1ec8 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());
}