diff options
author | Eli Zaretskii <eliz@gnu.org> | 2014-10-07 20:59:11 +0300 |
---|---|---|
committer | Paul Eggert <eggert@cs.ucla.edu> | 2014-10-07 13:17:23 -0700 |
commit | 8a695b675d018ecfab9db14fce4b13379f5ac908 (patch) | |
tree | 6ed33a0b2f2e3824107b0cf6bcf8747ae43666bb /lib | |
parent | 322e0b052c80b30792e8e7343f5e08e813e0d6fe (diff) | |
download | gnulib-8a695b675d018ecfab9db14fce4b13379f5ac908.tar.gz |
modules/fcntl: fix error reporting by dupfd
* lib/fcntl.c (dupfd) [_WIN32]: Don't overwrite the value of
errno set by _open_osfhandle by EMFILE. Convert errors
returned by DuplicateHandle to corresponding errno values.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/fcntl.c | 22 |
1 files changed, 19 insertions, 3 deletions
diff --git a/lib/fcntl.c b/lib/fcntl.c index 54f748606b..1e35dd1a4f 100644 --- a/lib/fcntl.c +++ b/lib/fcntl.c @@ -89,8 +89,25 @@ dupfd (int oldfd, int newfd, int flags) inherit, /* InheritHandle */ DUPLICATE_SAME_ACCESS)) /* Options */ { - /* TODO: Translate GetLastError () into errno. */ - errno = EMFILE; + switch (GetLastError ()) + { + case ERROR_TOO_MANY_OPEN_FILES: + errno = EMFILE; + break; + case ERROR_INVALID_HANDLE: + case ERROR_INVALID_TARGET_HANDLE: + case ERROR_DIRECT_ACCESS_HANDLE: + errno = EBADF; + break; + case ERROR_INVALID_PARAMETER: + case ERROR_INVALID_FUNCTION: + case ERROR_INVALID_ACCESS: + errno = EINVAL; + break; + default: + errno = EACCES; + break; + } result = -1; break; } @@ -98,7 +115,6 @@ dupfd (int oldfd, int newfd, int flags) if (duplicated_fd < 0) { CloseHandle (new_handle); - errno = EMFILE; result = -1; break; } |