insert_iter_rvalue.pass.cpp revision 06086258d3d8c48a916ec51c33e1ad8f46821b81
1//===----------------------------------------------------------------------===// 2// 3// The LLVM Compiler Infrastructure 4// 5// This file is dual licensed under the MIT and the University of Illinois Open 6// Source Licenses. See LICENSE.TXT for details. 7// 8//===----------------------------------------------------------------------===// 9 10// <list> 11 12// iterator insert(const_iterator position, value_type&& x); 13 14#if _LIBCPP_DEBUG >= 1 15#define _LIBCPP_ASSERT(x, m) ((x) ? (void)0 : std::exit(0)) 16#endif 17 18#include <list> 19#include <cassert> 20 21#include "../../../MoveOnly.h" 22#include "min_allocator.h" 23 24int main() 25{ 26#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 27 { 28 std::list<MoveOnly> l1; 29 l1.insert(l1.cend(), MoveOnly(1)); 30 assert(l1.size() == 1); 31 assert(l1.front() == MoveOnly(1)); 32 l1.insert(l1.cbegin(), MoveOnly(2)); 33 assert(l1.size() == 2); 34 assert(l1.front() == MoveOnly(2)); 35 assert(l1.back() == MoveOnly(1)); 36 } 37#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 38#if _LIBCPP_DEBUG >= 1 39 { 40 std::list<int> v1(3); 41 std::list<int> v2(3); 42 v1.insert(v2.begin(), 4); 43 assert(false); 44 } 45#endif 46#if __cplusplus >= 201103L 47#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 48 { 49 std::list<MoveOnly, min_allocator<MoveOnly>> l1; 50 l1.insert(l1.cend(), MoveOnly(1)); 51 assert(l1.size() == 1); 52 assert(l1.front() == MoveOnly(1)); 53 l1.insert(l1.cbegin(), MoveOnly(2)); 54 assert(l1.size() == 2); 55 assert(l1.front() == MoveOnly(2)); 56 assert(l1.back() == MoveOnly(1)); 57 } 58#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 59#if _LIBCPP_DEBUG >= 1 60 { 61 std::list<int, min_allocator<int>> v1(3); 62 std::list<int, min_allocator<int>> v2(3); 63 v1.insert(v2.begin(), 4); 64 assert(false); 65 } 66#endif 67#endif 68} 69