summaryrefslogtreecommitdiff
path: root/io.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-01-14 15:07:49 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-01-14 15:07:49 +0000
commitfa246559d2c1206e3f3d4b409c2e161671821905 (patch)
tree719f2b4bb8b2f330a39ea68e8dfd20af13b103bd /io.c
parentdfca247f666821d41176737a89186cecf4a7a1fa (diff)
* io.c (appendline): specifying limit should not generate broken
byte sequence. strings should be rounded. [ruby-dev:33088] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@15051 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'io.c')
-rw-r--r--io.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/io.c b/io.c
index 6ff3abd5d0..7d48f90f82 100644
--- a/io.c
+++ b/io.c
@@ -1712,6 +1712,18 @@ appendline(rb_io_t *fptr, int delim, const char *rsptr, int rslen, VALUE *strp,
if (c != EOF) {
RSTRING_PTR(str)[last++] = c;
}
+ if (limit > 0 && limit == pending) {
+ char *p = fptr->rbuf+fptr->rbuf_off;
+ char *pp = p + limit;
+ char *pl = rb_enc_left_char_head(p, pp, io_read_encoding(fptr));
+
+ if (pl < pp) {
+ int diff = pp - pl;
+ pending -= diff;
+ limit = pending;
+ rb_str_set_len(str, RSTRING_LEN(str)-diff);
+ }
+ }
read_buffered_data(RSTRING_PTR(str) + last, pending, fptr); /* must not fail */
limit -= pending;
*lp = limit;