[前][次][番号順一覧][スレッド一覧]

ruby-changes:2956

From: ko1@a...
Date: 22 Dec 2007 08:30:11 +0900
Subject: [ruby-changes:2956] nobu - Ruby:r14447 (trunk): * string.c (rb_str_buf_append): improvement for non-broken coded

nobu	2007-12-22 08:29:56 +0900 (Sat, 22 Dec 2007)

  New Revision: 14447

  Modified files:
    trunk/ChangeLog
    trunk/string.c

  Log:
    * string.c (rb_str_buf_append): improvement for non-broken coded
      strings.


  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/string.c?r1=14447&r2=14446
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=14447&r2=14446

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 14446)
+++ ChangeLog	(revision 14447)
@@ -1,3 +1,8 @@
+Sat Dec 22 08:29:56 2007  Nobuyoshi Nakada  <nobu@r...>
+
+	* string.c (rb_str_buf_append): improvement for non-broken coded
+	  strings.
+
 Sat Dec 22 06:30:04 2007  Koichi Sasada  <ko1@a...>
 
 	* bootstraptest/test_fork.rb: skip if fork is not unsupported.
Index: string.c
===================================================================
--- string.c	(revision 14446)
+++ string.c	(revision 14447)
@@ -1009,8 +1009,17 @@
 {
     rb_encoding *enc;
     long capa, len;
+    int cr1, cr2;
 
     enc = rb_enc_check(str, str2);
+    cr1 = ENC_CODERANGE(str);
+    cr2 = ENC_CODERANGE(str2);
+    if (cr1 == ENC_CODERANGE_BROKEN || cr2 == ENC_CODERANGE_BROKEN) {
+	cr1 = ENC_CODERANGE_UNKNOWN;
+    }
+    else if (cr2 > cr1) {
+	cr1 = cr2;
+    }
     rb_str_modify(str);
     if (STR_ASSOC_P(str)) {
 	FL_UNSET(str, STR_ASSOC);
@@ -1034,6 +1043,9 @@
     STR_SET_LEN(str, len);
     OBJ_INFECT(str, str2);
     rb_enc_associate(str, enc);
+    if (cr1 != ENC_CODERANGE_UNKNOWN) {
+	ENC_CODERANGE_SET(str, cr1);
+    }
 
     return str;
 }

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml

[前][次][番号順一覧][スレッド一覧]