Merge QtSharedPointer::Basic into QtSharedPointer::ExternalRefCount

The basic class existed for legacy only, when internal reference
counting was a goal. Since it isn't anymore, we can remove the
distinction and simply merge the two classes.

Change-Id: Ib7a1c4158a8d71e71fa6afa447938b8b85ddae87
Reviewed-by: Lars Knoll <lars.knoll@nokia.com>
Reviewed-by: Bradley T. Hughes <bradley.hughes@nokia.com>
This commit is contained in:
Thiago Macieira 2012-05-23 18:39:36 +02:00 committed by Qt by Nokia
parent f77d2e0319
commit 32edd16e2b

View File

@ -122,49 +122,6 @@ namespace QtSharedPointer {
template <class T> struct RemovePointer<QSharedPointer<T> > { typedef T Type; }; template <class T> struct RemovePointer<QSharedPointer<T> > { typedef T Type; };
template <class T> struct RemovePointer<QWeakPointer<T> > { typedef T Type; }; template <class T> struct RemovePointer<QWeakPointer<T> > { typedef T Type; };
// This class provides the basic functionality of a pointer wrapper.
// Its existence is mostly legacy, since originally QSharedPointer
// could also be used for internally-refcounted objects.
template <class T>
class Basic
{
typedef T *Basic:: *RestrictedBool;
public:
typedef T Type;
typedef T element_type;
typedef T value_type;
typedef value_type *pointer;
typedef const value_type *const_pointer;
typedef value_type &reference;
typedef const value_type &const_reference;
typedef qptrdiff difference_type;
inline T *data() const { return value; }
inline bool isNull() const { return !data(); }
inline operator RestrictedBool() const { return isNull() ? 0 : &Basic::value; }
inline bool operator !() const { return isNull(); }
inline T &operator*() const { return *data(); }
inline T *operator->() const { return data(); }
protected:
inline Basic(T *ptr = 0) : value(ptr) { }
inline Basic(Qt::Initialization) { }
// ~Basic();
inline void internalConstruct(T *ptr)
{
value = ptr;
}
#if defined(Q_NO_TEMPLATE_FRIENDS)
public:
#else
template <class X> friend class QT_PREPEND_NAMESPACE(QWeakPointer);
#endif
Type *value;
};
// This class is the d-pointer of QSharedPointer and QWeakPointer. // This class is the d-pointer of QSharedPointer and QWeakPointer.
// //
// It is a reference-counted reference counter. "strongref" is the inner // It is a reference-counted reference counter. "strongref" is the inner
@ -315,11 +272,28 @@ namespace QtSharedPointer {
// This is the main body of QSharedPointer. It implements the // This is the main body of QSharedPointer. It implements the
// external reference counting functionality. // external reference counting functionality.
template <class T> template <class T>
class ExternalRefCount: public Basic<T> class ExternalRefCount
{ {
protected: typedef T *ExternalRefCount:: *RestrictedBool;
typedef ExternalRefCountData Data; typedef ExternalRefCountData Data;
public:
typedef T Type;
typedef T element_type;
typedef T value_type;
typedef value_type *pointer;
typedef const value_type *const_pointer;
typedef value_type &reference;
typedef const value_type &const_reference;
typedef qptrdiff difference_type;
inline T *data() const { return value; }
inline bool isNull() const { return !data(); }
inline operator RestrictedBool() const { return isNull() ? 0 : &ExternalRefCount::value; }
inline bool operator !() const { return isNull(); }
inline T &operator*() const { return *data(); }
inline T *operator->() const { return data(); }
protected:
inline void deref() inline void deref()
{ deref(d); } { deref(d); }
static inline void deref(Data *d) static inline void deref(Data *d)
@ -344,31 +318,29 @@ namespace QtSharedPointer {
inline void internalCreate() inline void internalCreate()
{ {
T *ptr; d = ExternalRefCountWithContiguousData<T>::create(&value);
d = ExternalRefCountWithContiguousData<T>::create(&ptr);
Basic<T>::internalConstruct(ptr);
} }
inline void internalFinishConstruction(T *ptr) inline void internalFinishConstruction(T *ptr)
{ {
Basic<T>::internalConstruct(ptr); value = ptr;
if (ptr) d->setQObjectShared(ptr, true); if (ptr) d->setQObjectShared(ptr, true);
#ifdef QT_SHAREDPOINTER_TRACK_POINTERS #ifdef QT_SHAREDPOINTER_TRACK_POINTERS
if (ptr) internalSafetyCheckAdd(d, ptr); if (ptr) internalSafetyCheckAdd(d, ptr);
#endif #endif
} }
inline ExternalRefCount() : d(0) { } inline ExternalRefCount() : value(0), d(0) { }
inline ExternalRefCount(Qt::Initialization i) : Basic<T>(i) { } inline ExternalRefCount(Qt::Initialization) { }
template <typename Deleter> template <typename Deleter>
inline ExternalRefCount(T *ptr, Deleter deleter) : Basic<T>(Qt::Uninitialized) // throws inline ExternalRefCount(T *ptr, Deleter deleter) // throws
{ internalConstruct(ptr, deleter); } { internalConstruct(ptr, deleter); }
inline ExternalRefCount(const ExternalRefCount<T> &other) : Basic<T>(other), d(other.d) inline ExternalRefCount(const ExternalRefCount<T> &other) : value(other.value), d(other.d)
{ if (d) ref(); } { if (d) ref(); }
template <class X> template <class X>
inline ExternalRefCount(const ExternalRefCount<X> &other) : Basic<T>(other.value), d(other.d) inline ExternalRefCount(const ExternalRefCount<X> &other) : value(other.value), d(other.d)
{ if (d) ref(); } { if (d) ref(); }
inline ~ExternalRefCount() { deref(); } inline ~ExternalRefCount() { deref(); }
@ -429,6 +401,7 @@ namespace QtSharedPointer {
deref(o); deref(o);
} }
Type *value;
Data *d; Data *d;
}; };
} // namespace QtSharedPointer } // namespace QtSharedPointer