From ae0984b4b17e6bda2231da23c190033df369e5c0 Mon Sep 17 00:00:00 2001 From: Jeffrey Walton Date: Wed, 29 Jul 2015 13:37:52 -0400 Subject: Cleaned up tests for OS X, TR1 names spaces and ancient versus modern libstdc++ and libc++. Thanks to Jonathan Wakely for devising the clever test --- smartptr.h | 36 ++++++++++++++++++------------------ 1 file changed, 18 insertions(+), 18 deletions(-) (limited to 'smartptr.h') diff --git a/smartptr.h b/smartptr.h index 3ddfc9a9..30d996fa 100644 --- a/smartptr.h +++ b/smartptr.h @@ -7,26 +7,26 @@ NAMESPACE_BEGIN(CryptoPP) -#if 0 -// This must be kept in sync with stdcpp.h because is included based on the same logic. -#if ((__cplusplus >= 201103L) || (_MSC_VER >= 1600)) && !defined(__clang__) -# include - template - using auto_ptr = std::unique_ptr; -#elif defined(__clang__) -# if (__has_include()) -# include - using std::auto_ptr; -# endif -#elif (__cplusplus < 201103L) -# include - using std::auto_ptr; +// Hack ahead. Apple's standard library does not have C++'s unique_ptr. We can't test +// for unique_ptr directly because some of the Clangs on Apple fail the same way. +// However, modern standard libraries have , so we test for it instead. +// Thanks to Jonathan Wakely for devising the clever test for modern/ancient versions. + +#if (__cplusplus >= 201103L) || (_MSC_VER >= 1600) +# if defined(__clang__) && (__has_include()) +# define CRYPTOPP_HAVE_UNIQUE_PTR 1 +# else +# define CRYPTOPP_HAVE_UNIQUE_PTR 1 +# endif +#endif + +#ifdef CRYPTOPP_HAVE_UNIQUE_PTR +// use unique_ptr instead of auto_ptr +template + using std::auto_ptr = std::unique_ptr; #else -# include - template - using auto_ptr = std::unique_ptr; +// do nothing; use auto_ptr #endif -#endif // 0 template class simple_ptr { -- cgit v1.2.1