From 45991b0f31b815afe749e679bb5dda66890bf5f7 Mon Sep 17 00:00:00 2001 From: Jan-Arve Saether Date: Wed, 18 Apr 2012 13:58:50 +0200 Subject: Compile on Windows. MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit The previous code was trying to sum one pointer with one string literal... Using QVarLengthArray should also potentially speed things up a bit, since it will avoid a malloc if className is small enough (less than 15 bytes). Change-Id: I41218babb3030e7e6f9c31fc77e4af1c209ae0a5 Reviewed-by: Jędrzej Nowacki --- src/corelib/kernel/qmetatype.h | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) (limited to 'src/corelib') diff --git a/src/corelib/kernel/qmetatype.h b/src/corelib/kernel/qmetatype.h index 9377ddd87e..2261eb0d12 100644 --- a/src/corelib/kernel/qmetatype.h +++ b/src/corelib/kernel/qmetatype.h @@ -45,6 +45,7 @@ #include #include #include +#include #include #ifndef QT_NO_QOBJECT #include @@ -598,9 +599,14 @@ struct QMetaTypeIdQObject static int qt_metatype_id() { static QBasicAtomicInt metatype_id = Q_BASIC_ATOMIC_INITIALIZER(0); - if (!metatype_id.load()) - metatype_id.storeRelease(qRegisterMetaType(QByteArray(T::staticMetaObject.className() + QByteArray("*")).constData(), + if (!metatype_id.load()) { + int len = strlen(T::staticMetaObject.className()); + QVarLengthArray classNameStar; + classNameStar.append(T::staticMetaObject.className(), len); + classNameStar.append("*\0", 2); + metatype_id.storeRelease(qRegisterMetaType(classNameStar.constData(), reinterpret_cast(quintptr(-1)))); + } return metatype_id.loadAcquire(); } }; -- cgit v1.2.3