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
|
/*
Copyright (C) 2009 Ricardo Pescuma Domenecci
This is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with this file; see the file license.txt. If
not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
*/
#ifndef __SCOPE_H__
# define __SCOPE_H__
#define DEFINE_SCOPED_TYPE(_NAME_, _DELETE_) \
template<class T> \
class _NAME_ \
{ \
_NAME_(_NAME_ &); \
_NAME_ & operator=(_NAME_ &); \
\
public: \
_NAME_(T *t = NULL) : p(t) {} \
\
~_NAME_() \
{ \
release(); \
} \
\
T * operator=(T *t) \
{ \
release(); \
p = t; \
return t; \
} \
\
operator T*() const \
{ \
return p; \
} \
\
bool operator==(T *t) const \
{ \
return p == t; \
} \
\
bool operator!=(T *t) const \
{ \
return p != t; \
} \
\
T *get() const \
{ \
return p; \
} \
\
void release() \
{ \
if (p != NULL) \
dealoc(p); \
p = NULL; \
} \
\
T* detach() \
{ \
T *ret = p; \
p = NULL; \
return ret; \
} \
\
protected: \
T *p; \
\
void dealoc(T *ptr) \
{ \
_DELETE_; \
} \
}; \
\
template<typename T> \
inline bool operator==(T* p, const _NAME_<T> &b) { \
return p == b.get(); \
} \
\
template<typename T> \
inline bool operator!=(T* p, const _NAME_<T> &b) { \
return p != b.get(); \
}
DEFINE_SCOPED_TYPE(scoped_ptr, delete ptr)
DEFINE_SCOPED_TYPE(scoped_array, delete[] ptr)
DEFINE_SCOPED_TYPE(scoped_free, free(ptr))
DEFINE_SCOPED_TYPE(scoped_mir_free, mir_free(ptr))
#endif // __SCOPE_H__
|