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

ruby-changes:3651

From: ko1@a...
Date: Sun, 20 Jan 2008 13:06:20 +0900 (JST)
Subject: [ruby-changes:3651] nobu - Ruby:r15140 (trunk): * string.c (rb_str_each_char): performance improvement, and stop if

nobu	2008-01-20 13:06:03 +0900 (Sun, 20 Jan 2008)

  New Revision: 15140

  Modified files:
    trunk/ChangeLog
    trunk/string.c

  Log:
    * string.c (rb_str_each_char): performance improvement, and stop if
      shortened in the block.  [ruby-dev:33189]


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

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 15139)
+++ ChangeLog	(revision 15140)
@@ -1,3 +1,8 @@
+Sun Jan 20 13:06:01 2008  Nobuyoshi Nakada  <nobu@r...>
+
+	* string.c (rb_str_each_char): performance improvement, and stop if
+	  shortened in the block.  [ruby-dev:33189]
+
 Sun Jan 20 09:12:26 2008  NARUSE, Yui  <naruse@r...>
 
 	* common.mk: use -Ks when read insns.def. [ruby-dev#33185]
Index: string.c
===================================================================
--- string.c	(revision 15139)
+++ string.c	(revision 15140)
@@ -4590,11 +4590,22 @@
 static VALUE
 rb_str_each_char(VALUE str)
 {
-    int i, len = str_strlen(str, 0);
+    int i, len, n;
+    const char *ptr, *s;
+    rb_encoding *enc;
 
     RETURN_ENUMERATOR(str, 0, 0);
-    for (i=0; i<len; i++) {
-	rb_yield(rb_str_substr(str, i, 1));
+    ptr = RSTRING_PTR(str);
+    len = RSTRING_LEN(str);
+    enc = rb_enc_get(str);
+    n = rb_enc_mbclen(ptr, ptr + len, enc);
+    for (i = 0; i < len; i += n) {
+	rb_yield(rb_str_subseq(str, i, n));
+	ptr = RSTRING_PTR(str);
+	len = RSTRING_LEN(str);
+	enc = rb_enc_get(str);
+	s = rb_enc_left_char_head(ptr, ptr + i, enc);
+	n = rb_enc_mbclen(s, ptr + len, enc);
     }
     return str;
 }

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

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