diff options
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | win32/win32.c | 14 |
2 files changed, 14 insertions, 5 deletions
@@ -1,3 +1,8 @@ +Wed Jun 18 18:09:08 2008 NAKAMURA Usaku <usa@ruby-lang.org> + + * win32/win32.c (poll_child_status): set EINVAL to errno when + GetExitCodeProcess() fails with ERROR_INVALID_HANDLE. + Wed Jun 18 15:01:18 2008 NARUSE, Yui <naruse@ruby-lang.org> * io.c (rb_open_file): fs_encoding and fname_encoding is diff --git a/win32/win32.c b/win32/win32.c index b62adad77..813c4ee19 100644 --- a/win32/win32.c +++ b/win32/win32.c @@ -2007,9 +2007,9 @@ is_pipe(SOCKET sock) /* DONT call this for SOCKET! it clains it is PIPE. */ { int ret; - RUBY_CRITICAL( - ret = (GetFileType((HANDLE)sock) == FILE_TYPE_PIPE) - ); + RUBY_CRITICAL({ + ret = (GetFileType((HANDLE)sock) == FILE_TYPE_PIPE); + }); return ret; } @@ -2857,8 +2857,12 @@ poll_child_status(struct ChildRecord *child, int *stat_loc) err = GetLastError(); if (err == ERROR_INVALID_PARAMETER) errno = ECHILD; - else - errno = map_errno(GetLastError()); + else { + if (GetLastError() == ERROR_INVALID_HANDLE) + errno = EINVAL; + else + errno = map_errno(GetLastError()); + } CloseChildHandle(child); return -1; } |