diff options
author | Aaron Kennedy <aaron.kennedy@nokia.com> | 2010-10-14 09:00:02 (GMT) |
---|---|---|
committer | Aaron Kennedy <aaron.kennedy@nokia.com> | 2010-10-14 09:00:02 (GMT) |
commit | 0a0842ce6bc6a2d2731092c50c69a5ff3dc9b010 (patch) | |
tree | 8e0c633f2809d7e0b40aec3e5c140306d657153a /src | |
parent | c407d79f79c67f2f2bb84efc93061fd57fe4cf54 (diff) | |
download | Qt-0a0842ce6bc6a2d2731092c50c69a5ff3dc9b010.zip Qt-0a0842ce6bc6a2d2731092c50c69a5ff3dc9b010.tar.gz Qt-0a0842ce6bc6a2d2731092c50c69a5ff3dc9b010.tar.bz2 |
Fix potential memory corruption in QDeclarativePropertyCache
Task-number: QTBUG-14449
Diffstat (limited to 'src')
-rw-r--r-- | src/declarative/qml/qdeclarativepropertycache.cpp | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/src/declarative/qml/qdeclarativepropertycache.cpp b/src/declarative/qml/qdeclarativepropertycache.cpp index 82fa98f..259e492 100644 --- a/src/declarative/qml/qdeclarativepropertycache.cpp +++ b/src/declarative/qml/qdeclarativepropertycache.cpp @@ -140,6 +140,10 @@ void QDeclarativePropertyCache::clear() if (indexCache.at(ii)) indexCache.at(ii)->release(); } + for (int ii = 0; ii < methodIndexCache.count(); ++ii) { + if (methodIndexCache.at(ii)) methodIndexCache.at(ii)->release(); + } + for (StringCache::ConstIterator iter = stringCache.begin(); iter != stringCache.end(); ++iter) (*iter)->release(); @@ -234,12 +238,11 @@ void QDeclarativePropertyCache::append(QDeclarativeEngine *engine, const QMetaOb RData *data = new RData; data->identifier = enginePriv->objectClass->createPersistentIdentifier(propName); + indexCache[ii] = data; data->load(p, engine); data->flags |= propertyFlags; - indexCache[ii] = data; - if (stringCache.contains(propName)) { stringCache[propName]->release(); identifierCache[data->identifier.identifier]->release(); @@ -268,6 +271,7 @@ void QDeclarativePropertyCache::append(QDeclarativeEngine *engine, const QMetaOb RData *data = new RData; data->identifier = enginePriv->objectClass->createPersistentIdentifier(methodName); + methodIndexCache[ii] = data; data->load(m); if (m.methodType() == QMetaMethod::Slot || m.methodType() == QMetaMethod::Method) @@ -280,11 +284,10 @@ void QDeclarativePropertyCache::append(QDeclarativeEngine *engine, const QMetaOb identifierCache[data->identifier.identifier]->release(); } - methodIndexCache[ii] = data; - stringCache.insert(methodName, data); identifierCache.insert(data->identifier.identifier, data); data->addref(); + data->addref(); } } |