Mercurial > hg > Members > tobaru > cbc > CbC_llvm
view lib/Support/Errno.cpp @ 0:95c75e76d11b
LLVM 3.4
author | Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp> |
---|---|
date | Thu, 12 Dec 2013 13:56:28 +0900 |
parents | |
children | 60c9769439b8 |
line wrap: on
line source
//===- Errno.cpp - errno support --------------------------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This file implements the errno wrappers. // //===----------------------------------------------------------------------===// #include "llvm/Support/Errno.h" #include "llvm/Config/config.h" // Get autoconf configuration settings #include "llvm/Support/raw_ostream.h" #include <string.h> #if HAVE_ERRNO_H #include <errno.h> #endif //===----------------------------------------------------------------------===// //=== WARNING: Implementation here must contain only TRULY operating system //=== independent code. //===----------------------------------------------------------------------===// namespace llvm { namespace sys { #if HAVE_ERRNO_H std::string StrError() { return StrError(errno); } #endif // HAVE_ERRNO_H std::string StrError(int errnum) { const int MaxErrStrLen = 2000; char buffer[MaxErrStrLen]; buffer[0] = '\0'; std::string str; if (errnum == 0) return str; #ifdef HAVE_STRERROR_R // strerror_r is thread-safe. #if defined(__GLIBC__) && defined(_GNU_SOURCE) // glibc defines its own incompatible version of strerror_r // which may not use the buffer supplied. str = strerror_r(errnum, buffer, MaxErrStrLen - 1); #else strerror_r(errnum, buffer, MaxErrStrLen - 1); str = buffer; #endif #elif HAVE_DECL_STRERROR_S // "Windows Secure API" strerror_s(buffer, MaxErrStrLen - 1, errnum); str = buffer; #elif defined(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. str = strerror(errnum); #else // Strange that this system doesn't even have strerror // but, oh well, just use a generic message raw_string_ostream stream(str); stream << "Error #" << errnum; stream.flush(); #endif return str; } } // namespace sys } // namespace llvm