summaryrefslogtreecommitdiff
path: root/io.c
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-25 04:29:30 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-25 04:29:30 +0000
commitf29ec7ed67fb25ff998eb2f6d31ea103a2e33e46 (patch)
treee1115f21a0a9a9a3c23e7a0433a7509b567f4fec /io.c
parenta71fb38d47d910b421c56e7b28931be12a32d09d (diff)
* io.c (rb_io_flush): fsync() after buffer is flushed on win32.
[ruby-core:20043] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@20982 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'io.c')
-rw-r--r--io.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/io.c b/io.c
index e86a59ae73..7bab55b177 100644
--- a/io.c
+++ b/io.c
@@ -983,6 +983,9 @@ rb_io_flush(VALUE io)
if (fptr->mode & FMODE_WRITABLE) {
io_fflush(fptr);
+#ifdef _WIN32
+ fsync(fptr->fd);
+#endif
}
if (fptr->mode & FMODE_READABLE) {
io_unread(fptr);
@@ -4416,7 +4419,9 @@ popen_redirect(struct popen_arg *p)
}
}
}
+#endif
+#if defined(HAVE_FORK) || defined(_WIN32)
void
rb_close_before_exec(int lowfd, int maxhint, VALUE noclose_fds)
{
@@ -4433,12 +4438,16 @@ rb_close_before_exec(int lowfd, int maxhint, VALUE noclose_fds)
if (ret != -1 && !(ret & FD_CLOEXEC)) {
fcntl(fd, F_SETFD, ret|FD_CLOEXEC);
}
+#elif defined(_WIN32)
+ rb_w32_fd_noinherit(fd);
#else
close(fd);
#endif
}
}
+#endif
+#ifdef HAVE_FORK
static int
popen_exec(void *pp, char *errmsg, size_t errmsg_len)
{
@@ -5922,13 +5931,15 @@ rb_io_initialize(int argc, VALUE *argv, VALUE io)
fd = NUM2INT(fnum);
UPDATE_MAXFD(fd);
- if (NIL_P(vmode)) {
#if defined(HAVE_FCNTL) && defined(F_GETFL)
+ if (NIL_P(vmode)) {
oflags = fcntl(fd, F_GETFL);
if (oflags == -1) rb_sys_fail(0);
fmode = rb_io_oflags_fmode(oflags);
-#endif
}
+#elif defined(_WIN32)
+ if (rb_w32_is_valid_fd(fd)) rb_sys_fail(0);
+#endif
MakeOpenFile(io, fp);
fp->fd = fd;
fp->mode = fmode;