зеркало из https://github.com/github/ruby.git
* io.c (rb_io_extract_modeenc): raise an error for ASCII incompatible
encoding without binmode. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19166 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
Родитель
a10a5ddaac
Коммит
d4384f1230
|
@ -1,3 +1,8 @@
|
|||
Sat Sep 6 07:24:49 2008 Tanaka Akira <akr@fsij.org>
|
||||
|
||||
* io.c (rb_io_extract_modeenc): raise an error for ASCII incompatible
|
||||
encoding without binmode.
|
||||
|
||||
Sat Sep 6 06:28:46 2008 Tanaka Akira <akr@fsij.org>
|
||||
|
||||
* enc/trans/escape.trans: new file.
|
||||
|
|
3
io.c
3
io.c
|
@ -3898,6 +3898,9 @@ rb_io_extract_modeenc(VALUE *vmode_p, VALUE opthash,
|
|||
if ((fmode & FMODE_BINMODE) && (fmode & FMODE_TEXTMODE))
|
||||
rb_raise(rb_eArgError, "both textmode and binmode specified");
|
||||
|
||||
if (enc && !rb_enc_asciicompat(enc) && !(fmode & FMODE_BINMODE))
|
||||
rb_raise(rb_eArgError, "ASCII incompatible encoding needs binmode");
|
||||
|
||||
*vmode_p = vmode;
|
||||
|
||||
*oflags_p = oflags;
|
||||
|
|
|
@ -1226,11 +1226,35 @@ EOT
|
|||
end
|
||||
|
||||
def test_textmode_read_ascii_incompat_internal
|
||||
with_tmpdir {
|
||||
# ascii incompatible internal encoding needs binmode.
|
||||
assert_raise(ArgumentError) {
|
||||
open("t.utf8.crlf", "rt:utf-8:utf-16be") {|f| }
|
||||
}
|
||||
assert_raise(ArgumentError) {
|
||||
open("t.utf8.crlf", "r:utf-8:utf-16be") {|f| }
|
||||
}
|
||||
assert_raise(ArgumentError) {
|
||||
open("t.utf16.crlf", "rt:utf-16be") {|f| }
|
||||
}
|
||||
assert_raise(ArgumentError) {
|
||||
open("t.utf16.crlf", "r:utf-16be") {|f| }
|
||||
}
|
||||
}
|
||||
end
|
||||
|
||||
def test_binmode_read_ascii_incompat_internal
|
||||
with_tmpdir {
|
||||
generate_file("t.utf8.crlf", "a\r\nb\r\n")
|
||||
open("t.utf8.crlf", "rt:utf-8:utf-16be") {|f|
|
||||
generate_file("t.utf16.crlf", "\0a\0\r\0\n\0b\0\r\0\n")
|
||||
# ascii incompatible internal encoding needs binmode.
|
||||
open("t.utf8.crlf", "rb:utf-8:utf-16be") {|f|
|
||||
content = f.read
|
||||
assert_equal("\0a\0\r\0\n\0b\0\r\0\n".force_encoding("UTF-16BE"),
|
||||
content)
|
||||
}
|
||||
open("t.utf16.crlf", "rb:utf-16be") {|f|
|
||||
content = f.read
|
||||
# textmode doesn't affect for ascii incompatible internal encoding.
|
||||
assert_equal("\0a\0\r\0\n\0b\0\r\0\n".force_encoding("UTF-16BE"),
|
||||
content)
|
||||
}
|
||||
|
@ -1239,12 +1263,38 @@ EOT
|
|||
|
||||
def test_textmode_write_ascii_incompat_internal
|
||||
with_tmpdir {
|
||||
open("t.utf8.lf", "wt:utf-8:utf-16be") {|f|
|
||||
# ascii incompatible internal encoding needs binmode.
|
||||
assert_raise(ArgumentError) {
|
||||
open("t.utf8", "wt:utf-8:utf-16be") {|f| }
|
||||
}
|
||||
assert_raise(ArgumentError) {
|
||||
open("t.utf8", "w:utf-8:utf-16be") {|f| }
|
||||
}
|
||||
assert_raise(ArgumentError) {
|
||||
open("t.utf8", "w:utf-8:utf-16be") {|f| }
|
||||
}
|
||||
assert_raise(ArgumentError) {
|
||||
open("t.utf16", "wt:utf-16be") {|f| }
|
||||
}
|
||||
assert_raise(ArgumentError) {
|
||||
open("t.utf16", "w:utf-16be") {|f| }
|
||||
}
|
||||
}
|
||||
end
|
||||
|
||||
def test_binmode_write_ascii_incompat_internal
|
||||
with_tmpdir {
|
||||
open("t.utf8.lf", "wb:utf-8:utf-16be") {|f|
|
||||
f.print "\0a\0\n\0b\0\n".force_encoding("UTF-16BE")
|
||||
}
|
||||
content = File.read("t.utf8.lf", :mode=>"rb:ascii-8bit")
|
||||
# textmode doesn't affect for ascii incompatible internal encoding.
|
||||
assert_equal("a\nb\n", content)
|
||||
|
||||
open("t.utf8.lf", "wb:utf-16be") {|f|
|
||||
f.print "\0a\0\n\0b\0\n".force_encoding("UTF-16BE")
|
||||
}
|
||||
content = File.read("t.utf8.lf", :mode=>"rb:ascii-8bit")
|
||||
assert_equal("\0a\0\n\0b\0\n", content)
|
||||
}
|
||||
end
|
||||
|
||||
|
|
Загрузка…
Ссылка в новой задаче