mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	* Alphabetized #includes * Removed trailing whitespace * Wrapped or shortened lines over 80 chars git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@65181 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			135 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			135 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //===- 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
 |