From 86ade651044cc606584e11a5b2e8d02f315d3fa9 Mon Sep 17 00:00:00 2001 From: matz Date: Wed, 29 Oct 2008 16:40:05 +0000 Subject: * io.c (rb_io_rewind): should reset fptr->readconv if it's available. * io.c (more_char): clear readconv at EOF. * test/ruby/test_file.rb: should not read after EOF. use rewind instead. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@20045 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 10 ++++++++++ io.c | 9 ++++++++- test/ruby/test_file.rb | 24 ++++++++++++++++-------- 3 files changed, 34 insertions(+), 9 deletions(-) diff --git a/ChangeLog b/ChangeLog index 5060e6fb9f..4490f78c27 100644 --- a/ChangeLog +++ b/ChangeLog @@ -17,6 +17,16 @@ Wed Oct 29 23:57:29 2008 Yusuke Endoh * array.c (rb_ary_sort_bang): replacing array during sort broke invariant of array. +Wed Oct 29 21:06:46 2008 Yukihiro Matsumoto + + * io.c (rb_io_rewind): should reset fptr->readconv if it's + available. + + * io.c (more_char): clear readconv at EOF. + + * test/ruby/test_file.rb: should not read after EOF. use rewind + instead. + Wed Oct 29 20:45:08 2008 Yusuke Endoh * test/webrick/utils.rb (start_server): provide a reference to log of diff --git a/io.c b/io.c index 772d9e4d71..5fa6a1f17c 100644 --- a/io.c +++ b/io.c @@ -1057,6 +1057,8 @@ rb_io_set_pos(VALUE io, VALUE offset) return OFFT2NUM(pos); } +static void clear_readconv(rb_io_t *fptr); + /* * call-seq: * ios.rewind => 0 @@ -1082,6 +1084,9 @@ rb_io_rewind(VALUE io) ARGF.gets_lineno -= fptr->lineno; } fptr->lineno = 0; + if (fptr->readconv) { + clear_readconv(fptr); + } return INT2FIX(0); } @@ -1499,8 +1504,10 @@ more_char(rb_io_t *fptr) if (cbuf_len0 != fptr->cbuf_len) return 0; - if (res == econv_finished) + if (res == econv_finished) { + clear_readconv(fptr); return -1; + } if (res == econv_source_buffer_empty) { if (fptr->rbuf_len == 0) { diff --git a/test/ruby/test_file.rb b/test/ruby/test_file.rb index 0732c76a82..b4666ad4a6 100644 --- a/test/ruby/test_file.rb +++ b/test/ruby/test_file.rb @@ -42,8 +42,9 @@ class TestFile < Test::Unit::TestCase f.print "abc" f.truncate(0) f.print "def" - f.close + f.flush assert_equal("\0\0\0def", File.read(f.path), "[ruby-dev:24191]") + f.close end def test_truncate_rbuf @@ -68,7 +69,8 @@ class TestFile < Test::Unit::TestCase [nil, {:textmode=>true}, {:binmode=>true}].each do |mode| f = Tempfile.new("test-extended-file", mode) assert_nil(f.getc) - open(f.path, "w") {|g| g.print "a" } + f.print "a" + f.rewind assert_equal("a", f.read, "mode = <#{mode}>") end end @@ -77,7 +79,8 @@ class TestFile < Test::Unit::TestCase [nil, {:textmode=>true}, {:binmode=>true}].each do |mode| f = Tempfile.new("test-extended-file", mode) assert_nil(f.getc) - open(f.path, "w") {|g| g.print "a" } + f.print "a" + f.rewind assert_equal("a", f.gets("a"), "mode = <#{mode}>") end end @@ -86,7 +89,8 @@ class TestFile < Test::Unit::TestCase [nil, {:textmode=>true}, {:binmode=>true}].each do |mode| f = Tempfile.new("test-extended-file", mode) assert_nil(f.getc) - open(f.path, "wb") {|g| g.print "\na" } + f.print "\na" + f.rewind assert_equal("a", f.gets(""), "mode = <#{mode}>") end end @@ -95,7 +99,8 @@ class TestFile < Test::Unit::TestCase [nil, {:textmode=>true}, {:binmode=>true}].each do |mode| f = Tempfile.new("test-extended-file", mode) assert_nil(f.getc) - open(f.path, "w") {|g| g.print "a" } + f.print "a" + f.rewind result = [] f.each_char {|b| result << b } assert_equal([?a], result, "mode = <#{mode}>") @@ -106,7 +111,8 @@ class TestFile < Test::Unit::TestCase [nil, {:textmode=>true}, {:binmode=>true}].each do |mode| f = Tempfile.new("test-extended-file", mode) assert_nil(f.getc) - open(f.path, "w") {|g| g.print "a" } + f.print "a" + f.rewind result = [] f.each_byte {|b| result << b.chr } assert_equal([?a], result, "mode = <#{mode}>") @@ -117,7 +123,8 @@ class TestFile < Test::Unit::TestCase [nil, {:textmode=>true}, {:binmode=>true}].each do |mode| f = Tempfile.new("test-extended-file", mode) assert_nil(f.getc) - open(f.path, "w") {|g| g.print "a" } + f.print "a" + f.rewind assert_equal(?a, f.getc, "mode = <#{mode}>") end end @@ -126,7 +133,8 @@ class TestFile < Test::Unit::TestCase [nil, {:textmode=>true}, {:binmode=>true}].each do |mode| f = Tempfile.new("test-extended-file", mode) assert_nil(f.getc) - open(f.path, "w") {|g| g.print "a" } + f.print "a" + f.rewind assert_equal(?a, f.getbyte.chr, "mode = <#{mode}>") end end -- cgit v1.2.3