From a76dfbd4288271d3a61fe2f4307c406780ce7c49 Mon Sep 17 00:00:00 2001 From: Dan Albert Date: Tue, 6 Jan 2015 17:34:51 +0000 Subject: [PATCH] [libcxx] Set _LIBCPP_ELAST for mingw. Reviewers: K-ballo, mclow.lists, EricWF Reviewed By: EricWF Subscribers: jfb, jroelofs, majnemer, cfe-commits Differential Revision: http://reviews.llvm.org/D6558 llvm-svn: 225273 --- libcxx/include/__config | 16 ---------------- libcxx/src/config_elast.h | 36 ++++++++++++++++++++++++++++++++++++ libcxx/src/ios.cpp | 14 +++++++++----- libcxx/src/system_error.cpp | 7 +++++-- 4 files changed, 50 insertions(+), 23 deletions(-) create mode 100644 libcxx/src/config_elast.h diff --git a/libcxx/include/__config b/libcxx/include/__config index 8fd80bc..00ade4e 100644 --- a/libcxx/include/__config +++ b/libcxx/include/__config @@ -21,7 +21,6 @@ #if !_WIN32 #include -#include // for ELAST on FreeBSD #endif #define _LIBCPP_VERSION 1101 @@ -643,21 +642,6 @@ template struct __static_assert_check {}; #define _LIBCPP_WCTYPE_IS_MASK #endif -#if defined(ELAST) -#define _LIBCPP_ELAST ELAST -#elif defined(__linux__) -#define _LIBCPP_ELAST 4095 -#elif defined(_NEWLIB_VERSION) -#define _LIBCPP_ELAST __ELASTERROR -#elif defined(__APPLE__) -// Not _LIBCPP_ELAST needed on Apple -#elif defined(__sun__) -#define _LIBCPP_ELAST ESTALE -#else -// Warn here so that the person doing the libcxx port has an easier time: -#warning This platform's ELAST hasn't been ported yet -#endif - #ifndef _LIBCPP_TRIVIAL_PAIR_COPY_CTOR # define _LIBCPP_TRIVIAL_PAIR_COPY_CTOR 1 #endif diff --git a/libcxx/src/config_elast.h b/libcxx/src/config_elast.h new file mode 100644 index 0000000..08d0103 --- /dev/null +++ b/libcxx/src/config_elast.h @@ -0,0 +1,36 @@ +//===----------------------- config_elast.h -------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#ifndef _LIBCPP_CONFIG_ELAST +#define _LIBCPP_CONFIG_ELAST + +#if defined(_WIN32) +#include +#else +#include +#endif + +#if defined(ELAST) +#define _LIBCPP_ELAST ELAST +#elif defined(_NEWLIB_VERSION) +#define _LIBCPP_ELAST __ELASTERROR +#elif defined(__linux__) +#define _LIBCPP_ELAST 4095 +#elif defined(__APPLE__) +// No _LIBCPP_ELAST needed on Apple +#elif defined(__sun__) +#define _LIBCPP_ELAST ESTALE +#elif defined(_WIN32) +#define _LIBCPP_ELAST _sys_nerr +#else +// Warn here so that the person doing the libcxx port has an easier time: +#warning This platform's ELAST hasn't been ported yet +#endif + +#endif // _LIBCPP_CONFIG_ELAST diff --git a/libcxx/src/ios.cpp b/libcxx/src/ios.cpp index d879beb..90972c4 100644 --- a/libcxx/src/ios.cpp +++ b/libcxx/src/ios.cpp @@ -8,16 +8,20 @@ //===----------------------------------------------------------------------===// #include "__config" + #include "ios" -#include "streambuf" -#include "istream" -#include "string" + +#include + #include "__locale" #include "algorithm" +#include "config_elast.h" +#include "istream" +#include "limits" #include "memory" #include "new" -#include "limits" -#include +#include "streambuf" +#include "string" _LIBCPP_BEGIN_NAMESPACE_STD diff --git a/libcxx/src/system_error.cpp b/libcxx/src/system_error.cpp index 9c8adc4..c032fc0 100644 --- a/libcxx/src/system_error.cpp +++ b/libcxx/src/system_error.cpp @@ -7,11 +7,14 @@ // //===----------------------------------------------------------------------===// -#define _LIBCPP_BUILDING_SYSTEM_ERROR #include "__config" + +#define _LIBCPP_BUILDING_SYSTEM_ERROR #include "system_error" -#include "string" + +#include "config_elast.h" #include "cstring" +#include "string" _LIBCPP_BEGIN_NAMESPACE_STD -- 2.7.4