| //===- llvm/ADT/OwningPtr.h - Smart ptr that owns the pointee ---*- C++ -*-===// |
| // |
| // The LLVM Compiler Infrastructure |
| // |
| // This file is distributed under the University of Illinois Open Source |
| // License. See LICENSE.TXT for details. |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // This file defines and implements the OwningPtr class. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef LLVM_ADT_OWNING_PTR_H |
| #define LLVM_ADT_OWNING_PTR_H |
| |
| #include <cassert> |
| #include <cstddef> |
| |
| namespace llvm { |
| |
| /// OwningPtr smart pointer - OwningPtr mimics a built-in pointer except that it |
| /// guarantees deletion of the object pointed to, either on destruction of the |
| /// OwningPtr or via an explicit reset(). Once created, ownership of the |
| /// pointee object can be taken away from OwningPtr by using the take method. |
| template<class T> |
| class OwningPtr { |
| OwningPtr(OwningPtr const &); // DO NOT IMPLEMENT |
| OwningPtr &operator=(OwningPtr const &); // DO NOT IMPLEMENT |
| T *Ptr; |
| public: |
| explicit OwningPtr(T *P = 0) : Ptr(P) {} |
| |
| ~OwningPtr() { |
| delete Ptr; |
| } |
| |
| /// reset - Change the current pointee to the specified pointer. Note that |
| /// calling this with any pointer (including a null pointer) deletes the |
| /// current pointer. |
| void reset(T *P = 0) { |
| if (P == Ptr) return; |
| T *Tmp = Ptr; |
| Ptr = P; |
| delete Tmp; |
| } |
| |
| /// take - Reset the owning pointer to null and return its pointer. This does |
| /// not delete the pointer before returning it. |
| T *take() { |
| T *Tmp = Ptr; |
| Ptr = 0; |
| return Tmp; |
| } |
| |
| T &operator*() const { |
| assert(Ptr && "Cannot dereference null pointer"); |
| return *Ptr; |
| } |
| |
| T *operator->() const { return Ptr; } |
| T *get() const { return Ptr; } |
| operator bool() const { return Ptr != 0; } |
| bool operator!() const { return Ptr == 0; } |
| |
| void swap(OwningPtr &RHS) { |
| T *Tmp = RHS.Ptr; |
| RHS.Ptr = Ptr; |
| Ptr = Tmp; |
| } |
| }; |
| |
| template<class T> |
| inline void swap(OwningPtr<T> &a, OwningPtr<T> &b) { |
| a.swap(b); |
| } |
| |
| /// OwningArrayPtr smart pointer - OwningArrayPtr provides the same |
| /// functionality as OwningPtr, except that it works for array types. |
| template<class T> |
| class OwningArrayPtr { |
| OwningArrayPtr(OwningArrayPtr const &); // DO NOT IMPLEMENT |
| OwningArrayPtr &operator=(OwningArrayPtr const &); // DO NOT IMPLEMENT |
| T *Ptr; |
| public: |
| explicit OwningArrayPtr(T *P = 0) : Ptr(P) {} |
| |
| ~OwningArrayPtr() { |
| delete [] Ptr; |
| } |
| |
| /// reset - Change the current pointee to the specified pointer. Note that |
| /// calling this with any pointer (including a null pointer) deletes the |
| /// current pointer. |
| void reset(T *P = 0) { |
| if (P == Ptr) return; |
| T *Tmp = Ptr; |
| Ptr = P; |
| delete [] Tmp; |
| } |
| |
| /// take - Reset the owning pointer to null and return its pointer. This does |
| /// not delete the pointer before returning it. |
| T *take() { |
| T *Tmp = Ptr; |
| Ptr = 0; |
| return Tmp; |
| } |
| |
| T &operator[](std::ptrdiff_t i) const { |
| assert(Ptr && "Cannot dereference null pointer"); |
| return Ptr[i]; |
| } |
| |
| T *get() const { return Ptr; } |
| operator bool() const { return Ptr != 0; } |
| bool operator!() const { return Ptr == 0; } |
| |
| void swap(OwningArrayPtr &RHS) { |
| T *Tmp = RHS.Ptr; |
| RHS.Ptr = Ptr; |
| Ptr = Tmp; |
| } |
| }; |
| |
| template<class T> |
| inline void swap(OwningArrayPtr<T> &a, OwningArrayPtr<T> &b) { |
| a.swap(b); |
| } |
| |
| } // end namespace llvm |
| |
| #endif |