summaryrefslogtreecommitdiff
path: root/include/sys/wait.h
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2013-11-09 00:04:02 -0500
committerRich Felker <dalias@aerifal.cx>2013-11-09 00:04:02 -0500
commitf5980e330a331b83f99a25c522aae00170dff131 (patch)
treece6caa60da0d2167ac6dbf80e9b5c8100524ccda /include/sys/wait.h
parent41a9ba25cd810fb86ad0d6943bf2d5556d91b99e (diff)
downloadmusl-f5980e330a331b83f99a25c522aae00170dff131.tar.gz
musl-f5980e330a331b83f99a25c522aae00170dff131.tar.bz2
musl-f5980e330a331b83f99a25c522aae00170dff131.tar.xz
musl-f5980e330a331b83f99a25c522aae00170dff131.zip
adjust sys/wait.h not to produde errors in strict ISO C feature profile
siginfo_t is not available from signal.h when the strict ISO C feature profile (e.g. passing -std=c99 to gcc without defining any other feature test macros) is used, but the type is needed to declare waitid. using sys/wait.h (or any POSIX headers) in strict ISO C mode is an application bug, but in the interest of compatibility, it's best to avoid producing gratuitous errors. the simplest fix I could find is suppressing the declaration of waitid (and also signal.h inclusion, since it's not needed for anything else) in this case, while still exposing everything else in sys/wait.h
Diffstat (limited to 'include/sys/wait.h')
-rw-r--r--include/sys/wait.h10
1 files changed, 7 insertions, 3 deletions
diff --git a/include/sys/wait.h b/include/sys/wait.h
index a7ad7cd1..c794f5d3 100644
--- a/include/sys/wait.h
+++ b/include/sys/wait.h
@@ -6,8 +6,6 @@ extern "C" {
#include <features.h>
-#include <signal.h>
-
#define __NEED_pid_t
#define __NEED_id_t
#include <bits/alltypes.h>
@@ -19,9 +17,15 @@ typedef enum {
} idtype_t;
pid_t wait (int *);
-int waitid (idtype_t, id_t, siginfo_t *, int);
pid_t waitpid (pid_t, int *, int );
+#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
+ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) \
+ || defined(_BSD_SOURCE)
+#include <signal.h>
+int waitid (idtype_t, id_t, siginfo_t *, int);
+#endif
+
#if defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
#include <sys/resource.h>
pid_t wait3 (int *, int, struct rusage *);