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