// // atomic_sp_constexpr_test.cpp // // Copyright 2017, 2018 Peter Dimov // // Distributed under the Boost Software License, Version 1.0. // See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt // #include #include #include #include #if defined( BOOST_NO_CXX11_CONSTEXPR ) BOOST_PRAGMA_MESSAGE("Skipping test due to BOOST_NO_CXX11_CONSTEXPR") int main() {} #elif BOOST_WORKAROUND( BOOST_MSVC, < 1930 ) // MSVC does not implement static initialization for constexpr constructors BOOST_PRAGMA_MESSAGE("Skipping test due to BOOST_MSVC < 1930") int main() {} #elif defined(__clang__) && defined( BOOST_NO_CXX14_CONSTEXPR ) // Clang only implements static initialization for constexpr in C++14 mode BOOST_PRAGMA_MESSAGE("Skipping test due to __clang__ and BOOST_NO_CXX14_CONSTEXPR") int main() {} #elif defined( _LIBCPP_VERSION ) && ( _LIBCPP_VERSION < 6000 ) // in libc++, atomic_flag has a non-constexpr constructor from bool BOOST_PRAGMA_MESSAGE("Skipping test due to _LIBCPP_VERSION " BOOST_STRINGIZE(_LIBCPP_VERSION)) int main() {} #elif defined( BOOST_NO_CXX11_UNIFIED_INITIALIZATION_SYNTAX ) BOOST_PRAGMA_MESSAGE("Skipping test due to BOOST_NO_CXX11_UNIFIED_INITIALIZATION_SYNTAX") int main() {} #else #include #include struct X { }; struct Z { Z(); }; static Z z; static boost::atomic_shared_ptr p1; Z::Z() { p1 = boost::shared_ptr( new X ); } int main() { boost::shared_ptr p2 = p1; BOOST_TEST( p2.get() != 0 ); BOOST_TEST_EQ( p2.use_count(), 2 ); return boost::report_errors(); } #endif