//===- llvm/Support/Unix/Unix.h - Common Unix Include File -------*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This file defines things specific to Unix implementations. // //===----------------------------------------------------------------------===// #ifndef LLVM_LIB_SUPPORT_UNIX_UNIX_H #define LLVM_LIB_SUPPORT_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" #include "llvm/Support/Chrono.h" #include "llvm/Support/Errno.h" #include "llvm/Support/ErrorHandling.h" #include <algorithm> #include <assert.h> #include <cerrno> #include <cstdio> #include <cstdlib> #include <cstring> #include <string> #include <sys/types.h> #include <sys/wait.h> #ifdef HAVE_UNISTD_H #include <unistd.h> #endif #ifdef HAVE_SYS_TIME_H # include <sys/time.h> #endif #include <time.h> #ifdef HAVE_DLFCN_H # include <dlfcn.h> #endif #ifdef HAVE_FCNTL_H # include <fcntl.h> #endif /// This function builds an error message into \p ErrMsg using the \p prefix /// string and the Unix error number given by \p errnum. If errnum is -1, the /// default then the value of errno is used. /// Make an error message /// /// If the error number can be converted to a string, it will be /// separated from prefix by ": ". static inline bool MakeErrMsg( std::string* ErrMsg, const std::string& prefix, int errnum = -1) { … } // Include StrError(errnum) in a fatal error message. [[noreturn]] static inline void ReportErrnumFatal(const char *Msg, int errnum) { … } namespace llvm { namespace sys { /// Convert a struct timeval to a duration. Note that timeval can be used both /// as a time point and a duration. Be sure to check what the input represents. inline std::chrono::microseconds toDuration(const struct timeval &TV) { … } /// Convert a time point to struct timespec. inline struct timespec toTimeSpec(TimePoint<> TP) { … } /// Convert a time point to struct timeval. inline struct timeval toTimeVal(TimePoint<std::chrono::microseconds> TP) { … } } // namespace sys } // namespace llvm #endif