diff options
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | test/ruby/test_econv.rb | 9 | ||||
-rw-r--r-- | transcode.c | 2 |
3 files changed, 14 insertions, 1 deletions
@@ -1,3 +1,7 @@ +Sun Aug 31 04:35:21 2008 Tanaka Akira <akr@fsij.org> + + * transcode.c (rb_econv_putback): putback from last byte. + Sun Aug 31 04:27:04 2008 Tanaka Akira <akr@fsij.org> * transcode.c (econv_putback): renamed from econv_primitive_putback. diff --git a/test/ruby/test_econv.rb b/test/ruby/test_econv.rb index 48b22fc270..db72430760 100644 --- a/test/ruby/test_econv.rb +++ b/test/ruby/test_econv.rb @@ -485,6 +485,15 @@ class TestEncodingConverter < Test::Unit::TestCase assert_equal(["abcdef", ""], [dst, src]) end + def test_putback2 + ec = Encoding::Converter.new("utf-16le", "euc-jp") + ret = ec.primitive_convert(src="\x00\xd8\x21\x00", dst="", nil, nil) + assert_equal(:invalid_byte_sequence, ret) + assert_equal("\x00", ec.putback(1)) + assert_equal("\x21", ec.putback(1)) + assert_equal("", ec.putback(1)) + end + def test_invalid_replace ec = Encoding::Converter.new("UTF-8", "EUC-JP", Encoding::Converter::INVALID_REPLACE) ret = ec.primitive_convert(src="abc\x80def", dst="", nil, 100) diff --git a/transcode.c b/transcode.c index 88ccc9b042..6885bb5544 100644 --- a/transcode.c +++ b/transcode.c @@ -1452,7 +1452,7 @@ rb_econv_putback(rb_econv_t *ec, unsigned char *p, int n) if (ec->num_trans == 0 || n == 0) return; tc = ec->elems[0].tc; - memcpy(p, TRANSCODING_READBUF(tc) + tc->recognized_len, n); + memcpy(p, TRANSCODING_READBUF(tc) + tc->recognized_len + tc->readagain_len - n, n); tc->readagain_len -= n; } |