c38c652aeceead4d5ea330531b12728ef7687171
[oota-llvm.git] / lib / System / Unix / Unix.h
1 //===- llvm/System/Unix/Unix.h - Common Unix Include File -------*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file was developed by Reid Spencer and is distributed under the
6 // University of Illinois Open Source License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file defines things specific to Unix implementations.
11 //
12 //===----------------------------------------------------------------------===//
13
14 #ifndef LLVM_SYSTEM_UNIX_UNIX_H
15 #define LLVM_SYSTEM_UNIX_UNIX_H
16
17 //===----------------------------------------------------------------------===//
18 //=== WARNING: Implementation here must contain only generic UNIX code that
19 //===          is guaranteed to work on all UNIX variants.
20 //===----------------------------------------------------------------------===//
21
22 #include "llvm/Config/config.h"     // Get autoconf configuration settings
23 #include <cstdlib>
24 #include <cstdio>
25 #include <cstring>
26 #include <cerrno>
27 #include <string>
28 #include <algorithm>
29
30 #ifdef HAVE_UNISTD_H
31 #include <unistd.h>
32 #endif
33
34 #ifdef HAVE_SYS_TYPES_H
35 #include <sys/types.h>
36 #endif
37
38 #ifdef HAVE_SYS_PARAM_H
39 #include <sys/param.h>
40 #endif
41
42 #ifdef HAVE_ASSERT_H
43 #include <assert.h>
44 #endif
45
46 #ifdef TIME_WITH_SYS_TIME
47 # include <sys/time.h>
48 # include <time.h>
49 #else
50 # ifdef HAVE_SYS_TIME_H
51 #  include <sys/time.h>
52 # else
53 #  include <time.h>
54 # endif
55 #endif
56
57 #ifdef HAVE_SYS_WAIT_H
58 # include <sys/wait.h>
59 #endif
60
61 #ifndef WEXITSTATUS
62 # define WEXITSTATUS(stat_val) ((unsigned)(stat_val) >> 8)
63 #endif
64
65 #ifndef WIFEXITED
66 # define WIFEXITED(stat_val) (((stat_val) & 255) == 0)
67 #endif
68
69 /// This function builds an error message into \p ErrMsg using the \p prefix
70 /// string and the Unix error number given by \p errnum. If errnum is -1, the
71 /// default then the value of errno is used.
72 /// @brief Make an error message
73 inline bool MakeErrMsg(
74   std::string* ErrMsg, const std::string& prefix, int errnum = -1) {
75   if (!ErrMsg)
76     return true;
77   char buffer[MAXPATHLEN];
78   buffer[0] = 0;
79   if (errnum == -1)
80     errnum = errno;
81 #ifdef HAVE_STRERROR_R
82   // strerror_r is thread-safe.
83   if (errnum)
84     strerror_r(errnum,buffer,MAXPATHLEN-1);
85 #elif HAVE_STRERROR
86   // Copy the thread un-safe result of strerror into
87   // the buffer as fast as possible to minimize impact
88   // of collision of strerror in multiple threads.
89   if (errnum)
90     strncpy(buffer,strerror(errnum),MAXPATHLEN-1);
91   buffer[MAXPATHLEN-1] = 0;
92 #else
93   // Strange that this system doesn't even have strerror
94   // but, oh well, just use a generic message
95   sprintf(buffer, "Error #%d", errnum);
96 #endif
97   *ErrMsg = prefix + buffer;
98   return true;
99 }
100
101 #endif