Index: io.c =================================================================== --- io.c (revision 25770) +++ io.c (working copy) @@ -1625,7 +1625,6 @@ return 0; if (res == econv_finished) { - clear_readconv(fptr); return -1; } @@ -1687,10 +1686,14 @@ else rb_str_set_len(str, 0); make_readconv(fptr, 0); while (1) { - if (fptr->cbuf_len) { + if (fptr->cbuf_len > fptr->cbuf_capa/2) { io_shift_cbuf(fptr, fptr->cbuf_len, &str); } if (more_char(fptr) == -1) { + if (fptr->cbuf_len) { + io_shift_cbuf(fptr, fptr->cbuf_len, &str); + } + clear_readconv(fptr); return io_enc_str(str, fptr); } } @@ -2172,6 +2175,7 @@ } } } while (more_char(fptr) != -1); + clear_readconv(fptr); *lp = limit; return EOF; } @@ -2820,6 +2824,7 @@ } } if (more_char(fptr) == -1) { + clear_readconv(fptr); /* ignore an incomplete character before EOF */ return io; }