//===----------------------------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // UNSUPPORTED: libcpp-has-no-threads // UNSUPPORTED: c++98, c++03 // // class promise // promise(promise&& rhs); #include #include #include "test_macros.h" #include "test_allocator.h" int main() { assert(test_alloc_base::alloc_count == 0); { std::promise p0(std::allocator_arg, test_allocator()); std::promise p(std::move(p0)); assert(test_alloc_base::alloc_count == 1); std::future f = p.get_future(); assert(test_alloc_base::alloc_count == 1); assert(f.valid()); #ifndef TEST_HAS_NO_EXCEPTIONS try { f = p0.get_future(); assert(false); } catch (const std::future_error& e) { assert(e.code() == make_error_code(std::future_errc::no_state)); } assert(test_alloc_base::alloc_count == 1); #endif } assert(test_alloc_base::alloc_count == 0); { std::promise p0(std::allocator_arg, test_allocator()); std::promise p(std::move(p0)); assert(test_alloc_base::alloc_count == 1); std::future f = p.get_future(); assert(test_alloc_base::alloc_count == 1); assert(f.valid()); #ifndef TEST_HAS_NO_EXCEPTIONS try { f = p0.get_future(); assert(false); } catch (const std::future_error& e) { assert(e.code() == make_error_code(std::future_errc::no_state)); } assert(test_alloc_base::alloc_count == 1); #endif } assert(test_alloc_base::alloc_count == 0); { std::promise p0(std::allocator_arg, test_allocator()); std::promise p(std::move(p0)); assert(test_alloc_base::alloc_count == 1); std::future f = p.get_future(); assert(test_alloc_base::alloc_count == 1); assert(f.valid()); #ifndef TEST_HAS_NO_EXCEPTIONS try { f = p0.get_future(); assert(false); } catch (const std::future_error& e) { assert(e.code() == make_error_code(std::future_errc::no_state)); } assert(test_alloc_base::alloc_count == 1); #endif } assert(test_alloc_base::alloc_count == 0); }