blob: 1ce1838afbb7e2e6ee445a49a1d4d3e3f50308cb [file] [log] [blame]
Howard Hinnantc52f43e2010-08-22 00:59:46 +00001//===----------------------------------------------------------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
Howard Hinnantb64f8b02010-11-16 22:09:02 +00005// This file is dual licensed under the MIT and the University of Illinois Open
6// Source Licenses. See LICENSE.TXT for details.
Howard Hinnantc52f43e2010-08-22 00:59:46 +00007//
8//===----------------------------------------------------------------------===//
9
10// <memory>
11
12// unique_ptr
13
Dan Albert1d4a1ed2016-05-25 22:36:09 -070014// Test unique_ptr(pointer) ctor
Howard Hinnantc52f43e2010-08-22 00:59:46 +000015
16#include <memory>
Marshall Clow6b913d72015-01-09 20:25:52 +000017#include <utility>
Howard Hinnantc52f43e2010-08-22 00:59:46 +000018#include <cassert>
19
Dan Albert1d4a1ed2016-05-25 22:36:09 -070020// template <class U> explicit unique_ptr(auto_ptr<U>&);
Howard Hinnantc52f43e2010-08-22 00:59:46 +000021
22struct A
23{
24 static int count;
25 A() {++count;}
26 A(const A&) {++count;}
27 virtual ~A() {--count;}
28};
29
30int A::count = 0;
31
32struct B
33 : public A
34{
35 static int count;
36 B() {++count;}
37 B(const B&) {++count;}
38 virtual ~B() {--count;}
39};
40
41int B::count = 0;
42
43int main()
44{
45 {
46 B* p = new B;
47 std::auto_ptr<B> ap(p);
48 std::unique_ptr<A> up(std::move(ap));
49 assert(up.get() == p);
50 assert(ap.get() == 0);
51 assert(A::count == 1);
52 assert(B::count == 1);
53 }
54 assert(A::count == 0);
55 assert(B::count == 0);
56 {
57 B* p = new B;
58 std::auto_ptr<B> ap(p);
59 std::unique_ptr<A> up;
60 up = std::move(ap);
61 assert(up.get() == p);
62 assert(ap.get() == 0);
63 assert(A::count == 1);
64 assert(B::count == 1);
65 }
66 assert(A::count == 0);
67 assert(B::count == 0);
68}