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

ruby-changes:2771

From: ko1@a...
Date: 17 Dec 2007 17:09:58 +0900
Subject: [ruby-changes:2771] akr - Ruby:r14262 (trunk): * string.c (rb_enc_str_coderange): set ENC_CODERANGE_BROKEN using

akr	2007-12-17 16:41:21 +0900 (Mon, 17 Dec 2007)

  New Revision: 14262

  Modified files:
    trunk/ChangeLog
    trunk/string.c

  Log:
    * string.c (rb_enc_str_coderange): set ENC_CODERANGE_BROKEN using
      rb_enc_precise_mbclen.
      (rb_str_valid_encoding_p): just check coderange is
      ENC_CODERANGE_BROKEN or not.


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

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 14261)
+++ ChangeLog	(revision 14262)
@@ -1,3 +1,10 @@
+Mon Dec 17 16:39:25 2007  Tanaka Akira  <akr@f...>
+
+	* string.c (rb_enc_str_coderange): set ENC_CODERANGE_BROKEN using
+	  rb_enc_precise_mbclen.
+	  (rb_str_valid_encoding_p): just check coderange is
+	  ENC_CODERANGE_BROKEN or not.
+
 Mon Dec 17 16:04:16 2007  GOTOU Yuuzou  <gotoyuzo@n...>
 
 	* ext/openssl/lib/openssl/buffering.rb (Buffering#gets): added second
Index: string.c
===================================================================
--- string.c	(revision 14261)
+++ string.c	(revision 14262)
@@ -105,27 +105,26 @@
     if (cr == ENC_CODERANGE_UNKNOWN) {
 	rb_encoding *enc = rb_enc_get(str);
 
-	if (!rb_enc_asciicompat(enc)) {
-	    cr = ENC_CODERANGE_VALID;
-	    ENC_CODERANGE_SET(str, cr);
-	    return cr;
-	}
-	else {
-	    const char *p = RSTRING_PTR(str);
-	    const char *e = p + RSTRING_LEN(str);
+        const char *p = RSTRING_PTR(str);
+        const char *e = p + RSTRING_LEN(str);
 
-	    cr = ENC_CODERANGE_7BIT;
-	    while (p < e) {
-		int c = (unsigned char)*p;
+        cr = rb_enc_asciicompat(enc) ? ENC_CODERANGE_7BIT : ENC_CODERANGE_VALID;
+        while (p < e) {
+            int ret = rb_enc_precise_mbclen(p, e, enc);
+            int len = MBCLEN_CHARFOUND(ret);
 
-		if (!rb_enc_isascii(c, enc)) {
-		    cr = ENC_CODERANGE_VALID;
-		    break;
-		}
-		p++;
-	    }
-	    ENC_CODERANGE_SET(str, cr);
-	}
+            if (len) {
+                if (len != 1 || !rb_enc_isascii((unsigned char)*p, enc)) {
+                    cr = ENC_CODERANGE_VALID;
+                }
+                p += len;
+            }
+            else {
+                cr = ENC_CODERANGE_BROKEN;
+                break;
+            }
+        }
+        ENC_CODERANGE_SET(str, cr);
     }
     return cr;
 }
@@ -5316,20 +5315,9 @@
 static VALUE
 rb_str_valid_encoding_p(VALUE str)
 {
-    char *p = RSTRING_PTR(str);
-    char *pend = RSTRING_END(str);
-    rb_encoding *enc = rb_enc_get(str);
+    int cr = rb_enc_str_coderange(str);
 
-    while (p < pend) {
-	int n;
-
-        n = rb_enc_precise_mbclen(p, pend, enc);
-        if (!MBCLEN_CHARFOUND(n)) {
-            return Qfalse;
-        }
-        p += n;
-    }
-    return Qtrue;
+    return cr == ENC_CODERANGE_BROKEN ? Qfalse : Qtrue;
 }
 
 /**********************************************************************

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

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