blob: 6d9c30597789365a6fd539b4c2ab3c2eb2d3e14a [file] [log] [blame]
Chris Lattner71430722007-12-20 19:14:02 +00001//===- llvm/ADT/OwningPtr.h - Smart ptr that owns the pointee ---*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner7ed47a12007-12-29 19:59:42 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Chris Lattner71430722007-12-20 19:14:02 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This file defines and implements the OwningPtr class.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_ADT_OWNING_PTR_H
15#define LLVM_ADT_OWNING_PTR_H
16
17#include <cassert>
Eli Friedmanfaa99952008-02-25 23:35:32 +000018#include <cstddef>
Chris Lattner71430722007-12-20 19:14:02 +000019
20namespace llvm {
21
22/// OwningPtr smart pointer - OwningPtr mimics a built-in pointer except that it
23/// guarantees deletion of the object pointed to, either on destruction of the
24/// OwningPtr or via an explicit reset(). Once created, ownership of the
25/// pointee object can be taken away from OwningPtr by using the take method.
Misha Brukman3a54b3d2009-01-09 19:25:42 +000026template<class T>
Chris Lattner71430722007-12-20 19:14:02 +000027class OwningPtr {
Chris Lattner0adabe52012-01-23 15:10:41 +000028 OwningPtr(OwningPtr const &); // DO NOT IMPLEMENT
29 OwningPtr &operator=(OwningPtr const &); // DO NOT IMPLEMENT
Chris Lattner71430722007-12-20 19:14:02 +000030 T *Ptr;
31public:
32 explicit OwningPtr(T *P = 0) : Ptr(P) {}
33
34 ~OwningPtr() {
35 delete Ptr;
36 }
37
38 /// reset - Change the current pointee to the specified pointer. Note that
39 /// calling this with any pointer (including a null pointer) deletes the
40 /// current pointer.
Misha Brukman3a54b3d2009-01-09 19:25:42 +000041 void reset(T *P = 0) {
Chris Lattner71430722007-12-20 19:14:02 +000042 if (P == Ptr) return;
43 T *Tmp = Ptr;
44 Ptr = P;
45 delete Tmp;
46 }
47
48 /// take - Reset the owning pointer to null and return its pointer. This does
49 /// not delete the pointer before returning it.
Misha Brukman3a54b3d2009-01-09 19:25:42 +000050 T *take() {
Chris Lattner71430722007-12-20 19:14:02 +000051 T *Tmp = Ptr;
52 Ptr = 0;
53 return Tmp;
54 }
Misha Brukman3a54b3d2009-01-09 19:25:42 +000055
Chris Lattner71430722007-12-20 19:14:02 +000056 T &operator*() const {
57 assert(Ptr && "Cannot dereference null pointer");
58 return *Ptr;
59 }
60
61 T *operator->() const { return Ptr; }
62 T *get() const { return Ptr; }
63 operator bool() const { return Ptr != 0; }
64 bool operator!() const { return Ptr == 0; }
65
66 void swap(OwningPtr &RHS) {
67 T *Tmp = RHS.Ptr;
68 RHS.Ptr = Ptr;
69 Ptr = Tmp;
70 }
71};
72
73template<class T>
74inline void swap(OwningPtr<T> &a, OwningPtr<T> &b) {
75 a.swap(b);
76}
77
Ted Kremenek3a818a32007-12-20 19:53:47 +000078/// OwningArrayPtr smart pointer - OwningArrayPtr provides the same
79/// functionality as OwningPtr, except that it works for array types.
Misha Brukman3a54b3d2009-01-09 19:25:42 +000080template<class T>
Ted Kremenek3a818a32007-12-20 19:53:47 +000081class OwningArrayPtr {
82 OwningArrayPtr(OwningArrayPtr const &); // DO NOT IMPLEMENT
83 OwningArrayPtr &operator=(OwningArrayPtr const &); // DO NOT IMPLEMENT
84 T *Ptr;
85public:
86 explicit OwningArrayPtr(T *P = 0) : Ptr(P) {}
87
88 ~OwningArrayPtr() {
89 delete [] Ptr;
90 }
91
92 /// reset - Change the current pointee to the specified pointer. Note that
93 /// calling this with any pointer (including a null pointer) deletes the
94 /// current pointer.
Misha Brukman3a54b3d2009-01-09 19:25:42 +000095 void reset(T *P = 0) {
Ted Kremenek3a818a32007-12-20 19:53:47 +000096 if (P == Ptr) return;
97 T *Tmp = Ptr;
98 Ptr = P;
Ted Kremenek4cd31452008-12-08 17:28:11 +000099 delete [] Tmp;
Ted Kremenek3a818a32007-12-20 19:53:47 +0000100 }
101
102 /// take - Reset the owning pointer to null and return its pointer. This does
103 /// not delete the pointer before returning it.
Misha Brukman3a54b3d2009-01-09 19:25:42 +0000104 T *take() {
Ted Kremenek3a818a32007-12-20 19:53:47 +0000105 T *Tmp = Ptr;
106 Ptr = 0;
107 return Tmp;
108 }
Misha Brukman3a54b3d2009-01-09 19:25:42 +0000109
Ted Kremenek3a818a32007-12-20 19:53:47 +0000110 T &operator[](std::ptrdiff_t i) const {
111 assert(Ptr && "Cannot dereference null pointer");
112 return Ptr[i];
113 }
Misha Brukman3a54b3d2009-01-09 19:25:42 +0000114
Ted Kremenek3a818a32007-12-20 19:53:47 +0000115 T *get() const { return Ptr; }
116 operator bool() const { return Ptr != 0; }
117 bool operator!() const { return Ptr == 0; }
118
119 void swap(OwningArrayPtr &RHS) {
120 T *Tmp = RHS.Ptr;
121 RHS.Ptr = Ptr;
122 Ptr = Tmp;
123 }
124};
125
126template<class T>
127inline void swap(OwningArrayPtr<T> &a, OwningArrayPtr<T> &b) {
128 a.swap(b);
129}
130
Chris Lattner71430722007-12-20 19:14:02 +0000131} // end namespace llvm
132
133#endif