]> git.saurik.com Git - wxWidgets.git/blame - interface/weakref.h
prevent crash if panel/kicker is killed, bug 1872724
[wxWidgets.git] / interface / weakref.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: weakref.h
e54c96f1 3// Purpose: interface of wxWeakRefDynamic<T>
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
9/**
23324ae1 10 @wxheader{weakref.h}
7c913512 11
73473b3e
RR
12 wxWeakRefDynamic<T> is a template class for weak references that is used in
13 the same way as wxWeakRef<T>. The only difference is that wxWeakRefDynamic
7c913512
FM
14 defaults to using @c dynamic_cast for establishing the object
15 reference (while wxWeakRef defaults to @c static_cast).
16
23324ae1
FM
17 So, wxWeakRef will detect a type mismatch during compile time and will
18 have a little better run-time performance. The role of wxWeakRefDynamic
7c913512
FM
19 is to handle objects which derived type one does not know.
20
73473b3e 21 @note wxWeakRef<T> selects an implementation based on the static type
23324ae1 22 of T. If T does not have wxTrackable statically, it defaults to to a mixed-
7c913512
FM
23 mode operation, where it uses @c dynamic_cast as the last measure (if
24 available from the compiler and enabled when building wxWidgets).
25
73473b3e 26 For general cases, wxWeakRef<T> is the better choice.
7c913512 27
73473b3e 28 For API documentation, see: wxWeakRef<T>
7c913512 29
23324ae1
FM
30 @library{wxcore}
31 @category{FIXME}
32*/
5cb947fd 33template<typename T>
7c913512 34class wxWeakRefDynamic<T>
23324ae1
FM
35{
36public:
7c913512 37
23324ae1
FM
38};
39
40
e54c96f1 41
23324ae1 42/**
23324ae1 43 @wxheader{weakref.h}
7c913512
FM
44
45 wxWeakRef is a template class for weak references to wxWidgets objects,
46 such as wxEvtHandler, wxWindow and
23324ae1
FM
47 wxObject. A weak reference behaves much like an ordinary
48 pointer, but when the object pointed is destroyed, the weak reference is
7c913512
FM
49 automatically reset to a @NULL pointer.
50
73473b3e 51 wxWeakRef<T> can be used whenever one must keep a pointer to an object
23324ae1 52 that one does not directly own, and that may be destroyed before the object
7c913512
FM
53 holding the reference.
54
73473b3e 55 wxWeakRef<T> is a small object and the mechanism behind it is fast
7c913512
FM
56 (@b O(1)). So the overall cost of using it is small.
57
e84fd6a1
RR
58 Example
59
60 @code
61 wxWindow *wnd = new wxWindow( parent, wxID_ANY, "wxWindow" );
62 wxWeakRef<wxWindow> wr = wnd;
63 wxWindowRef wr2 = wnd; // Same as above, but using a typedef
64 // Do things with window
65 wnd->Show( true );
66 // Weak ref is used like an ordinary pointer
67 wr->Show( false );
68 wnd->Destroy();
69 // Now the weak ref has been reset, so we don't risk accessing
70 // a dangling pointer:
71 wxASSERT( wr==NULL );
72 @endcode
73
74 wxWeakRef<T> works for any objects that are derived from wxTrackable. By default,
75 wxEvtHandler and wxWindow derive from wxTrackable. However, wxObject does not, so
76 types like wxFont and wxColour are not trackable. The example below shows how to
77 create a wxObject derived class that is trackable:
78
79 @code
80 class wxMyTrackableObject : public wxObject, public wxTrackable
81 {
82 // ... other members here
83 };
84 @endcode
85
86 The following types of weak references are predefined:
87
88 @code
89 typedef wxWeakRef<wxEvtHandler> wxEvtHandlerRef;
90 typedef wxWeakRef<wxWindow> wxWindowRef;
91 @endcode
92
93
23324ae1
FM
94 @library{wxbase}
95 @category{FIXME}
7c913512 96
73473b3e 97 @see wxSharedPtr<T>, wxScopedPtr<T>
23324ae1 98*/
5cb947fd 99template<typename T>
7c913512 100class wxWeakRef<T>
23324ae1
FM
101{
102public:
103 /**
104 Constructor. The weak reference is initialized to @e pobj.
105 */
5cb947fd 106 wxWeakRef(T* pobj = NULL);
23324ae1 107
6dd21c54
RR
108 /**
109 Copy constructor.
110 */
111 wxWeakRef(const wxWeakRef<T>& wr);
112
23324ae1
FM
113 /**
114 Destructor.
115 */
5cb947fd 116 ~wxWeakRef();
23324ae1
FM
117
118 /**
119 Called when the tracked object is destroyed. Be default sets
14bdedbc
RR
120 internal pointer to @NULL. You need to call this method if
121 you override it.
23324ae1
FM
122 */
123 virtual void OnObjectDestroy();
124
125 /**
126 Release currently tracked object and rests object reference.
127 */
128 void Release();
129
130 /**
131 Returns pointer to the tracked object or @NULL.
132 */
328f5751 133 T* get() const;
23324ae1
FM
134
135 /**
136 Release currently tracked object and start tracking the same object as
137 the wxWeakRef @e wr.
138 */
139 T* operator =(wxWeakRef<T>& wr);
140
141 /**
142 Implicit conversion to T*. Returns pointer to the tracked
143 object or @NULL.
144 */
328f5751 145 T* operator*() const;
23324ae1
FM
146
147 /**
148 Returns a reference to the tracked object. If the internal pointer is @NULL
149 this method will cause an assert in debug mode.
150 */
328f5751 151 T operator*() const;
23324ae1
FM
152
153 /**
154 Smart pointer member access. Returns a pointer to the
155 tracked object. If the internal pointer is @NULL this
156 method will cause an assert in debug mode.
157 */
158 T* operator-();
159
160 /**
161 Releases the currently tracked object and starts tracking @e pobj.
162 A weak reference may be reset by passing @e @NULL as @e pobj.
163 */
164 T* operator=(T* pobj);
165};
e54c96f1 166