diff options
| author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-05-23 15:59:09 +0000 |
|---|---|---|
| committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-05-23 15:59:09 +0000 |
| commit | c1ccdcb9755a3e48035f2d53f11b7922503a697f (patch) | |
| tree | 7c9bec32375e80e3a18b0a35ca8aaa91d0ccb47a | |
| parent | 1f1cc4dedd025e79477b78bdd479d7bef4a2183d (diff) | |
| download | ruby-c1ccdcb9755a3e48035f2d53f11b7922503a697f.tar.gz ruby-c1ccdcb9755a3e48035f2d53f11b7922503a697f.tar.xz ruby-c1ccdcb9755a3e48035f2d53f11b7922503a697f.zip | |
* string.c (rb_str_each_char): return original string.
[ruby-core:23499]
* string.c (rb_str_each_codepoint): protect string from
modification.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@23552 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
| -rw-r--r-- | ChangeLog | 8 | ||||
| -rw-r--r-- | string.c | 7 |
2 files changed, 13 insertions, 2 deletions
@@ -1,3 +1,11 @@ +Sat May 23 23:52:33 2009 Yukihiro Matsumoto <matz@ruby-lang.org> + + * string.c (rb_str_each_char): return original string. + [ruby-core:23499] + + * string.c (rb_str_each_codepoint): protect string from + modification. + Sat May 23 21:48:58 2009 Nobuyoshi Nakada <nobu@ruby-lang.org> * ext/dl/handle.c (rb_dlhandle_s_sym): added a method to access @@ -5925,6 +5925,7 @@ rb_str_each_byte(VALUE str) static VALUE rb_str_each_char(VALUE str) { + VALUE orig = str; int i, len, n; const char *ptr; rb_encoding *enc; @@ -5948,7 +5949,7 @@ rb_str_each_char(VALUE str) rb_yield(rb_str_subseq(str, i, n)); } } - return str; + return orig; } /* @@ -5984,6 +5985,7 @@ rb_str_each_char(VALUE str) static VALUE rb_str_each_codepoint(VALUE str) { + VALUE orig = str; int len, n; unsigned int c; const char *ptr, *end; @@ -5991,6 +5993,7 @@ rb_str_each_codepoint(VALUE str) if (single_byte_optimizable(str)) return rb_str_each_byte(str); RETURN_ENUMERATOR(str, 0, 0); + str = rb_str_new4(str); ptr = RSTRING_PTR(str); len = RSTRING_LEN(str); end = RSTRING_END(str); @@ -6000,7 +6003,7 @@ rb_str_each_codepoint(VALUE str) rb_yield(UINT2NUM(c)); ptr += n; } - return str; + return orig; } static long |
