summaryrefslogtreecommitdiffstats
path: root/llvm/lib/System/Unix/Unix.h
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2004-12-27 06:17:50 +0000
committerReid Spencer <rspencer@reidspencer.com>2004-12-27 06:17:50 +0000
commite925d8b8b2cc04b5376cda63671e1a95d80c86ae (patch)
tree8a875695aef3a33e4ee364619149175640788791 /llvm/lib/System/Unix/Unix.h
parentefda887fe204812fdcebb5ddd3730ce3568e8a80 (diff)
downloadbcm5719-llvm-e925d8b8b2cc04b5376cda63671e1a95d80c86ae.tar.gz
bcm5719-llvm-e925d8b8b2cc04b5376cda63671e1a95d80c86ae.zip
For PR351:
* Ensure #includes are wrapped with appropriate HAVE_ guards * Account for variations in time.h and sys/time.h inclusion. * Add macros for getting wait(2) exit status correctly (per autoconf sugg.) * Implement ThrowErrno in terms of strerror_r, strerror or none based on what is available on the platform. llvm-svn: 19161
Diffstat (limited to 'llvm/lib/System/Unix/Unix.h')
-rw-r--r--llvm/lib/System/Unix/Unix.h62
1 files changed, 58 insertions, 4 deletions
diff --git a/llvm/lib/System/Unix/Unix.h b/llvm/lib/System/Unix/Unix.h
index 71445094afd..6dc75545b66 100644
--- a/llvm/lib/System/Unix/Unix.h
+++ b/llvm/lib/System/Unix/Unix.h
@@ -11,24 +11,78 @@
//
//===----------------------------------------------------------------------===//
+#ifndef LLVM_SYSTEM_UNIX_UNIX_H
+#define LLVM_SYSTEM_UNIX_UNIX_H
+
//===----------------------------------------------------------------------===//
//=== WARNING: Implementation here must contain only generic UNIX code that
//=== is guaranteed to work on all UNIX variants.
//===----------------------------------------------------------------------===//
#include "llvm/Config/config.h" // Get autoconf configuration settings
-#include <unistd.h>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#include <cerrno>
+#include <string>
+#include <algorithm>
+
+#ifdef HAVE_UNISTD_H
+#include <unistd.h>
+#endif
+
+#ifdef HAVE_SYS_TYPES_H
#include <sys/types.h>
+#endif
+
+#ifdef HAVE_SYS_PARAM_H
#include <sys/param.h>
+#endif
+
+#ifdef HAVE_ASSERT_H
#include <assert.h>
-#include <string>
-#include <algorithm>
+#endif
+
+#ifdef TIME_WITH_SYS_TIME
+# include <sys/time.h>
+# include <time.h>
+#else
+# ifdef HAVE_SYS_TIME_H
+# include <sys/time.h>
+# else
+# include <time.h>
+# endif
+#endif
+
+#ifdef HAVE_SYS_WAIT_H
+# include <sys/wait.h>
+#endif
+
+#ifndef WEXITSTATUS
+# define WEXITSTATUS(stat_val) ((unsigned)(stat_val) >> 8)
+#endif
+
+#ifndef WIFEXITED
+# define WIFEXITED(stat_val) (((stat_val) & 255) == 0)
+#endif
inline void ThrowErrno(const std::string& prefix) {
char buffer[MAXPATHLEN];
- throw prefix + ": " + strerror(errno);
+#ifdef HAVE_STRERROR_R
+ // strerror_r is thread-safe.
+ strerror_r(errno,buffer,MAXPATHLEN-1);
+#elif HAVE_STRERROR
+ // Copy the thread un-safe result of strerror into
+ // the buffer as fast as possible to minimize impact
+ // of collision of strerror in multiple threads.
+ strncpy(buffer,strerror(errno),MAXPATHLEN-1);
+ buffer[MAXPATHLEN-1] = 0;
+#else
+ // Strange that this system doesn't even have strerror
+ // but, oh well, just use a generic message
+ sprintf(buffer, "Error #%d", errno);
+#endif
+ throw prefix + ": " + buffer;
}
+
+#endif
OpenPOWER on IntegriCloud