}
}
- void AssignCopy( const wxWeakRefStatic& wr )
+ void AssignCopy(const wxWeakRefStatic& wr)
{
Assign( wr.m_pobj );
}
T *m_pobj;
};
-#ifdef HAVE_PARTIAL_SPECIALIZATION
+#if !defined(HAVE_PARTIAL_SPECIALIZATION) || !defined(HAVE_TEMPLATE_OVERLOAD_RESOLUTION)
+ #define USE_STATIC_WEAKREF
+#endif
+
+
+#ifndef USE_STATIC_WEAKREF
template<class T,bool use_static>
struct wxWeakRefImpl;
void AssignCopy(const wxWeakRefImpl& wr)
{
- DoAssign( wr.m_pobj, wr.m_ptbase );
+ DoAssign(wr.m_pobj, wr.m_ptbase);
}
void DoAssign( T* pobj, wxTrackable *ptbase ) {
wxTrackable *m_ptbase;
};
-#endif // HAVE_PARTIAL_SPECIALIZATION
+#endif // #ifndef USE_STATIC_WEAKREF
+
// A weak reference to an object of type T, where T has type wxTrackable
// (usually statically but if not dynamic_cast<> is tried).
template <class T>
class wxWeakRef : public
-#ifdef HAVE_PARTIAL_SPECIALIZATION
- wxWeakRefImpl<T, wxIsStaticTrackable<T>::value>
-#else
+#ifdef USE_STATIC_WEAKREF
wxWeakRefStatic<T>
+#else
+ wxWeakRefImpl<T, wxIsStaticTrackable<T>::value>
#endif
{
public:
// Weak ref implementation assign objects are queried for wxTrackable
// using dynamic_cast<>
-template<class T>
+template <class T>
class wxWeakRefDynamic : public wxTrackerNode
{
public:
}
}
- void AssignCopy(const wxWeakRefDynamic& wr)
- {
- Assign(wr.m_pobj);
- }
-
virtual void OnObjectDestroy()
{
wxASSERT_MSG( m_pobj, "tracked object should have removed us itself" );
// Provide some basic types of weak references
class WXDLLIMPEXP_FWD_BASE wxEvtHandler;
-class WXDLLIMPEXP_FWD_BASE wxWindow;
+class WXDLLIMPEXP_FWD_CORE wxWindow;
typedef wxWeakRef<wxEvtHandler> wxEvtHandlerRef;
typedef wxWeakRef<wxWindow> wxWindowRef;