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

ruby-changes:4035

From: ko1@a...
Date: Sun, 17 Feb 2008 22:02:08 +0900 (JST)
Subject: [ruby-changes:4035] naruse - Ruby:r15525 (trunk): * encoding.c (ENC_CODERANGE_AND): fix broken case.

naruse	2008-02-17 22:01:52 +0900 (Sun, 17 Feb 2008)

  New Revision: 15525

  Modified files:
    trunk/ChangeLog
    trunk/include/ruby/encoding.h
    trunk/string.c

  Log:
    * encoding.c (ENC_CODERANGE_AND): fix broken case. [ruby-dev:33826]
    
    * string.c (rb_str_times): fix broken case. [ruby-dev:33826]

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/string.c?r1=15525&r2=15524&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=15525&r2=15524&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/include/ruby/encoding.h?r1=15525&r2=15524&diff_format=u

Index: include/ruby/encoding.h
===================================================================
--- include/ruby/encoding.h	(revision 15524)
+++ include/ruby/encoding.h	(revision 15525)
@@ -56,14 +56,13 @@
 #define ENC_CODERANGE_SET(obj,cr) (RBASIC(obj)->flags = \
 				   (RBASIC(obj)->flags & ~ENC_CODERANGE_MASK) | (cr))
 #define ENC_CODERANGE_CLEAR(obj) ENC_CODERANGE_SET(obj,0)
-#define ENC_CODERANGE_AND(a, b) (\
-    (a == b) ? a : \
-    (a == ENC_CODERANGE_BROKEN) ? ENC_CODERANGE_BROKEN : \
-    (b == ENC_CODERANGE_BROKEN) ? ENC_CODERANGE_BROKEN : \
-    (a == ENC_CODERANGE_UNKNOWN) ? ENC_CODERANGE_UNKNOWN : \
-    (b == ENC_CODERANGE_UNKNOWN) ? ENC_CODERANGE_UNKNOWN : \
-    ENC_CODERANGE_VALID)
 
+/* assumed ASCII compatiblity */
+#define ENC_CODERANGE_AND(a, b) \
+    (a == ENC_CODERANGE_7BIT ? b : \
+     a == ENC_CODERANGE_VALID ? (b == ENC_CODERANGE_7BIT ? ENC_CODERANGE_VALID : b) : \
+     ENC_CODERANGE_UNKNOWN)
+
 #define ENCODING_CODERANGE_SET(obj, encindex, cr) \
     do { \
         VALUE rb_encoding_coderange_obj = (obj); \
Index: ChangeLog
===================================================================
--- ChangeLog	(revision 15524)
+++ ChangeLog	(revision 15525)
@@ -1,3 +1,9 @@
+Sun Feb 17 21:38:21 2008  NARUSE, Yui  <naruse@r...>
+
+	* encoding.c (ENC_CODERANGE_AND): fix broken case. [ruby-dev:33826]
+
+	* string.c (rb_str_times): fix broken case. [ruby-dev:33826]
+
 Sun Feb 17 20:45:10 2008  Tanaka Akira  <akr@f...>
 
 	* re.c (rb_reg_prepare_re): add enable_warning parameter.
Index: string.c
===================================================================
--- string.c	(revision 15524)
+++ string.c	(revision 15525)
@@ -758,6 +758,7 @@
 {
     VALUE str2;
     long n, len;
+    int cr;
 
     len = NUM2LONG(times);
     if (len < 0) {
@@ -779,7 +780,9 @@
     }
     RSTRING_PTR(str2)[RSTRING_LEN(str2)] = '\0';
     OBJ_INFECT(str2, str);
-    ENCODING_CODERANGE_SET(str2, rb_enc_get_index(str), ENC_CODERANGE(str));
+    cr = ENC_CODERANGE(str);
+    if (cr == ENC_CODERANGE_BROKEN) cr = ENC_CODERANGE_UNKNOWN;
+    ENCODING_CODERANGE_SET(str2, rb_enc_get_index(str), cr);
 
     return str2;
 }

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

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