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/