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/