insert_iter_rv.pass.cpp revision 6046aced820aaab4f14f2026531dd11d10690691
1//===----------------------------------------------------------------------===// 2// 3// The LLVM Compiler Infrastructure 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 8//===----------------------------------------------------------------------===// 9 10// <map> 11 12// class multimap 13 14// template <class P> 15// iterator insert(const_iterator position, P&& p); 16 17#include <map> 18#include <cassert> 19 20#include "../../../MoveOnly.h" 21 22int main() 23{ 24#ifdef _LIBCPP_MOVE 25 { 26 typedef std::multimap<int, MoveOnly> M; 27 typedef std::pair<int, MoveOnly> P; 28 typedef M::iterator R; 29 M m; 30 R r = m.insert(m.cend(), P(2, 2)); 31 assert(r == m.begin()); 32 assert(m.size() == 1); 33 assert(r->first == 2); 34 assert(r->second == 2); 35 36 r = m.insert(m.cend(), P(1, 1)); 37 assert(r == m.begin()); 38 assert(m.size() == 2); 39 assert(r->first == 1); 40 assert(r->second == 1); 41 42 r = m.insert(m.cend(), P(3, 3)); 43 assert(r == prev(m.end())); 44 assert(m.size() == 3); 45 assert(r->first == 3); 46 assert(r->second == 3); 47 48 r = m.insert(m.cend(), P(3, 2)); 49 assert(r == prev(m.end())); 50 assert(m.size() == 4); 51 assert(r->first == 3); 52 assert(r->second == 2); 53 } 54#endif // _LIBCPP_MOVE 55} 56