swap.pass.cpp revision f5256e16dfc425c1d466f6308d4026d529ce9e0b
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// <memory> 11 12// unique_ptr 13 14// test swap 15 16#include <memory> 17#include <cassert> 18 19#include "../../deleter.h" 20 21struct A 22{ 23 int state_; 24 static int count; 25 A() : state_(0) {++count;} 26 explicit A(int i) : state_(i) {++count;} 27 A(const A& a) : state_(a.state_) {++count;} 28 A& operator=(const A& a) {state_ = a.state_; return *this;} 29 ~A() {--count;} 30 31 friend bool operator==(const A& x, const A& y) 32 {return x.state_ == y.state_;} 33}; 34 35int A::count = 0; 36 37int main() 38{ 39 { 40 A* p1 = new A[3]; 41 std::unique_ptr<A[], Deleter<A[]> > s1(p1, Deleter<A[]>(1)); 42 A* p2 = new A[3]; 43 std::unique_ptr<A[], Deleter<A[]> > s2(p2, Deleter<A[]>(2)); 44 assert(s1.get() == p1); 45 assert(s1.get_deleter().state() == 1); 46 assert(s2.get() == p2); 47 assert(s2.get_deleter().state() == 2); 48 s1.swap(s2); 49 assert(s1.get() == p2); 50 assert(s1.get_deleter().state() == 2); 51 assert(s2.get() == p1); 52 assert(s2.get_deleter().state() == 1); 53 assert(A::count == 6); 54 } 55 assert(A::count == 0); 56} 57