summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-02-17 04:04:14 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-02-17 04:04:14 +0000
commitcd50451ec7fb0c4a0c6d47eb1f696c334f9f5a93 (patch)
tree67538587d44b000f9311850e3fafb4df375ba9ba
parent033654d8435edd5664c0a783a1b0379b61ba1efc (diff)
downloadruby-cd50451ec7fb0c4a0c6d47eb1f696c334f9f5a93.tar.gz
ruby-cd50451ec7fb0c4a0c6d47eb1f696c334f9f5a93.tar.xz
ruby-cd50451ec7fb0c4a0c6d47eb1f696c334f9f5a93.zip
* string.c (str_sublen): use rb_enc_strlen.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@15517 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rw-r--r--string.c14
2 files changed, 7 insertions, 11 deletions
diff --git a/ChangeLog b/ChangeLog
index 5bcd0ab78..b37fc4652 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Sun Feb 17 13:03:48 2008 Tanaka Akira <akr@fsij.org>
+
+ * string.c (str_sublen): use rb_enc_strlen.
+
Sun Feb 17 12:17:52 2008 NARUSE, Yui <naruse@ruby-lang.org>
* enc/{euc_jp.c,gbk.c,iso_8859_1.c,iso_8859_11.c,iso_8859_13.c,
diff --git a/string.c b/string.c
index cc39d7269..aef3d1896 100644
--- a/string.c
+++ b/string.c
@@ -1071,19 +1071,11 @@ str_utf8_offset(const char *p, const char *e, int nth)
static long
str_sublen(VALUE str, long pos, rb_encoding *enc)
{
- if (rb_enc_mbmaxlen(enc) == 1 || pos < 0) return pos;
+ if (rb_enc_mbmaxlen(enc) == 1 || pos < 0)
+ return pos;
else {
char *p = RSTRING_PTR(str);
- char *e = p + pos;
- long i;
-
- i = 0;
- while (p < e) {
- p += rb_enc_mbclen(p, RSTRING_END(str), enc);
- i++;
- }
- if (p == e) return i;
- return i - 1;
+ return rb_enc_strlen(p, p + pos, enc);
}
}