diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-02-29 06:19:21 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-02-29 06:19:21 +0000 |
commit | 8c2372933098e73a549e0c8ce7c9edc94c03e38a (patch) | |
tree | 1387dc138321fdc44b90cddcb87609889966d229 /string.c | |
parent | 6fcc9bd4dd149487ba883a26537408e97c382224 (diff) | |
download | ruby-8c2372933098e73a549e0c8ce7c9edc94c03e38a.tar.gz ruby-8c2372933098e73a549e0c8ce7c9edc94c03e38a.tar.xz ruby-8c2372933098e73a549e0c8ce7c9edc94c03e38a.zip |
* string.c (rb_str_rpartition): calculation was done in byte indexing.
* test/ruby/test_m17n_comb.rb (TestM17NComb::test_str_start_with):
allow start_with? matching on broken strings.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@15639 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'string.c')
-rw-r--r-- | string.c | 7 |
1 files changed, 4 insertions, 3 deletions
@@ -1144,6 +1144,7 @@ str_nth(const char *p, const char *e, int nth, rb_encoding *enc, int singlebyte) return (char *)p; } +/* char offset to byte offset */ static int str_offset(const char *p, const char *e, int nth, rb_encoding *enc, int singlebyte) { @@ -1204,6 +1205,7 @@ str_utf8_offset(const char *p, const char *e, int nth) } #endif +/* byte offset to char offset */ long rb_str_sublen(VALUE str, long pos) { @@ -6036,10 +6038,9 @@ rb_str_rpartition(VALUE str, VALUE sep) if (regex) { sep = rb_reg_nth_match(0, rb_backref_get()); } - return rb_ary_new3(3, rb_str_subseq(str, 0, pos), + return rb_ary_new3(3, rb_str_substr(str, 0, pos), sep, - rb_str_subseq(str, pos+RSTRING_LEN(sep), - RSTRING_LEN(str)-pos-RSTRING_LEN(sep))); + rb_str_substr(str,pos+str_strlen(sep,STR_ENC_GET(sep)),RSTRING_LEN(str))); } /* |