Some libcxxrt-compatibility cleanups (avoid defining things twice).
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@151717 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -32,51 +32,54 @@ | |||||||
|   static std::unexpected_handler __unexpected_handler; |   static std::unexpected_handler __unexpected_handler; | ||||||
| #endif  // __APPLE__ | #endif  // __APPLE__ | ||||||
|  |  | ||||||
|  | namespace std | ||||||
|  | { | ||||||
|  |  | ||||||
| #if !defined(LIBCXXRT) && !defined(_LIBCPPABI_VERSION) | #if !defined(LIBCXXRT) && !defined(_LIBCPPABI_VERSION) | ||||||
|  |  | ||||||
| // libcxxrt provides implementations of these functions itself. | // libcxxrt provides implementations of these functions itself. | ||||||
| std::unexpected_handler | unexpected_handler | ||||||
| std::set_unexpected(std::unexpected_handler func) _NOEXCEPT | set_unexpected(unexpected_handler func) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_lock_test_and_set(&__unexpected_handler, func); |     return __sync_lock_test_and_set(&__unexpected_handler, func); | ||||||
| } | } | ||||||
|  |  | ||||||
| std::unexpected_handler | unexpected_handler | ||||||
| std::get_unexpected() _NOEXCEPT | get_unexpected() _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_fetch_and_add(&__unexpected_handler, (std::unexpected_handler)0); |     return __sync_fetch_and_add(&__unexpected_handler, (unexpected_handler)0); | ||||||
| } | } | ||||||
|  |  | ||||||
| _ATTRIBUTE(noreturn) | _ATTRIBUTE(noreturn) | ||||||
| void | void | ||||||
| std::unexpected() | unexpected() | ||||||
| { | { | ||||||
|     (*std::get_unexpected())(); |     (*get_unexpected())(); | ||||||
|     // unexpected handler should not return |     // unexpected handler should not return | ||||||
|     std::terminate(); |     terminate(); | ||||||
| } | } | ||||||
|  |  | ||||||
| std::terminate_handler | terminate_handler | ||||||
| std::set_terminate(std::terminate_handler func) _NOEXCEPT | set_terminate(terminate_handler func) _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_lock_test_and_set(&__terminate_handler, func); |     return __sync_lock_test_and_set(&__terminate_handler, func); | ||||||
| } | } | ||||||
|  |  | ||||||
| std::terminate_handler | terminate_handler | ||||||
| std::get_terminate() _NOEXCEPT | get_terminate() _NOEXCEPT | ||||||
| { | { | ||||||
|     return __sync_fetch_and_add(&__terminate_handler, (std::terminate_handler)0); |     return __sync_fetch_and_add(&__terminate_handler, (terminate_handler)0); | ||||||
| } | } | ||||||
|  |  | ||||||
| _ATTRIBUTE(noreturn) | _ATTRIBUTE(noreturn) | ||||||
| void | void | ||||||
| std::terminate() _NOEXCEPT | terminate() _NOEXCEPT | ||||||
| { | { | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
|     try |     try | ||||||
|     { |     { | ||||||
| #endif  // _LIBCPP_NO_EXCEPTIONS | #endif  // _LIBCPP_NO_EXCEPTIONS | ||||||
|         (*std::get_terminate())(); |         (*get_terminate())(); | ||||||
|         // handler should not return |         // handler should not return | ||||||
|         ::abort (); |         ::abort (); | ||||||
| #ifndef _LIBCPP_NO_EXCEPTIONS | #ifndef _LIBCPP_NO_EXCEPTIONS | ||||||
| @@ -90,23 +93,17 @@ std::terminate() _NOEXCEPT | |||||||
| } | } | ||||||
| #endif // !defined(LIBCXXRT) && !defined(_LIBCPPABI_VERSION) | #endif // !defined(LIBCXXRT) && !defined(_LIBCPPABI_VERSION) | ||||||
|  |  | ||||||
| bool std::uncaught_exception() _NOEXCEPT | #ifndef LIBCXXRT | ||||||
|  | bool uncaught_exception() _NOEXCEPT | ||||||
| { | { | ||||||
| #if __APPLE__ | #if __APPLE__ | ||||||
|     // on Darwin, there is a helper function so __cxa_get_globals is private |     // on Darwin, there is a helper function so __cxa_get_globals is private | ||||||
|     return __cxa_uncaught_exception(); |     return __cxa_uncaught_exception(); | ||||||
| #elif LIBCXXRT |  | ||||||
|     __cxa_eh_globals * globals = __cxa_get_globals(); |  | ||||||
|     return (globals->uncaughtExceptions != 0); |  | ||||||
| #else  // __APPLE__ |  | ||||||
|     #warning uncaught_exception not yet implemented |     #warning uncaught_exception not yet implemented | ||||||
|     ::abort(); |     ::abort(); | ||||||
| #endif  // __APPLE__ | #endif  // __APPLE__ | ||||||
| } | } | ||||||
|  |  | ||||||
| namespace std |  | ||||||
| { |  | ||||||
|  |  | ||||||
| #ifndef _LIBCPPABI_VERSION | #ifndef _LIBCPPABI_VERSION | ||||||
|  |  | ||||||
| exception::~exception() _NOEXCEPT | exception::~exception() _NOEXCEPT | ||||||
| @@ -128,6 +125,7 @@ const char* bad_exception::what() const _NOEXCEPT | |||||||
| } | } | ||||||
|  |  | ||||||
| #endif  // _LIBCPPABI_VERSION | #endif  // _LIBCPPABI_VERSION | ||||||
|  | #endif //LIBCXXRT | ||||||
|  |  | ||||||
| exception_ptr::~exception_ptr() _NOEXCEPT | exception_ptr::~exception_ptr() _NOEXCEPT | ||||||
| { | { | ||||||
| @@ -184,15 +182,14 @@ nested_exception::rethrow_nested() const | |||||||
|     rethrow_exception(__ptr_); |     rethrow_exception(__ptr_); | ||||||
| } | } | ||||||
|  |  | ||||||
| } // std |  | ||||||
|  |  | ||||||
| std::exception_ptr std::current_exception() _NOEXCEPT | exception_ptr current_exception() _NOEXCEPT | ||||||
| { | { | ||||||
| #if HAVE_DEPENDENT_EH_ABI | #if HAVE_DEPENDENT_EH_ABI | ||||||
|     // be nicer if there was a constructor that took a ptr, then |     // be nicer if there was a constructor that took a ptr, then | ||||||
|     // this whole function would be just: |     // this whole function would be just: | ||||||
|     //    return exception_ptr(__cxa_current_primary_exception()); |     //    return exception_ptr(__cxa_current_primary_exception()); | ||||||
|     std::exception_ptr ptr; |     exception_ptr ptr; | ||||||
|     ptr.__ptr_ = __cxa_current_primary_exception(); |     ptr.__ptr_ = __cxa_current_primary_exception(); | ||||||
|     return ptr; |     return ptr; | ||||||
| #else  // __APPLE__ | #else  // __APPLE__ | ||||||
| @@ -202,7 +199,7 @@ std::exception_ptr std::current_exception() _NOEXCEPT | |||||||
| } | } | ||||||
|  |  | ||||||
| _ATTRIBUTE(noreturn) | _ATTRIBUTE(noreturn) | ||||||
| void std::rethrow_exception(exception_ptr p) | void rethrow_exception(exception_ptr p) | ||||||
| { | { | ||||||
| #if HAVE_DEPENDENT_EH_ABI | #if HAVE_DEPENDENT_EH_ABI | ||||||
|     __cxa_rethrow_primary_exception(p.__ptr_); |     __cxa_rethrow_primary_exception(p.__ptr_); | ||||||
| @@ -213,3 +210,4 @@ void std::rethrow_exception(exception_ptr p) | |||||||
|     ::abort(); |     ::abort(); | ||||||
| #endif  // __APPLE__ | #endif  // __APPLE__ | ||||||
| } | } | ||||||
|  | } // std | ||||||
|   | |||||||
| @@ -24,7 +24,7 @@ | |||||||
|     static std::new_handler __new_handler; |     static std::new_handler __new_handler; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| //#ifndef _LIBCPPABI_VERSION | #if !defined (LIBCXXRT) // && !defined(_LIBCPPABI_VERSION) | ||||||
|  |  | ||||||
| // Implement all new and delete operators as weak definitions | // Implement all new and delete operators as weak definitions | ||||||
| // in this shared library, so that they can be overriden by programs | // in this shared library, so that they can be overriden by programs | ||||||
| @@ -134,7 +134,7 @@ operator delete[] (void* ptr, const std::nothrow_t&) _NOEXCEPT | |||||||
|     ::operator delete[](ptr); |     ::operator delete[](ptr); | ||||||
| } | } | ||||||
|  |  | ||||||
| //#endif  // _LIBCPPABI_VERSION | #endif  // !_LIBCPPABI_VERSION && !LIBCXXRT | ||||||
|  |  | ||||||
| namespace std | namespace std | ||||||
| { | { | ||||||
| @@ -155,6 +155,8 @@ get_new_handler() _NOEXCEPT | |||||||
|     return __sync_fetch_and_add(&__new_handler, (new_handler)0); |     return __sync_fetch_and_add(&__new_handler, (new_handler)0); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #ifndef LIBCXXRT | ||||||
|  |  | ||||||
| bad_alloc::bad_alloc() _NOEXCEPT | bad_alloc::bad_alloc() _NOEXCEPT | ||||||
| { | { | ||||||
| } | } | ||||||
| @@ -184,6 +186,7 @@ bad_array_new_length::what() const _NOEXCEPT | |||||||
| } | } | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|  | #endif //LIBCXXRT | ||||||
|  |  | ||||||
| void | void | ||||||
| __throw_bad_alloc() | __throw_bad_alloc() | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ | |||||||
|  |  | ||||||
| #include "typeinfo" | #include "typeinfo" | ||||||
|  |  | ||||||
| #ifndef _LIBCPPABI_VERSION | #if !(defined(_LIBCPPABI_VERSION) || defined(LIBCXXRT)) | ||||||
|  |  | ||||||
| std::bad_cast::bad_cast() _NOEXCEPT | std::bad_cast::bad_cast() _NOEXCEPT | ||||||
| { | { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 David Chisnall
					David Chisnall