diff options
author | naruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-10-12 06:37:27 +0000 |
---|---|---|
committer | naruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-10-12 06:37:27 +0000 |
commit | 7587eb706a593f1728fcc0f3c4480856159e5d2a (patch) | |
tree | 9317224b226db60a0341ac0b70b970b8ca6690e6 | |
parent | 0a8f047a983deaf853e8ddc9f70da78f3a83f9ef (diff) |
* io.c (rb_io_ungetc): use unsigned int for GB18030.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@29448 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | io.c | 11 | ||||
-rw-r--r-- | test/ruby/test_io_m17n.rb | 24 |
3 files changed, 34 insertions, 5 deletions
@@ -1,3 +1,7 @@ +Tue Oct 12 15:36:09 2010 NARUSE, Yui <naruse@ruby-lang.org> + + * io.c (rb_io_ungetc): use unsigned int for GB18030. + Tue Oct 12 15:14:21 2010 NARUSE, Yui <naruse@ruby-lang.org> * io.c (rb_io_putc): support multibyte characters. @@ -3229,12 +3229,13 @@ rb_io_ungetc(VALUE io, VALUE c) rb_io_check_char_readable(fptr); if (NIL_P(c)) return Qnil; if (FIXNUM_P(c)) { - int cc = FIX2INT(c); - rb_encoding *enc = io_read_encoding(fptr); - char buf[16]; - - c = rb_str_new(buf, rb_enc_mbcput(cc, buf, enc)); + c = rb_enc_uint_chr(FIX2UINT(c), io_read_encoding(fptr)); } +#if SIZEOF_LONG > SIZEOF_INT + else if (TYPE(c) == T_BIGNUM) { + c = rb_enc_uint_chr(NUM2UINT(c), io_read_encoding(fptr)); + } +#endif else { SafeStringValue(c); } diff --git a/test/ruby/test_io_m17n.rb b/test/ruby/test_io_m17n.rb index 5f35c227ea..10714b3e44 100644 --- a/test/ruby/test_io_m17n.rb +++ b/test/ruby/test_io_m17n.rb @@ -418,6 +418,30 @@ EOT } end + def test_ungetc_int + with_tmpdir { + generate_file('tmp', "A") + s = open("tmp", "r:GB18030") {|f| + f.ungetc(0x8431A439) + f.read + } + assert_equal(Encoding::GB18030, s.encoding) + assert_str_equal(0x8431A439.chr("GB18030")+"A", s) + } + end + + def test_ungetc_str + with_tmpdir { + generate_file('tmp', "A") + s = open("tmp", "r:GB18030") {|f| + f.ungetc(0x8431A439.chr("GB18030")) + f.read + } + assert_equal(Encoding::GB18030, s.encoding) + assert_str_equal(0x8431A439.chr("GB18030")+"A", s) + } + end + def test_ungetc_stateful_conversion with_tmpdir { src = "before \e$B\x23\x30\x23\x31\e(B after".force_encoding("iso-2022-jp") |