blob: 159eeb2c0122ff43fa16786fb7dd787c20eaeb62 (
plain)
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
116
117
118
119
120
121
122
|
#ifndef __smartptr_h
#define __smartptr_h
#include "object.h"
#include <stdio.h>
#ifdef SWIG
#define TEMPLATE_TYPEDEF(x, y) \
%template(y) x; \
typedef x y
#else
#define TEMPLATE_TYPEDEF(x, y) typedef x y
#endif
template<class T>
class ePtr
{
protected:
T *ptr;
public:
T &operator*() { return *ptr; }
ePtr(): ptr(0)
{
}
ePtr(T *c): ptr(c)
{
if (c)
c->AddRef();
}
ePtr(const ePtr &c)
{
ptr=c.ptr;
if (ptr)
ptr->AddRef();
}
ePtr &operator=(T *c)
{
if (c)
c->AddRef();
if (ptr)
ptr->Release();
ptr=c;
return *this;
}
ePtr &operator=(ePtr<T> &c)
{
if (c.ptr)
c.ptr->AddRef();
if (ptr)
ptr->Release();
ptr=c.ptr;
return *this;
}
~ePtr()
{
if (ptr)
ptr->Release();
}
T* grabRef() { if (!ptr) return 0; ptr->AddRef(); return ptr; }
T* &ptrref() { assert(!ptr); return ptr; }
T* operator->() const { assert(ptr); return ptr; }
operator T*() const { return this->ptr; }
};
#ifndef SWIG
template<class T>
class eMutablePtr: public ePtr<T>
{
/* read doc/iObject about the ePtrHelper */
template<class T1>
class ePtrHelper
{
T1 *m_obj;
public:
inline ePtrHelper(T1 *obj): m_obj(obj)
{
m_obj->AddRef();
}
inline ~ePtrHelper()
{
m_obj->Release();
}
inline T1* operator->() { return m_obj; }
};
protected:
T *ptr;
public:
eMutablePtr(): ePtr<T>(0)
{
}
eMutablePtr(T *c): ePtr<T>(c)
{
}
eMutablePtr(const eMutablePtr &c): ePtr<T>(c)
{
}
eMutablePtr &operator=(T *c)
{
ePtr<T>::operator=(c);
return *this;
}
ePtrHelper<T> operator->() { assert(ptr); return ePtrHelper<T>(ptr); }
/* for const objects, we don't need the helper, as they can't */
/* be changed outside the program flow. at least this is */
/* what the compiler assumes, so in case you're using const */
/* eMutablePtrs note that they have to be const. */
const T* operator->() const { assert(ptr); return ptr; }
};
#endif
#endif
|