summaryrefslogtreecommitdiff
path: root/lib/dup2.c
diff options
context:
space:
mode:
authorBruno Haible <bruno@clisp.org>2011-09-18 10:34:24 +0200
committerBruno Haible <bruno@clisp.org>2011-09-18 10:34:24 +0200
commit9df7fd21fac8a3af186c9c560ff0da10f007ccc5 (patch)
tree2a00aa887d5af582f554547926b6358f7d630262 /lib/dup2.c
parent0b3a22be69e9afb311ae8b64e141155b3d948f14 (diff)
downloadgnulib-9df7fd21fac8a3af186c9c560ff0da10f007ccc5.tar.gz
dup2: Support for MSVC.
* lib/dup2.c: Include msvc-inval.h. (rpl_dup2): Handle invalid parameter notifications during dup2 and _get_osfhandle calls. * modules/dup2 (Depends-on): Add msvc-inval. * doc/posix-functions/dup2.texi: Mention problem on MSVC.
Diffstat (limited to 'lib/dup2.c')
-rw-r--r--lib/dup2.c29
1 files changed, 27 insertions, 2 deletions
diff --git a/lib/dup2.c b/lib/dup2.c
index e00dc7b2e3..09ae49fb3f 100644
--- a/lib/dup2.c
+++ b/lib/dup2.c
@@ -31,6 +31,8 @@
# include <windows.h>
#endif
+#include "msvc-inval.h"
+
#if HAVE_DUP2
# undef dup2
@@ -45,7 +47,19 @@ rpl_dup2 (int fd, int desired_fd)
future dup2 calls will hang. */
if (fd == desired_fd)
{
- if ((HANDLE) _get_osfhandle (fd) == INVALID_HANDLE_VALUE)
+ HANDLE handle;
+
+ TRY_MSVC_INVAL
+ {
+ handle = (HANDLE) _get_osfhandle (fd);
+ }
+ CATCH_MSVC_INVAL
+ {
+ handle = INVALID_HANDLE_VALUE;
+ }
+ DONE_MSVC_INVAL
+
+ if (handle == INVALID_HANDLE_VALUE)
{
errno = EBADF;
return -1;
@@ -64,7 +78,18 @@ rpl_dup2 (int fd, int desired_fd)
if (fd == desired_fd)
return fcntl (fd, F_GETFL) == -1 ? -1 : fd;
# endif
- result = dup2 (fd, desired_fd);
+
+ TRY_MSVC_INVAL
+ {
+ result = dup2 (fd, desired_fd);
+ }
+ CATCH_MSVC_INVAL
+ {
+ result = -1;
+ errno = EBADF;
+ }
+ DONE_MSVC_INVAL
+
# ifdef __linux__
/* Correct a Linux return value.
<http://git.kernel.org/?p=linux/kernel/git/stable/linux-2.6.30.y.git;a=commitdiff;h=2b79bc4f7ebbd5af3c8b867968f9f15602d5f802>