summaryrefslogtreecommitdiffstats
path: root/llvm/lib/System/Unix/Unix.h
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2006-07-07 17:32:37 +0000
committerChris Lattner <sabre@nondot.org>2006-07-07 17:32:37 +0000
commit5a9d2e5a0a66a28fc322437b0146eb5b1b368087 (patch)
tree877a5ae3eb4f11d6dd139031b3584e83166c3fc2 /llvm/lib/System/Unix/Unix.h
parent1fb6e0d79da834bed4ff965ae4ad876f583afce4 (diff)
downloadbcm5719-llvm-5a9d2e5a0a66a28fc322437b0146eb5b1b368087.tar.gz
bcm5719-llvm-5a9d2e5a0a66a28fc322437b0146eb5b1b368087.zip
Change AllocateRWX/DeallocateRWX to not throw an exception.
llvm-svn: 29058
Diffstat (limited to 'llvm/lib/System/Unix/Unix.h')
-rw-r--r--llvm/lib/System/Unix/Unix.h63
1 files changed, 46 insertions, 17 deletions
diff --git a/llvm/lib/System/Unix/Unix.h b/llvm/lib/System/Unix/Unix.h
index 32609f22155..4ef38963ffd 100644
--- a/llvm/lib/System/Unix/Unix.h
+++ b/llvm/lib/System/Unix/Unix.h
@@ -66,28 +66,57 @@
# define WIFEXITED(stat_val) (((stat_val) & 255) == 0)
#endif
+inline bool GetErrno(const std::string &prefix, std::string *ErrDest,
+ int errnum = -1) {
+ char buffer[MAXPATHLEN];
+
+ if (ErrDest == 0) return true;
+
+ buffer[0] = 0;
+ if (errnum == -1)
+ errnum = errno;
+#ifdef HAVE_STRERROR_R
+ // strerror_r is thread-safe.
+ if (errnum)
+ strerror_r(errnum, 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.
+ if (errnum)
+ strncpy(buffer, strerror(errnum), 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", errnum);
+#endif
+ *ErrDest = prefix + ": " + buffer;
+ return true;
+}
+
inline void ThrowErrno(const std::string& prefix, int errnum = -1) {
- char buffer[MAXPATHLEN];
- buffer[0] = 0;
- if (errnum == -1)
- errnum = errno;
+ char buffer[MAXPATHLEN];
+ buffer[0] = 0;
+ if (errnum == -1)
+ errnum = errno;
#ifdef HAVE_STRERROR_R
- // strerror_r is thread-safe.
- if (errnum)
- strerror_r(errnum,buffer,MAXPATHLEN-1);
+ // strerror_r is thread-safe.
+ if (errnum)
+ strerror_r(errnum,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.
- if (errnum)
- strncpy(buffer,strerror(errnum),MAXPATHLEN-1);
- buffer[MAXPATHLEN-1] = 0;
+ // 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.
+ if (errnum)
+ strncpy(buffer,strerror(errnum),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", errnum);
+ // Strange that this system doesn't even have strerror
+ // but, oh well, just use a generic message
+ sprintf(buffer, "Error #%d", errnum);
#endif
- throw prefix + ": " + buffer;
+ throw prefix + ": " + buffer;
}
#endif
OpenPOWER on IntegriCloud