From: Nick Lewycky Date: Fri, 19 Aug 2011 20:43:24 +0000 (+0000) Subject: Do not depend on the standard library on the system. Replace the #include with X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=1999c7c8fa8393e0986b12328b2366a18d6038ff;p=clang Do not depend on the standard library on the system. Replace the #include with the relevant section of libcxx. As an aside, I am not at all confident that this test is still testing that it's supposed to. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@138075 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/CodeGenCXX/weak-external.cpp b/test/CodeGenCXX/weak-external.cpp index f1ecc890ab..dad54f6861 100644 --- a/test/CodeGenCXX/weak-external.cpp +++ b/test/CodeGenCXX/weak-external.cpp @@ -12,7 +12,54 @@ // template, it's instantiation is *not* suppressed (despite being in // basic_string), so we would emit it as a weak definition. -#include +#define _LIBCPP_EXCEPTION_ABI __attribute__ ((__visibility__("default"))) +#define _LIBCPP_INLINE_VISIBILITY __attribute__ ((__visibility__("hidden"), __always_inline__)) +#define _LIBCPP_VISIBLE __attribute__ ((__visibility__("default"))) +#if (__has_feature(cxx_noexcept)) +# define _NOEXCEPT noexcept +# define _NOEXCEPT_(x) noexcept(x) +#else +# define _NOEXCEPT throw() +# define _NOEXCEPT_(x) +#endif + +namespace std // purposefully not using versioning namespace +{ + +template struct char_traits; +template class allocator; +template , + class _Allocator = allocator<_CharT> > + class _LIBCPP_VISIBLE basic_string; +typedef basic_string, allocator > string; + +class _LIBCPP_EXCEPTION_ABI exception +{ +public: + _LIBCPP_INLINE_VISIBILITY exception() _NOEXCEPT {} + virtual ~exception() _NOEXCEPT; + virtual const char* what() const _NOEXCEPT; +}; + +class _LIBCPP_EXCEPTION_ABI runtime_error + : public exception +{ +private: + void* __imp_; +public: + explicit runtime_error(const string&); + explicit runtime_error(const char*); + + runtime_error(const runtime_error&) _NOEXCEPT; + runtime_error& operator=(const runtime_error&) _NOEXCEPT; + + virtual ~runtime_error() _NOEXCEPT; + + virtual const char* what() const _NOEXCEPT; +}; + +} void dummysymbol() { throw(std::runtime_error("string"));