From: Jan-Arve Saether Date: Wed, 18 Apr 2012 11:58:50 +0000 (+0200) Subject: Compile on Windows. X-Git-Tag: 071012110112~1498 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=45991b0f31b815afe749e679bb5dda66890bf5f7;p=profile%2Fivi%2Fqtbase.git Compile on Windows. 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 --- diff --git a/src/corelib/kernel/qmetatype.h b/src/corelib/kernel/qmetatype.h index 9377ddd..2261eb0 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(); } };