From: Kent Hansen Date: Wed, 23 May 2012 21:04:52 +0000 (+0200) Subject: Simplify method name extraction in property cache X-Git-Url: http://git.silmor.de/gitweb/?a=commitdiff_plain;h=98105aac87a4cab12118cfbda77f0907c6d8f86c;p=konrad%2Fqtdeclarative.git Simplify method name extraction in property cache All of Qt is now generating r7 meta-objects, so the compat support can be removed. Change-Id: Ib8e697b86a0ae8a68209fe661a8043505838f631 Reviewed-by: Aaron Kennedy --- diff --git a/src/qml/qml/qqmlpropertycache.cpp b/src/qml/qml/qqmlpropertycache.cpp index 86c0d71..8167280 100644 --- a/src/qml/qml/qqmlpropertycache.cpp +++ b/src/qml/qml/qqmlpropertycache.cpp @@ -658,18 +658,12 @@ void QQmlPropertyCache::append(QQmlEngine *engine, const QMetaObject *metaObject continue; // Extract method name - const char *signature; - if (QMetaObjectPrivate::get(metaObject)->revision >= 7) { - // Safe to use the raw name pointer - signature = m.name().constData(); - } else { - // Safe to use the raw signature pointer - signature = m.methodSignature().constData(); - } - const char *cptr = signature; + // It's safe to keep the raw name pointer + Q_ASSERT(QMetaObjectPrivate::get(metaObject)->revision >= 7); + const char *rawName = m.name().constData(); + const char *cptr = rawName; char utf8 = 0; - while (*cptr && *cptr != '(') { - Q_ASSERT(*cptr != 0); + while (*cptr) { utf8 |= *cptr & 0x80; ++cptr; } @@ -699,7 +693,7 @@ void QQmlPropertyCache::append(QQmlEngine *engine, const QMetaObject *metaObject QQmlPropertyData *old = 0; if (utf8) { - QHashedString methodName(QString::fromUtf8(signature, cptr - signature)); + QHashedString methodName(QString::fromUtf8(rawName, cptr - rawName)); if (QQmlPropertyData **it = stringCache.value(methodName)) old = *it; stringCache.insert(methodName, data); @@ -710,7 +704,7 @@ void QQmlPropertyCache::append(QQmlEngine *engine, const QMetaObject *metaObject ++signalHandlerIndex; } } else { - QHashedCStringRef methodName(signature, cptr - signature); + QHashedCStringRef methodName(rawName, cptr - rawName); if (QQmlPropertyData **it = stringCache.value(methodName)) old = *it; stringCache.insert(methodName, data); @@ -721,9 +715,9 @@ void QQmlPropertyCache::append(QQmlEngine *engine, const QMetaObject *metaObject QVarLengthArray str(length+3); str[0] = 'o'; str[1] = 'n'; - str[2] = toupper(signature[0]); + str[2] = toupper(rawName[0]); if (length > 1) - memcpy(&str[3], &signature[1], length - 1); + memcpy(&str[3], &rawName[1], length - 1); str[length + 2] = '\0'; QHashedString on(QString::fromLatin1(str.data()));