[llvm-commits] CVS: llvm/lib/System/Unix/Unix.h
Reid Spencer
reid at x10sys.com
Sun Dec 26 22:18:01 PST 2004
Changes in directory llvm/lib/System/Unix:
Unix.h updated: 1.9 -> 1.10
---
Log message:
For PR351: http://llvm.cs.uiuc.edu/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.
---
Diffs of the changes: (+58 -4)
Index: llvm/lib/System/Unix/Unix.h
diff -u llvm/lib/System/Unix/Unix.h:1.9 llvm/lib/System/Unix/Unix.h:1.10
--- llvm/lib/System/Unix/Unix.h:1.9 Wed Dec 8 10:10:52 2004
+++ llvm/lib/System/Unix/Unix.h Mon Dec 27 00:17:50 2004
@@ -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
More information about the llvm-commits
mailing list