111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert//===----------------------------------------------------------------------===// 211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// 311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// The LLVM Compiler Infrastructure 411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// 511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// This file is dual licensed under the MIT and the University of Illinois Open 611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// Source Licenses. See LICENSE.TXT for details. 711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// 811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert//===----------------------------------------------------------------------===// 911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert 1011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// <deque> 1111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert 1211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// deque& operator=(deque&& c) 1311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// noexcept( 1411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// allocator_type::propagate_on_container_move_assignment::value && 1511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// is_nothrow_move_assignable<allocator_type>::value); 1611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert 1711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// This tests a conforming extension 1811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert 1911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#include <deque> 2011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#include <cassert> 2111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert 2211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#include "../../../MoveOnly.h" 2311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#include "test_allocator.h" 2411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert 2511cd02dfb91661c65134cac258cf5924270e9d2Dan Alberttemplate <class T> 2611cd02dfb91661c65134cac258cf5924270e9d2Dan Albertstruct some_alloc 2711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert{ 2811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef T value_type; 2911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert some_alloc(const some_alloc&); 3011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert}; 3111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert 3211cd02dfb91661c65134cac258cf5924270e9d2Dan Albertint main() 3311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert{ 3411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#if __has_feature(cxx_noexcept) 3511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert { 3611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef std::deque<MoveOnly> C; 3711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert static_assert(std::is_nothrow_move_assignable<C>::value, ""); 3811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert } 3911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert { 4011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef std::deque<MoveOnly, test_allocator<MoveOnly>> C; 4111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert static_assert(!std::is_nothrow_move_assignable<C>::value, ""); 4211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert } 4311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert { 4411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef std::deque<MoveOnly, other_allocator<MoveOnly>> C; 4511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert static_assert(std::is_nothrow_move_assignable<C>::value, ""); 4611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert } 4711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert { 4811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef std::deque<MoveOnly, some_alloc<MoveOnly>> C; 4911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert static_assert(!std::is_nothrow_move_assignable<C>::value, ""); 5011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert } 5111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#endif 5211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert} 53