From 3cf8e426f49ee6adb1090865854506aa92316ce3 Mon Sep 17 00:00:00 2001 From: Olivier Goffart Date: Sat, 7 Feb 2015 14:12:30 +0100 Subject: QMetaType: Automatic registration of Q_GADGET and Q_ENUM types Change-Id: If43dcc2b77fea5ae3ec40cc847467fc21fbd2c83 Reviewed-by: Marc Mutz Reviewed-by: Simon Hausmann --- src/corelib/kernel/qmetatype.h | 55 ++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 53 insertions(+), 2 deletions(-) (limited to 'src/corelib/kernel') diff --git a/src/corelib/kernel/qmetatype.h b/src/corelib/kernel/qmetatype.h index 025fbb6372..b743e78890 100644 --- a/src/corelib/kernel/qmetatype.h +++ b/src/corelib/kernel/qmetatype.h @@ -1545,7 +1545,10 @@ namespace QtPrivate Q_CORE_EXPORT bool isBuiltinType(const QByteArray &type); } // namespace QtPrivate -template ::Value> +template ::Value ? QMetaType::PointerToQObject : + QtPrivate::IsGadgetHelper::Value ? QMetaType::IsGadget : + QtPrivate::IsQEnumHelper::Value ? QMetaType::IsEnumeration : 0> struct QMetaTypeIdQObject { enum { @@ -1725,8 +1728,9 @@ QT_DEPRECATED inline Q_DECL_CONSTEXPR int qRegisterMetaType(T *) #endif #endif +#ifndef QT_NO_QOBJECT template -struct QMetaTypeIdQObject +struct QMetaTypeIdQObject { enum { Defined = 1 @@ -1749,6 +1753,53 @@ struct QMetaTypeIdQObject } }; +template +struct QMetaTypeIdQObject +{ + enum { + Defined = 1 + }; + + static int qt_metatype_id() + { + static QBasicAtomicInt metatype_id = Q_BASIC_ATOMIC_INITIALIZER(0); + if (const int id = metatype_id.loadAcquire()) + return id; + const char * const cName = T::staticMetaObject.className(); + const int newId = qRegisterNormalizedMetaType( + cName, + reinterpret_cast(quintptr(-1))); + metatype_id.storeRelease(newId); + return newId; + } +}; + +template +struct QMetaTypeIdQObject +{ + enum { + Defined = 1 + }; + + static int qt_metatype_id() + { + static QBasicAtomicInt metatype_id = Q_BASIC_ATOMIC_INITIALIZER(0); + if (const int id = metatype_id.loadAcquire()) + return id; + const char *eName = qt_getEnumName(T()); + const char *cName = qt_getEnumMetaObject(T())->className(); + QByteArray typeName; + typeName.reserve(int(strlen(cName) + 2 + strlen(eName))); + typeName.append(cName).append("::").append(eName); + const int newId = qRegisterNormalizedMetaType( + typeName, + reinterpret_cast(quintptr(-1))); + metatype_id.storeRelease(newId); + return newId; + } +}; +#endif + #ifndef QT_NO_DATASTREAM template inline int qRegisterMetaTypeStreamOperators() -- cgit v1.2.3