ZFFramework
 
Loading...
Searching...
No Matches
zfweak.h
Go to the documentation of this file.
1
5
6#ifndef _ZFI_zfweak_h_
7#define _ZFI_zfweak_h_
8
9#include "zfweak_fwd.h"
10
12
13// ============================================================
53public:
54 zfweak(void) : _ZFP_obj(zfnull) {}
55 zfweak(ZF_IN zfweak const &obj) : _ZFP_obj(zfRetain(obj._ZFP_obj)) {}
56 zfweak(ZF_IN ZFObject *obj) : _ZFP_obj(obj ? zfRetain(obj->_ZFP_ZFObject_weakHolder()) : zfnull) {}
57 template<typename T_ZFObject>
58 zfweak(ZF_IN T_ZFObject const &obj) {
59 ZFObject *t = _ZFP_zfanyCast(obj);
60 _ZFP_obj = t ? zfRetain(t->_ZFP_ZFObject_weakHolder()) : zfnull;
61 }
62 ~zfweak(void) {
63 zfRelease(_ZFP_obj);
64 }
65
66public:
67 inline zfweak &operator = (ZF_IN zfweak const &obj) {
68 this->set(obj);
69 return *this;
70 }
71 template<typename T_ZFObject>
72 inline zfweak &operator = (ZF_IN T_ZFObject const &obj) {
73 this->set(obj);
74 return *this;
75 }
76
77public:
78 template<typename T_ZFObject>
79 inline zfbool operator == (ZF_IN T_ZFObject const &obj) const {
80 return this->toObject() == _ZFP_zfanyCast(obj);
81 }
82 template<typename T_ZFObject>
83 inline zfbool operator != (ZF_IN T_ZFObject const &obj) const {
84 return this->toObject() != _ZFP_zfanyCast(obj);
85 }
86
87public:
88 inline ZFObject *operator -> (void) const {
89 return this->toObject();
90 }
91 inline operator ZFObject * (void) const {
92 return this->toObject();
93 }
94 template<typename T_ZFObject>
95 inline operator T_ZFObject * (void) const {
96 return zfcast(T_ZFObject *, this->toObject());
97 }
98
99public:
100 static const ZFClass *ClassData(void) {
101 return ZFObject::ClassData();
102 }
104
105public:
109 inline zfbool valid(void) const {
110 return this->toObject() != zfnull;
111 }
112
116 inline zfany get(void) const {
117 return _ZFP_obj ? _ZFP_obj->get().toObject() : zfnull;
118 }
119
122 template<typename T_ZFObject>
123 void set(ZF_IN T_ZFObject const &obj) {
124 ZFObject *t = _ZFP_zfanyCast(obj);
125 _ZFP_I_zfweak *old = _ZFP_obj;
126 _ZFP_obj = (t ? zfRetain(t->_ZFP_ZFObject_weakHolder()) : zfnull);
127 zfRelease(old);
128 }
129
132 void set(ZF_IN const zfweak &obj) {
133 this->set(obj.toObject());
134 }
135
138 void set(ZF_IN zfnullT const &) {
139 _ZFP_I_zfweak *old = _ZFP_obj;
140 _ZFP_obj = zfnull;
141 zfRelease(old);
142 }
143
144public:
148 inline ZFObject *toObject(void) const {
149 return _ZFP_obj ? _ZFP_obj->get().toObject() : zfnull;
150 }
151
154 template<typename T_ZFObject>
155 inline T_ZFObject to(void) const {
156 return zfcast(T_ZFObject, this->toObject());
157 }
158
162 const zfany &asAny(void) const {
163 return _ZFP_obj;
164 }
165
166private:
167 zfanyT<_ZFP_I_zfweak> _ZFP_obj;
168};
170 if(v) {
171 s += "[weak]";
172 v.toObject()->objectInfoT(s);
173 }
174 else {
175 s += ZFTOKEN_zfnull;
176 }
177})
179 return ZFObjectCompare(v0.toObject(), v1.toObject());
180 })
183
184// ============================================================
188template<typename T_ZFObjectBase>
191public:
192 zfweakT(void) : zfweak() {}
193 zfweakT(ZF_IN zfweak const &obj) : zfweak(obj) {}
194 zfweakT(ZF_IN zfweakT<T_ZFObjectBase> const &obj) : zfweak((zfweak const &)obj) {}
195 zfweakT(ZF_IN ZFObject *obj) : zfweak(obj) {}
196 template<typename T_ZFObject>
197 zfweakT(ZF_IN T_ZFObject const &obj) : zfweak(obj) {}
198
199public:
200 inline zfweakT<T_ZFObjectBase> &operator = (ZF_IN zfweak const &obj) {
201 this->set(obj);
202 return *this;
203 }
204 inline zfweakT<T_ZFObjectBase> &operator = (ZF_IN zfweakT<T_ZFObjectBase> const &obj) {
205 this->set(obj);
206 return *this;
207 }
208 template<typename T_ZFObject>
209 inline zfweakT<T_ZFObjectBase> &operator = (ZF_IN T_ZFObject const &obj) {
210 this->set(obj);
211 return *this;
212 }
213
214public:
215 template<typename T_ZFObject>
216 inline zfbool operator == (ZF_IN T_ZFObject const &obj) const {
217 return this->toObject() == _ZFP_zfanyCast(obj);
218 }
219 template<typename T_ZFObject>
220 inline zfbool operator != (ZF_IN T_ZFObject const &obj) const {
221 return this->toObject() != _ZFP_zfanyCast(obj);
222 }
223
224public:
225 inline T_ZFObjectBase *operator -> (void) const {
226 return zfcast(T_ZFObjectBase *, this->toObject());
227 }
228
229public:
230 inline ZFObject *toObject(void) const { // required for _ZFP_zfanyCast to work
231 return zfweak::toObject();
232 }
233
234public:
235 static const ZFClass *ClassData(void) {
236 return T_ZFObjectBase::ClassData();
237 }
239};
240ZFOUTPUT_TYPE_TEMPLATE(typename T_ZFObject, zfweakT<T_ZFObject>, {
241 if(v) {
242 s += "[weak]";
243 v.toObject()->objectInfoT(s);
244 }
245 else {
246 s += ZFTOKEN_zfnull;
247 }
248})
250template<typename T_ZFObject>
252public:
253 enum {
254 TypeIdRegistered = 1,
255 TypeIdSerializable = 1,
256 };
257 static inline const zfstring &TypeId(void) {
259 }
260 static inline const ZFClass *TypeIdClass(void) {
261 return v_zfweak::ClassData();
262 }
264 virtual zfbool typeIdSerializable(void) const {
265 return TypeIdSerializable;
266 }
268 virtual const zfstring &typeId(void) const {
269 return TypeId();
270 }
272 virtual const ZFClass *typeIdClass(void) const {
273 return TypeIdClass();
274 }
275 static zfbool ValueStore(
276 ZF_OUT zfauto &obj
277 , ZF_IN zfweakT<T_ZFObject> const &v
278 ) {
279 return ZFTypeId<zfweak>::ValueStore(obj, v);
280 }
281 template<typename T_Access = zfweakT<T_ZFObject>
282 , int T_Mode = ((zftTraits<typename zftTraits<T_Access>::TrNoRef>::TrIsPtr
283 && !zftIsSame<typename zftTraits<T_Access>::TrNoRef, zfweakT<T_ZFObject> >::Value) ? 1
284 : ((zftTraits<typename zftTraits<T_Access>::TrNoRef>::TrIsPtr
285 && zftIsSame<typename zftTraits<T_Access>::TrNoRef, zfweakT<T_ZFObject> >::Value
286 && !zftTraits<T_Access>::TrIsRef) ? 2 : 0))
287 , typename T_Fix = void
288 >
289 zfclassNotPOD Value {
290 public:
291 static zfbool zfvAccessAvailable(ZF_IN_OUT zfauto &obj) {
293 }
294 static T_Access zfvAccess(ZF_IN_OUT zfauto &obj) {
295 // zfweakT ensured safe for reinterpret cast
297 }
298 static void zfvAccessFinish(ZF_IN_OUT zfauto &obj) {
300 }
301 };
302 template<typename T_Access>
303 zfclassNotPOD Value<T_Access, 1> {
304 public:
305 static zfbool zfvAccessAvailable(ZF_IN_OUT zfauto &obj) {
307 }
308 static typename zftTraits<T_Access>::TrNoRef zfvAccess(ZF_IN_OUT zfauto &obj) {
309 // zfweakT ensured safe for reinterpret cast
311 }
312 static void zfvAccessFinish(ZF_IN_OUT zfauto &obj) {
314 }
315 };
316public:
318 virtual zfbool genericValueStore(ZF_OUT zfauto &obj, ZF_IN const void *v) const {
319 return ValueStore(obj, *(const zfweakT<T_ZFObject> *)v);
320 }
322 virtual void *genericAccess(ZF_IN_OUT zfauto &obj) const {
323 if(!Value<zfweakT<T_ZFObject> >::zfvAccessAvailable(obj)) {
324 return zfnull;
325 }
326 return (void *)zfnew(zfweakT<T_ZFObject>, Value<zfweakT<T_ZFObject> >::zfvAccess(obj));
327 }
329 virtual void genericAccessFinish(ZF_IN_OUT zfauto &obj, ZF_IN void *v) const {
331 Value<zfweakT<T_ZFObject> >::zfvAccessFinish(obj);
332 }
334 virtual ZFCoreArrayBase *genericArrayNew(void) const {
336 }
337};
339
341// ============================================================
342template<typename T_ZFObject>
343inline zfbool operator == (ZF_IN T_ZFObject *obj, ZF_IN zfweak const &e) {
344 return e.toObject() == _ZFP_zfanyCast(obj);
345}
346template<typename T_ZFObject>
347inline zfbool operator != (ZF_IN T_ZFObject *obj, ZF_IN zfweak const &e) {
348 return e.toObject() != _ZFP_zfanyCast(obj);
349}
350
351// ============================================================
352template<typename T_ZFObject, typename T_ZFObjectBase>
353inline zfbool operator == (ZF_IN T_ZFObject *obj, ZF_IN zfweakT<T_ZFObjectBase> const &e) {
354 return e.toObject() == _ZFP_zfanyCast(obj);
355}
356template<typename T_ZFObject, typename T_ZFObjectBase>
357inline zfbool operator != (ZF_IN T_ZFObject *obj, ZF_IN zfweakT<T_ZFObjectBase> const &e) {
358 return e.toObject() != _ZFP_zfanyCast(obj);
359}
361
362// ============================================================
363template<typename T_ZFObject>
364zfclassNotPOD _ZFP_zfweakCkT {
365public:
366 static inline void zfweakNotSupport(void) {}
367};
368template<> zfclassNotPOD _ZFP_zfweakCkT<zfweak> {};
369template<typename T_ZFObject> zfclassNotPOD _ZFP_zfweakCkT<zfweakT<T_ZFObject> > {};
370template<typename T_ZFObject>
371inline void _ZFP_zfweakCk(T_ZFObject &t) {
372 _ZFP_zfweakCkT<typename zftTraits<T_ZFObject>::TrNoRef>::zfweakNotSupport();
373}
374
376#endif // #ifndef _ZFI_zfweak_h_
377
#define ZFCOMPARER_DEFAULT_DECLARE(T_Comparable0, T_Comparable1, compareAction)
declare a template specialization for ZFComparerDefault
Definition ZFComparer.h:264
#define ZFLIB_ZFCore
used to export symbols
Definition ZFCoreEnvDef.h:30
#define zfclassLikePOD
shows the class is not a POD type, but you may use it like a POD except memset it to 0
Definition ZFCoreTypeDef_ClassType.h:41
#define zfextend
dummy macro shows class inherit from another
Definition ZFCoreTypeDef_ClassType.h:53
#define zfdelete(instance)
same as delete defined for future use
Definition ZFCoreTypeDef_ClassType.h:91
#define zfoverride
dummy macro shows that method override parent's method
Definition ZFCoreTypeDef_ClassType.h:58
#define ZF_IN
dummy macro that shows the param used as required input
Definition ZFCoreTypeDef_ClassType.h:180
#define ZF_OUT
dummy macro that shows the param used as required output
Definition ZFCoreTypeDef_ClassType.h:188
#define zfclassNotPOD
shows the class is not a POD type, you should not memset it or declare it in stack or copy value by c...
Definition ZFCoreTypeDef_ClassType.h:48
#define ZF_IN_OUT
dummy macro that shows the param used as required input and output
Definition ZFCoreTypeDef_ClassType.h:196
#define zfnew(Type,...)
same as new defined for future use
Definition ZFCoreTypeDef_ClassType.h:89
#define zfnullT
type for zfnull, can be used for function overload
Definition ZFCoreTypeDef_CoreType.h:85
_ZFT_t_zfbool zfbool
bool type
Definition ZFCoreTypeDef_CoreType.h:103
#define zfnull
same as NULL, defined for future use
Definition ZFCoreTypeDef_CoreType.h:88
#define ZFOUTPUT_TYPE(T_Type, outputAction)
declare your custom type conversion to string, convenient for debug
Definition ZFCoreTypeDef_OtherType.h:221
#define ZFOUTPUT_TYPE_TEMPLATE(T_typenameList, T_Type, outputAction)
see ZFOUTPUT_TYPE
Definition ZFCoreTypeDef_OtherType.h:262
#define ZFTOKEN_zfnull
string tokens
Definition ZFCoreTypeDef_OtherType.h:16
zft_zfstring< zfchar > zfstring
see zft_zfstring
Definition ZFCoreTypeDef_StringType.h:15
#define ZF_NAMESPACE_GLOBAL_BEGIN
begin namespace ZFFramework
Definition ZFNamespace.h:97
#define ZF_NAMESPACE_GLOBAL_END
end namespace ZFFramework
Definition ZFNamespace.h:98
#define zfcast(T_To, obj)
safely cast ZFObject types, return null if not desired type
Definition ZFObjectCast.h:28
#define zfRelease(obj)
release an object, see ZFObject
Definition ZFObjectRetain.h:148
#define zfRetain(obj)
retain an object, see ZFObject
Definition ZFObjectRetain.h:128
ZFCompareResult ZFObjectCompare(ZFObject *const &e0, ZFObject *const &e1)
util method to compare two ZFObject, return ZFCompareEqual if both null, return ZFCompareUncomparable...
Definition ZFObjectUtil.h:21
#define ZFTYPEID_ACCESS_ONLY_REG(ZFLIB_, TypeName, Type,...)
see ZFTYPEID_DECLARE
Definition ZFTypeIdDeclare.h:205
#define ZFTYPEID_ACCESS_ONLY_DECLARE(ZFLIB_, TypeName, Type)
see ZFTYPEID_DECLARE
Definition ZFTypeIdDeclare.h:195
ZFObject's class info.
Definition ZFClass.h:67
dummy base for ZFCoreArray
Definition ZFCoreArray.h:162
light weight array
Definition ZFCoreArray.h:331
base class of all objects
Definition ZFObjectCore.h:209
static const ZFClass * ClassData(void)
get class info
Definition ZFObjectCore.h:211
static zfbool zfvAccessAvailable(zfauto &obj)
try access as raw value, see ZFTypeId::Value
static T_Access zfvAccess(zfauto &obj)
try access as raw value, see ZFTypeId::Value
static void zfvAccessFinish(zfauto &obj)
finish access as raw value, see ZFTypeId::Value
type data traits for ZFTYPEID_DECLARE
Definition ZFTypeIdFwd.h:117
static const zfstring & TypeId(void)
get type id, or return ZFTypeId_none if not registered
static zfbool ValueStore(zfauto &obj, T_Type const &v)
store the value to wrapper object
base protocol for ZFTypeId
Definition ZFTypeIdFwd.h:24
static const ZFClass * ClassData(void)
get class info
Definition zfweak.h:181
util method to cast ZFObject types freely
Definition zfany.h:35
ZFObject * toObject(void) const
get the holded object
Definition zfany.h:85
see zfany
Definition zfany.h:106
a ZFObject holder which would release content object automatically when destroyed
Definition zfautoFwd.h:34
T_Type TrNoRef
remove reference
Definition ZFCoreUtilTemplate.h:110
weak reference to ZFObject
Definition zfweak.h:51
zfany get(void) const
get the holded object
Definition zfweak.h:116
const zfany & asAny(void) const
access as zfany
Definition zfweak.h:162
void set(T_ZFObject const &obj)
set the holded object
Definition zfweak.h:123
ZFObject * toObject(void) const
get the holded object
Definition zfweak.h:148
T_ZFObject to(void) const
cast by zfcast
Definition zfweak.h:155
void set(const zfweak &obj)
set the holded object
Definition zfweak.h:132
zfbool valid(void) const
true if the holded object is not null
Definition zfweak.h:109
void set(zft_zfnullT const &)
set the holded object
Definition zfweak.h:138
see zfweak
Definition zfweak.h:189
weak reference to ZFObject