//===----------------------------------------------------------------------===// // // 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: c++03 // // void swap(multimap& c) // noexcept(!allocator_type::propagate_on_container_swap::value || // __is_nothrow_swappable::value); // // In C++17, the standard says that swap shall have: // noexcept(allocator_traits::is_always_equal::value && // noexcept(swap(declval(), declval()))); // This tests a conforming extension #include #include #include #include "test_macros.h" #include "MoveOnly.h" #include "test_allocator.h" template struct some_comp { typedef T value_type; some_comp() {} some_comp(const some_comp&) {} bool operator()(const T&, const T&) const { return false; } }; template struct some_comp2 { typedef T value_type; some_comp2() {} some_comp2(const some_comp2&) {} bool operator()(const T&, const T&) const { return false; } }; #if TEST_STD_VER >= 14 template void swap(some_comp2&, some_comp2&) noexcept {} #endif template struct some_alloc { typedef T value_type; some_alloc() {} some_alloc(const some_alloc&); void deallocate(void*, unsigned) {} typedef std::true_type propagate_on_container_swap; }; template struct some_alloc2 { typedef T value_type; some_alloc2() {} some_alloc2(const some_alloc2&); void deallocate(void*, unsigned) {} typedef std::false_type propagate_on_container_swap; typedef std::true_type is_always_equal; }; template struct some_alloc3 { typedef T value_type; some_alloc3() {} some_alloc3(const some_alloc3&); void deallocate(void*, unsigned) {} typedef std::false_type propagate_on_container_swap; typedef std::false_type is_always_equal; }; int main(int, char**) { typedef std::pair V; { typedef std::multimap C; static_assert(noexcept(swap(std::declval(), std::declval())), ""); } #if defined(_LIBCPP_VERSION) { typedef std::multimap, test_allocator> C; static_assert(noexcept(swap(std::declval(), std::declval())), ""); } { typedef std::multimap, other_allocator> C; static_assert(noexcept(swap(std::declval(), std::declval())), ""); } #endif // _LIBCPP_VERSION { typedef std::multimap> C; static_assert(!noexcept(swap(std::declval(), std::declval())), ""); } #if TEST_STD_VER >= 14 { // POCS allocator, throwable swap for comp typedef std::multimap, some_alloc > C; static_assert(!noexcept(swap(std::declval(), std::declval())), ""); } { // always equal allocator, throwable swap for comp typedef std::multimap, some_alloc2> C; static_assert(!noexcept(swap(std::declval(), std::declval())), ""); } { // POCS allocator, nothrow swap for comp typedef std::multimap, some_alloc > C; static_assert( noexcept(swap(std::declval(), std::declval())), ""); } { // always equal allocator, nothrow swap for comp typedef std::multimap, some_alloc2> C; static_assert( noexcept(swap(std::declval(), std::declval())), ""); } #if defined(_LIBCPP_VERSION) { // NOT always equal allocator, nothrow swap for comp typedef std::multimap, some_alloc3> C; static_assert( noexcept(swap(std::declval(), std::declval())), ""); } #endif // _LIBCPP_VERSION #endif return 0; }