//===----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // UNSUPPORTED: libcpp-has-no-threads // UNSUPPORTED: c++03 // // class promise // void swap(promise& other); // template void swap(promise& x, promise& y); #include #include #include "test_macros.h" #include "test_allocator.h" int main(int, char**) { assert(test_alloc_base::alloc_count == 0); { std::promise p0(std::allocator_arg, test_allocator()); std::promise p(std::allocator_arg, test_allocator()); assert(test_alloc_base::alloc_count == 2); p.swap(p0); assert(test_alloc_base::alloc_count == 2); std::future f = p.get_future(); assert(test_alloc_base::alloc_count == 2); assert(f.valid()); f = p0.get_future(); assert(f.valid()); assert(test_alloc_base::alloc_count == 2); } assert(test_alloc_base::alloc_count == 0); { std::promise p0(std::allocator_arg, test_allocator()); std::promise p(std::allocator_arg, test_allocator()); assert(test_alloc_base::alloc_count == 2); swap(p, p0); assert(test_alloc_base::alloc_count == 2); std::future f = p.get_future(); assert(test_alloc_base::alloc_count == 2); assert(f.valid()); f = p0.get_future(); assert(f.valid()); assert(test_alloc_base::alloc_count == 2); } assert(test_alloc_base::alloc_count == 0); { std::promise p0(std::allocator_arg, test_allocator()); std::promise p; assert(test_alloc_base::alloc_count == 1); p.swap(p0); assert(test_alloc_base::alloc_count == 1); std::future f = p.get_future(); assert(test_alloc_base::alloc_count == 1); assert(f.valid()); f = p0.get_future(); assert(f.valid()); assert(test_alloc_base::alloc_count == 1); } assert(test_alloc_base::alloc_count == 0); { std::promise p0(std::allocator_arg, test_allocator()); std::promise p; assert(test_alloc_base::alloc_count == 1); swap(p, p0); assert(test_alloc_base::alloc_count == 1); std::future f = p.get_future(); assert(test_alloc_base::alloc_count == 1); assert(f.valid()); f = p0.get_future(); assert(f.valid()); assert(test_alloc_base::alloc_count == 1); } assert(test_alloc_base::alloc_count == 0); return 0; }