summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-09-19 23:07:22 +0000
committernaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-09-19 23:07:22 +0000
commit00cdba732f4ec132947ac33479e423ae5da016cc (patch)
tree77f6f87f3666f53723501f254ebd18f1e286098d
parent48aad600bab75a6b5866c9a46b5828351cc6878a (diff)
* re.c (rb_reg_desc): Regexps of ASCII Compatible encoding may
contain non-ASCII characters. So in that case its encoding must keep original encoding. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19433 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog6
-rw-r--r--re.c8
2 files changed, 12 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 9057898b15..0f6fc95461 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+Sat Sep 20 07:59:31 2008 NARUSE, Yui <naruse@ruby-lang.org>
+
+ * re.c (rb_reg_desc): Regexps of ASCII Compatible encoding may
+ contain non-ASCII characters. So in that case its encoding
+ must keep original encoding.
+
Sat Sep 20 07:44:56 2008 NARUSE, Yui <naruse@ruby-lang.org>
* common.mk: prec.c is removed.
diff --git a/re.c b/re.c
index b9d3840313..9b9cb87d02 100644
--- a/re.c
+++ b/re.c
@@ -380,8 +380,12 @@ static VALUE
rb_reg_desc(const char *s, long len, VALUE re)
{
VALUE str = rb_str_buf_new2("/");
-
- rb_enc_associate(str, rb_usascii_encoding());
+ if (rb_enc_asciicompat(rb_enc_get(re))) {
+ rb_enc_copy(str, re);
+ }
+ else {
+ rb_enc_associate(str, rb_usascii_encoding());
+ }
rb_reg_expr_str(str, s, len);
rb_str_buf_cat2(str, "/");
if (re) {