ruby-changes:4086
From: ko1@a...
Date: Fri, 22 Feb 2008 21:16:14 +0900 (JST)
Subject: [ruby-changes:4086] naruse - Ruby:r15576 (trunk): * string.c (rb_enc_cr_str_copy): check string's coderange is 7bit or
naruse 2008-02-22 21:15:56 +0900 (Fri, 22 Feb 2008)
New Revision: 15576
Modified files:
trunk/ChangeLog
trunk/string.c
Log:
* string.c (rb_enc_cr_str_copy): check string's coderange is 7bit or
valid.
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/string.c?r1=15576&r2=15575&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=15576&r2=15575&diff_format=u
Index: ChangeLog
===================================================================
--- ChangeLog (revision 15575)
+++ ChangeLog (revision 15576)
@@ -1,3 +1,8 @@
+Fri Feb 22 21:12:42 2008 NARUSE, Yui <naruse@r...>
+
+ * string.c (rb_enc_cr_str_copy): check string's coderange is 7bit or
+ valid.
+
Fri Feb 22 19:50:19 2008 Nobuyoshi Nakada <nobu@r...>
* bignum.c (BIGZEROP): fix for longer Bignum zeros. [ruby-Bugs-17454]
Index: string.c
===================================================================
--- string.c (revision 15575)
+++ string.c (revision 15576)
@@ -215,8 +215,17 @@
rb_enc_cr_str_copy(VALUE dest, VALUE src)
{
rb_enc_copy(dest, src);
- if (!is_broken_string(src))
- ENC_CODERANGE_SET(dest, ENC_CODERANGE(src));
+ switch (ENC_CODERANGE(src)) {
+ case ENC_CODERANGE_7BIT:
+ ENC_CODERANGE_SET(dest, ENC_CODERANGE_7BIT);
+ break;
+ case ENC_CODERANGE_VALID:
+ if (search_nonascii(RSTRING_PTR(dest), RSTRING_END(dest)))
+ ENC_CODERANGE_SET(dest, ENC_CODERANGE_VALID);
+ else
+ ENC_CODERANGE_SET(dest, ENC_CODERANGE_7BIT);
+ break;
+ }
}
void
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/