[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