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

ruby-changes:4017

From: ko1@a...
Date: Sat, 16 Feb 2008 18:30:15 +0900 (JST)
Subject: [ruby-changes:4017] naruse - Ruby:r15507 (trunk): * string.c (str_strlen): little more optimize.

naruse	2008-02-16 18:30:03 +0900 (Sat, 16 Feb 2008)

  New Revision: 15507

  Modified files:
    trunk/ChangeLog
    trunk/string.c

  Log:
    * string.c (str_strlen): little more optimize.
      (rb_enc_nth): remove needless variable 'c'.

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/string.c?r1=15507&r2=15506&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=15507&r2=15506&diff_format=u

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 15506)
+++ ChangeLog	(revision 15507)
@@ -1,3 +1,8 @@
+Sat Feb 16 18:25:14 2008  NARUSE, Yui  <naruse@r...>
+
+	* string.c (str_strlen): little more optimize.
+	  (rb_enc_nth): remove needless variable 'c'.
+
 Sat Feb 16 18:00:13 2008  Tanaka Akira  <akr@f...>
 
 	* encoding.c (rb_enc_compatible): empty strings are always compatible.
Index: string.c
===================================================================
--- string.c	(revision 15506)
+++ string.c	(revision 15507)
@@ -643,9 +643,11 @@
 	    }
 	    while (s < t) {
 		unsigned long d = *s;
-		d = (~d ^ (d&(d<<1)))&NONASCII_MASK;
-		d = (d>>7) + (d>>15);
-		d = d + (d>>16);
+		d = ~d | (d<<1);
+		d &= NONASCII_MASK;
+		d >>= 7;
+		d += (d>>8);
+		d += (d>>16);
 #if NONASCII_MASK == 0x8080808080808080UL
 		d = d + (d>>32);
 #endif
@@ -657,6 +659,7 @@
 	for (; p<e; p++) {
 	    if (((*p)&0xC0) != 0x80) len++;
 	}
+	return len;
     }
     else
 #endif
@@ -664,6 +667,9 @@
     if (len < 0) {
 	rb_raise(rb_eArgError, "invalid mbstring sequence");
     }
+    if (ENC_CODERANGE(str) != ENC_CODERANGE_VALID && enc == STR_ENC_GET(str)) {
+	ENC_CODERANGE_SET(str, ENC_CODERANGE_VALID);
+    }
     return len;
 }
 
@@ -949,8 +955,6 @@
 char*
 rb_enc_nth(const char *p, const char *e, int nth, rb_encoding *enc)
 {
-    int c;
-
     if (rb_enc_mbmaxlen(enc) == 1) {
         p += nth;
     }
@@ -981,10 +985,8 @@
         return (char *)p;
     }
     else {
-        for (c=0; p<e && nth--; c++) {
-            int n = rb_enc_mbclen(p, e, enc);
-
-            p += n;
+        while (p<e && nth--) {
+            p += rb_enc_mbclen(p, e, enc);
         }
     }
     if (p > e) p = e;

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

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