/* Copyright 2019 Glen Joseph Fernandes (glenjofe@gmail.com) Distributed under the Boost Software License, Version 1.0. (http://www.boost.org/LICENSE_1_0.txt) */ #include #if (!defined(BOOST_LIBSTDCXX_VERSION) || \ BOOST_LIBSTDCXX_VERSION >= 46000) && \ !defined(BOOST_NO_CXX11_SMART_PTR) #include #include template struct creator { typedef T value_type; typedef T* pointer; template struct rebind { typedef creator other; }; creator() { } template creator(const creator&) { } T* allocate(std::size_t size) { return static_cast(::operator new(sizeof(T) * size)); } void deallocate(T* ptr, std::size_t) { ::operator delete(ptr); } }; template inline bool operator==(const creator&, const creator&) { return true; } template inline bool operator!=(const creator&, const creator&) { return false; } class type { public: static unsigned instances; type() { if (instances == 0) { throw true; } ++instances; } ~type() { --instances; } private: type(const type&); type& operator=(const type&); }; unsigned type::instances = 0; int main() { try { boost::allocate_unique(creator()); BOOST_ERROR("allocate_unique did not throw"); } catch (...) { BOOST_TEST(type::instances == 0); } try { boost::allocate_unique(creator<>()); BOOST_ERROR("allocate_unique did not throw"); } catch (...) { BOOST_TEST(type::instances == 0); } return boost::report_errors(); } #else int main() { return 0; } #endif