diff --git a/ChangeLog b/ChangeLog index 45e89d1ba7..fdfd848ebf 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +Tue Feb 14 16:00:30 2012 Nobuyoshi Nakada + + * io.c (io_setstrbuf): cut down the buffer if longer. + Tue Feb 14 15:06:37 2012 Nobuyoshi Nakada * lib/test/unit/assertions.rb (build_message): skip escaped diff --git a/io.c b/io.c index 541263980e..074d2c50f7 100644 --- a/io.c +++ b/io.c @@ -2072,7 +2072,7 @@ io_shift_cbuf(rb_io_t *fptr, int len, VALUE *strp) } static void -io_setstrbuf(VALUE *str,long len) +io_setstrbuf(VALUE *str, long len) { #ifdef _WIN32 len = (len + 1) & ~1L; /* round up for wide char */ @@ -2081,8 +2081,13 @@ io_setstrbuf(VALUE *str,long len) *str = rb_str_new(0, 0); } else { - StringValue(*str); - len -= RSTRING_LEN(*str); + VALUE s = StringValue(*str); + long clen = RSTRING_LEN(s); + if (clen >= len) { + if (clen != len) rb_str_set_len(s, len); + return; + } + len -= clen; } rb_str_modify_expand(*str, len); }