From 86edc9ab8541d15b470dd4fe0bac1e136c2ffced Mon Sep 17 00:00:00 2001 From: ksss Date: Sun, 21 May 2017 22:54:46 +0900 Subject: IO#sysread should raise IOError when closed --- src/io.c | 2 +- test/io.rb | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/src/io.c b/src/io.c index 2a24b18a4..f15f182f2 100644 --- a/src/io.c +++ b/src/io.c @@ -636,7 +636,7 @@ mrb_io_sysread(mrb_state *mrb, mrb_value io) buf = mrb_str_resize(mrb, buf, maxlen); } - fptr = (struct mrb_io *)mrb_get_datatype(mrb, io, &mrb_io_type); + fptr = (struct mrb_io *)io_get_open_fptr(mrb, io); ret = read(fptr->fd, RSTRING_PTR(buf), maxlen); switch (ret) { case 0: /* EOF */ diff --git a/test/io.rb b/test/io.rb index 5a95961f3..02ab038bb 100644 --- a/test/io.rb +++ b/test/io.rb @@ -235,6 +235,7 @@ assert('IO.sysopen, IO#sysread') do end io.close assert_equal "", io.sysread(0) + assert_raise(IOError) { io.sysread(1) } io.closed? end -- cgit v1.2.3