summaryrefslogtreecommitdiff
path: root/io.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-04-19 15:41:27 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-04-19 15:41:27 +0000
commita91d8b8c33b834f47ab000cc3844e9b18c1becba (patch)
tree9bbe283239d9be1358ae9b6f30cad2f0ecb9a352 /io.c
parentaef15affc7ae8dc03220efa3cc2b21906cd8e7a1 (diff)
* io.c (internal_{read,write}_func, rb_{read,write}_internal):
reverted r27265, since now rb_thread_blocking_region() preserves errno. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@27403 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'io.c')
-rw-r--r--io.c21
1 files changed, 4 insertions, 17 deletions
diff --git a/io.c b/io.c
index 2c18e07c75..c9ac80c816 100644
--- a/io.c
+++ b/io.c
@@ -530,7 +530,6 @@ wsplit_p(rb_io_t *fptr)
struct io_internal_struct {
int fd;
- int saved_errno;
void *buf;
size_t capa;
};
@@ -539,48 +538,36 @@ static VALUE
internal_read_func(void *ptr)
{
struct io_internal_struct *iis = (struct io_internal_struct*)ptr;
- ssize_t ret = read(iis->fd, iis->buf, iis->capa);
- iis->saved_errno = errno;
- return (VALUE)ret;
+ return read(iis->fd, iis->buf, iis->capa);
}
static VALUE
internal_write_func(void *ptr)
{
struct io_internal_struct *iis = (struct io_internal_struct*)ptr;
- ssize_t ret = write(iis->fd, iis->buf, iis->capa);
- iis->saved_errno = errno;
- return (VALUE)ret;
+ return write(iis->fd, iis->buf, iis->capa);
}
static ssize_t
rb_read_internal(int fd, void *buf, size_t count)
{
struct io_internal_struct iis;
- ssize_t ret;
-
iis.fd = fd;
iis.buf = buf;
iis.capa = count;
- ret = (ssize_t)rb_thread_blocking_region(internal_read_func, &iis, RUBY_UBF_IO, 0);
- errno = iis.saved_errno;
- return ret;
+ return (ssize_t)rb_thread_blocking_region(internal_read_func, &iis, RUBY_UBF_IO, 0);
}
static ssize_t
rb_write_internal(int fd, void *buf, size_t count)
{
struct io_internal_struct iis;
- ssize_t ret;
-
iis.fd = fd;
iis.buf = buf;
iis.capa = count;
- ret = (ssize_t)rb_thread_blocking_region(internal_write_func, &iis, RUBY_UBF_IO, 0);
- errno = iis.saved_errno;
- return ret;
+ return (ssize_t)rb_thread_blocking_region(internal_write_func, &iis, RUBY_UBF_IO, 0);
}
static long