2 Copyright (C) 2009-2025 Free Software Foundation, Inc.
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation, either version 3, or (at your option)
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, see <https://www.gnu.org/licenses/>. */
21 #include "signature.h"
22 SIGNATURE_CHECK (pipe
, int, (int[2]));
26 #if defined _WIN32 && ! defined __CYGWIN__
27 /* Get declarations of the native Windows API functions. */
28 # define WIN32_LEAN_AND_MEAN
30 /* Get _get_osfhandle. */
31 # if GNULIB_MSVC_NOTHROW
32 # include "msvc-nothrow.h"
38 #include "binary-io.h"
41 /* Return true if FD is open. */
45 #if defined _WIN32 && ! defined __CYGWIN__
46 /* On native Windows, the initial state of unassigned standard file
47 descriptors is that they are open but point to an
48 INVALID_HANDLE_VALUE, and there is no fcntl. */
49 return (HANDLE
) _get_osfhandle (fd
) != INVALID_HANDLE_VALUE
;
52 # error Please port fcntl to your platform
54 return 0 <= fcntl (fd
, F_GETFL
);
58 /* Return true if FD is not inherited to child processes. */
62 #if defined _WIN32 && ! defined __CYGWIN__
63 HANDLE h
= (HANDLE
) _get_osfhandle (fd
);
65 ASSERT (GetHandleInformation (h
, &flags
));
66 return (flags
& HANDLE_FLAG_INHERIT
) == 0;
69 ASSERT ((flags
= fcntl (fd
, F_GETFD
)) >= 0);
70 return (flags
& FD_CLOEXEC
) != 0;
74 /* Return true if FD is in non-blocking mode. */
76 is_nonblocking (int fd
)
78 #if defined _WIN32 && ! defined __CYGWIN__
79 /* We don't use the non-blocking mode for sockets here. */
83 ASSERT ((flags
= fcntl (fd
, F_GETFL
)) >= 0);
84 return (flags
& O_NONBLOCK
) != 0;
95 ASSERT (pipe (fd
) >= 0);
98 ASSERT (fd
[0] != fd
[1]);
99 ASSERT (is_open (fd
[0]));
100 ASSERT (is_open (fd
[1]));
101 ASSERT (!is_cloexec (fd
[0]));
102 ASSERT (!is_cloexec (fd
[1]));
103 ASSERT (!is_nonblocking (fd
[0]));
104 ASSERT (!is_nonblocking (fd
[1]));
106 return test_exit_status
;