/usr/include/root/TGeoRCPtr.h is in libroot-geom-dev 5.34.14-1build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 | /*************************************************************************
* Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
* All rights reserved. *
* *
* For the licensing terms see $ROOTSYS/LICENSE. *
* For the list of contributors see $ROOTSYS/README/CREDITS. *
*************************************************************************/
// Author: Andrei.Gheata@cern.ch 29/05/2013
//______________________________________________________________________________
// TGeoRCPtr - A reference counting-managed pointer for classes derived from
// TGeoExtension which can be used as C pointer. Based on
// CodeProject implementation example
//______________________________________________________________________________
/*______________________________________________________________________________
Example:
=======
class MyExtension : public TGeoExtension {
public:
MyExtension() : TGeoExtension(), fRC(0) {printf("Created MyExtension\n");}
virtual ~MyExtension() {printf("Deleted MyExtension\n");}
virtual TGeoExtension *Grab() const {fRC++; return (TGeoExtension*)this;}
virtual void Release() const {assert(fRC > 0); fRC--; if (fRC ==0) delete this;}
void print() const {printf("MyExtension object %p\n", this);}
private:
mutable Int_t fRC; // Reference counter
ClassDef(MyExtension,1)
};
Usage:
======
// Module 1 creates an object
TGeoRCPtr<MyExtension> a2 = new MyExtension(); //fRC=1
// Module 2 grabs object
TGeoRCPtr<MyExtension> ptr2 = a2; //fRC=2
// Module 2 invokes a method
ptr2->Print();
(*ptr2).Print();
// Module 1 no longer needs object
a2 = 0; //RC=1
// Module 2 no longer needs object
ptr2 = 0; //object will be destroyed here
Note:
=====
Event if one forgets to call ptr2 = 0, the object gets delete when the method
using ptr2 gets out of scope.
______________________________________________________________________________*/
template<class T>
class TGeoRCPtr
{
public:
//Construct using a C pointer, e.g. TGeoRCPtr<T> x = new T();
TGeoRCPtr(T* ptr = 0)
: fPtr(ptr)
{
if(ptr != 0) ptr->Grab();
}
//Copy constructor
TGeoRCPtr(const TGeoRCPtr &ptr)
: fPtr(ptr.fPtr)
{
if(fPtr != 0) fPtr->Grab();
}
~TGeoRCPtr()
{
if(fPtr != 0) fPtr->Release();
}
//Assign a pointer, e.g. x = new T();
TGeoRCPtr &operator=(T* ptr)
{
if(ptr != 0) ptr->Grab();
if(fPtr != 0) fPtr->Release();
fPtr = ptr;
return (*this);
}
//Assign another TGeoRCPtr
TGeoRCPtr &operator=(const TGeoRCPtr &ptr)
{
return (*this) = ptr.fPtr;
}
//Retrieve actual pointer
T* Get() const
{
return fPtr;
}
//Some overloaded operators to facilitate dealing with an TGeoRCPtr as a convetional C pointer.
//Without these operators, one can still use the less transparent Get() method to access the pointer.
T* operator->() const {return fPtr;} //x->member
T &operator*() const {return *fPtr;} //*x, (*x).member
operator T*() const {return fPtr;} //T* y = x;
operator bool() const {return fPtr != 0;} //if(x) {/*x is not NULL*/}
bool operator==(const TGeoRCPtr &ptr) {return fPtr == ptr.fPtr;}
bool operator==(const T *ptr) {return fPtr == ptr;}
private:
T *fPtr; //Actual pointer
};
|