diff options
author | Aaron Kennedy <aaron.kennedy@nokia.com> | 2010-02-11 04:52:34 (GMT) |
---|---|---|
committer | Aaron Kennedy <aaron.kennedy@nokia.com> | 2010-02-12 04:58:22 (GMT) |
commit | 1d2b1b31166e029e009f08877ef95f95e58a03a4 (patch) | |
tree | ae2ce1a9465f885ff6e24b583fe7330c74a9dd78 /src/declarative | |
parent | 4b740bdf8cbaaf97541a821c28bae075067343d3 (diff) | |
download | Qt-1d2b1b31166e029e009f08877ef95f95e58a03a4.zip Qt-1d2b1b31166e029e009f08877ef95f95e58a03a4.tar.gz Qt-1d2b1b31166e029e009f08877ef95f95e58a03a4.tar.bz2 |
Cleanup public QmlMetaType API
Remove some unnecessary methods from the QmlMetaType class
Diffstat (limited to 'src/declarative')
-rw-r--r-- | src/declarative/qml/qmlboundsignal.cpp | 2 | ||||
-rw-r--r-- | src/declarative/qml/qmlcompiledbindings.cpp | 4 | ||||
-rw-r--r-- | src/declarative/qml/qmlcontext.cpp | 31 | ||||
-rw-r--r-- | src/declarative/qml/qmlengine.cpp | 28 | ||||
-rw-r--r-- | src/declarative/qml/qmlengine_p.h | 3 | ||||
-rw-r--r-- | src/declarative/qml/qmlenginedebug.cpp | 4 | ||||
-rw-r--r-- | src/declarative/qml/qmlguard_p.h | 2 | ||||
-rw-r--r-- | src/declarative/qml/qmlmetaproperty.cpp | 23 | ||||
-rw-r--r-- | src/declarative/qml/qmlmetaproperty_p.h | 3 | ||||
-rw-r--r-- | src/declarative/qml/qmlmetatype.cpp | 148 | ||||
-rw-r--r-- | src/declarative/qml/qmlmetatype.h | 15 | ||||
-rw-r--r-- | src/declarative/util/qmllistaccessor.cpp | 7 |
12 files changed, 112 insertions, 158 deletions
diff --git a/src/declarative/qml/qmlboundsignal.cpp b/src/declarative/qml/qmlboundsignal.cpp index 110a56c..d42e7ba 100644 --- a/src/declarative/qml/qmlboundsignal.cpp +++ b/src/declarative/qml/qmlboundsignal.cpp @@ -214,7 +214,7 @@ QmlBoundSignalParameters::QmlBoundSignalParameters(const QMetaMethod &method, } QVariant::Type t = (QVariant::Type)QMetaType::type(type.constData()); - if (QmlMetaType::isObject(t)) { + if (QmlMetaType::isQObject(t)) { types[ii] = QMetaType::QObjectStar; QMetaPropertyBuilder prop = mob.addProperty(name, "QObject*"); prop.setWritable(false); diff --git a/src/declarative/qml/qmlcompiledbindings.cpp b/src/declarative/qml/qmlcompiledbindings.cpp index cdea96f..b5fbab9 100644 --- a/src/declarative/qml/qmlcompiledbindings.cpp +++ b/src/declarative/qml/qmlcompiledbindings.cpp @@ -1682,7 +1682,7 @@ bool QmlBindingCompilerPrivate::compile(QmlJS::AST::Node *node) } else if (type.type == destination->type) { } else { const QMetaObject *from = type.metaObject; - const QMetaObject *to = QmlMetaType::rawMetaObjectForType(destination->type); + const QMetaObject *to = engine->rawMetaObjectForType(destination->type); if (QmlMetaPropertyPrivate::canConvert(from, to)) type.type = destination->type; @@ -2420,7 +2420,7 @@ bool QmlBindingCompilerPrivate::fetch(Result &rv, const QMetaObject *mo, int reg fetch.fetch.exceptionId = exceptionId(node); rv.type = prop.userType(); - rv.metaObject = QmlMetaType::metaObjectForType(rv.type); + rv.metaObject = engine->metaObjectForType(rv.type); rv.reg = reg; if (rv.type == QMetaType::QString) { diff --git a/src/declarative/qml/qmlcontext.cpp b/src/declarative/qml/qmlcontext.cpp index 4c6dc6f..d9fc76b 100644 --- a/src/declarative/qml/qmlcontext.cpp +++ b/src/declarative/qml/qmlcontext.cpp @@ -383,23 +383,26 @@ void QmlContext::setContextProperty(const QString &name, const QVariant &value) if (d->notifyIndex == -1) d->notifyIndex = this->metaObject()->methodCount(); - if (d->engine && QmlEnginePrivate::get(d->engine)->isObject(value.userType())) { - QObject *o = *(QObject **)value.constData(); - setContextProperty(name, o); - } else { + if (d->engine) { + bool ok; + QObject *o = QmlEnginePrivate::get(d->engine)->toQObject(value, &ok); + if (ok) { + setContextProperty(name, o); + return; + } + } - if (!d->propertyNames) d->propertyNames = new QmlIntegerCache(d->engine); + if (!d->propertyNames) d->propertyNames = new QmlIntegerCache(d->engine); - int idx = d->propertyNames->value(name); - if (idx == -1) { - d->propertyNames->add(name, d->idValueCount + d->propertyValues.count()); - d->propertyValues.append(value); + int idx = d->propertyNames->value(name); + if (idx == -1) { + d->propertyNames->add(name, d->idValueCount + d->propertyValues.count()); + d->propertyValues.append(value); - d->refreshExpressions(); - } else { - d->propertyValues[idx] = value; - QMetaObject::activate(this, idx + d->notifyIndex, 0); - } + d->refreshExpressions(); + } else { + d->propertyValues[idx] = value; + QMetaObject::activate(this, idx + d->notifyIndex, 0); } } diff --git a/src/declarative/qml/qmlengine.cpp b/src/declarative/qml/qmlengine.cpp index 372821e..cdbe5f3 100644 --- a/src/declarative/qml/qmlengine.cpp +++ b/src/declarative/qml/qmlengine.cpp @@ -1085,9 +1085,10 @@ QScriptValue QmlEnginePrivate::tint(QScriptContext *ctxt, QScriptEngine *engine) QScriptValue QmlEnginePrivate::scriptValueFromVariant(const QVariant &val) { - if (QmlMetaType::isObject(val.userType())) { - QObject *rv = *(QObject **)val.constData(); - return objectClass->newQObject(rv); + bool objOk; + QObject *obj = QmlMetaType::toQObject(val, &objOk); + if (objOk) { + return objectClass->newQObject(obj); } else { return qScriptValueFromValue(&scriptEngine, val); } @@ -1598,9 +1599,20 @@ bool QmlEnginePrivate::isQmlList(int t) const return m_qmlLists.contains(t) || QmlMetaType::isQmlList(t); } -bool QmlEnginePrivate::isObject(int t) +bool QmlEnginePrivate::isQObject(int t) { - return m_compositeTypes.contains(t) || QmlMetaType::isObject(t); + return m_compositeTypes.contains(t) || QmlMetaType::isQObject(t); +} + +QObject *QmlEnginePrivate::toQObject(const QVariant &v, bool *ok) const +{ + int t = v.userType(); + if (m_compositeTypes.contains(t)) { + if (ok) *ok = true; + return *(QObject **)(v.constData()); + } else { + return QmlMetaType::toQObject(v, ok); + } } int QmlEnginePrivate::qmlListType(int t) const @@ -1628,7 +1640,8 @@ const QMetaObject *QmlEnginePrivate::rawMetaObjectForType(int t) const if (iter != m_compositeTypes.end()) { return (*iter)->root; } else { - return QmlMetaType::rawMetaObjectForType(t); + QmlType *type = QmlMetaType::qmlType(t); + return type?type->baseMetaObject():0; } } @@ -1638,7 +1651,8 @@ const QMetaObject *QmlEnginePrivate::metaObjectForType(int t) const if (iter != m_compositeTypes.end()) { return (*iter)->root; } else { - return QmlMetaType::metaObjectForType(t); + QmlType *type = QmlMetaType::qmlType(t); + return type?type->metaObject():0; } } diff --git a/src/declarative/qml/qmlengine_p.h b/src/declarative/qml/qmlengine_p.h index 8349090..13ed5ef 100644 --- a/src/declarative/qml/qmlengine_p.h +++ b/src/declarative/qml/qmlengine_p.h @@ -268,7 +268,8 @@ public: void registerCompositeType(QmlCompiledData *); bool isQmlList(int) const; - bool isObject(int); + bool isQObject(int); + QObject *toQObject(const QVariant &, bool *ok = 0) const; int qmlListType(int) const; QmlMetaType::TypeCategory typeCategory(int) const; const QMetaObject *rawMetaObjectForType(int) const; diff --git a/src/declarative/qml/qmlenginedebug.cpp b/src/declarative/qml/qmlenginedebug.cpp index 2abd6e6..b0c1ec9 100644 --- a/src/declarative/qml/qmlenginedebug.cpp +++ b/src/declarative/qml/qmlenginedebug.cpp @@ -117,7 +117,7 @@ QmlEngineDebugServer::propertyData(QObject *obj, int propIdx) if (QVariant::Type(prop.userType()) < QVariant::UserType) { rv.type = QmlObjectProperty::Basic; - } else if (QmlMetaType::isObject(prop.userType())) { + } else if (QmlMetaType::isQObject(prop.userType())) { rv.type = QmlObjectProperty::Object; } else if (QmlMetaType::isList(prop.userType()) || QmlMetaType::isQmlList(prop.userType())) { @@ -140,7 +140,7 @@ QVariant QmlEngineDebugServer::valueContents(const QVariant &value) const for (int i=0; i<count; i++) contents << valueContents(QmlMetaType::listAt(value, i)); return contents; - } else if (QmlMetaType::isObject(userType)) { + } else if (QmlMetaType::isQObject(userType)) { QObject *o = QmlMetaType::toQObject(value); if (o) { QString name = o->objectName(); diff --git a/src/declarative/qml/qmlguard_p.h b/src/declarative/qml/qmlguard_p.h index 42a4406..1e55bcb 100644 --- a/src/declarative/qml/qmlguard_p.h +++ b/src/declarative/qml/qmlguard_p.h @@ -94,6 +94,8 @@ private: inline void remGuard(); }; +Q_DECLARE_METATYPE(QmlGuard<QObject>); + QT_END_NAMESPACE #include "qmldeclarativedata_p.h" diff --git a/src/declarative/qml/qmlmetaproperty.cpp b/src/declarative/qml/qmlmetaproperty.cpp index 09c936e..f23a50a 100644 --- a/src/declarative/qml/qmlmetaproperty.cpp +++ b/src/declarative/qml/qmlmetaproperty.cpp @@ -852,17 +852,13 @@ bool QmlMetaPropertyPrivate::write(QObject *object, const QmlPropertyCache::Data } else if (property.flags & QmlPropertyCache::Data::IsQObjectDerived) { - const QMetaObject *valMo = 0; - if (enginePriv) valMo = enginePriv->rawMetaObjectForType(value.userType()); - else valMo = QmlMetaType::rawMetaObjectForType(value.userType()); + const QMetaObject *valMo = rawMetaObjectForType(enginePriv, value.userType()); if (!valMo) return false; QObject *o = *(QObject **)value.constData(); - const QMetaObject *propMo = 0; - if (enginePriv) propMo = enginePriv->rawMetaObjectForType(t); - else propMo = QmlMetaType::rawMetaObjectForType(t); + const QMetaObject *propMo = rawMetaObjectForType(enginePriv, t); if (o) valMo = o->metaObject(); @@ -892,7 +888,7 @@ bool QmlMetaPropertyPrivate::write(QObject *object, const QmlPropertyCache::Data QVariant listVar = prop.read(object); QmlMetaType::clear(listVar); for (int ii = 0; ii < list.count(); ++ii) { - QVariant v = QmlMetaType::fromObject(list.at(ii), listType); + QVariant v = QmlMetaType::qmlType(listType)->fromObject(list.at(ii)); QmlMetaType::append(listVar, v); } @@ -913,8 +909,7 @@ bool QmlMetaPropertyPrivate::write(QObject *object, const QmlPropertyCache::Data int type = li->type(); if (QObject *obj = QmlMetaType::toQObject(value)) { - const QMetaObject *mo = - QmlMetaType::rawMetaObjectForType(type); + const QMetaObject *mo = rawMetaObjectForType(enginePriv, type); const QMetaObject *objMo = obj->metaObject(); bool found = false; @@ -966,6 +961,16 @@ bool QmlMetaPropertyPrivate::write(QObject *object, const QmlPropertyCache::Data return true; } +const QMetaObject *QmlMetaPropertyPrivate::rawMetaObjectForType(QmlEnginePrivate *engine, int userType) +{ + if (engine) { + return engine->rawMetaObjectForType(userType); + } else { + QmlType *type = QmlMetaType::qmlType(userType); + return type?type->baseMetaObject():0; + } +} + /*! Set the property value to \a value. */ diff --git a/src/declarative/qml/qmlmetaproperty_p.h b/src/declarative/qml/qmlmetaproperty_p.h index 97b5208..90b443e 100644 --- a/src/declarative/qml/qmlmetaproperty_p.h +++ b/src/declarative/qml/qmlmetaproperty_p.h @@ -63,6 +63,7 @@ QT_BEGIN_NAMESPACE class QmlContext; +class QmlEnginePrivate; class QmlMetaPropertyPrivate { public: @@ -102,6 +103,8 @@ public: QVariant readValueProperty(); bool writeValueProperty(const QVariant &, QmlMetaProperty::WriteFlags); + + static const QMetaObject *rawMetaObjectForType(QmlEnginePrivate *, int); static bool writeEnumProperty(const QMetaProperty &prop, int idx, QObject *object, const QVariant &value, int flags); static bool write(QObject *, const QmlPropertyCache::Data &, const QVariant &, QmlContext *, QmlMetaProperty::WriteFlags flags = 0); diff --git a/src/declarative/qml/qmlmetatype.cpp b/src/declarative/qml/qmlmetatype.cpp index d9c007d..e66f600 100644 --- a/src/declarative/qml/qmlmetatype.cpp +++ b/src/declarative/qml/qmlmetatype.cpp @@ -43,6 +43,7 @@ #include "qmlproxymetaobject_p.h" #include "qmlcustomparser_p.h" +#include "qmlguard_p.h" #include <QtCore/qdebug.h> #include <QtCore/qstringlist.h> @@ -490,48 +491,26 @@ int QmlMetaType::registerType(const QmlPrivate::MetaTypeIds &id, QmlPrivate::Fun return index; } -int QmlMetaType::qmlParserStatusCast(int userType) +QObject *QmlMetaType::toQObject(const QVariant &v, bool *ok) { - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - QmlType *type = data->idToType.value(userType); - if (type && type->typeId() == userType) - return type->parserStatusCast(); - else - return -1; -} + if (!isQObject(v.userType())) { + if (ok) *ok = false; + return 0; + } -int QmlMetaType::qmlPropertyValueSourceCast(int userType) -{ - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - QmlType *type = data->idToType.value(userType); - if (type && type->typeId() == userType) - return type->propertyValueSourceCast(); - else - return -1; -} + if (ok) *ok = true; -int QmlMetaType::qmlPropertyValueInterceptorCast(int userType) -{ - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - QmlType *type = data->idToType.value(userType); - if (type && type->typeId() == userType) - return type->propertyValueInterceptorCast(); - else - return -1; + return *(QObject **)v.constData(); } -QObject *QmlMetaType::toQObject(const QVariant &v) +bool QmlMetaType::isQObject(int userType) { - if (!isObject(v.userType())) - return 0; + if (userType == QMetaType::QObjectStar) + return true; - // NOTE: This assumes a cast to QObject does not alter the - // object pointer - QObject *rv = *(QObject **)v.constData(); - return rv; + QReadLocker lock(metaTypeDataLock()); + QmlMetaTypeData *data = metaTypeData(); + return userType >= 0 && userType < data->objects.size() && data->objects.testBit(userType); } /* @@ -593,46 +572,6 @@ bool QmlMetaType::append(const QVariant &list, const QVariant &item) } } -QVariant QmlMetaType::fromObject(QObject *obj, int typeId) -{ - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - - QmlType *type = data->idToType.value(typeId); - if (type && type->typeId() == typeId) - return type->fromObject(obj); - else - return QVariant(); -} - -const QMetaObject *QmlMetaType::rawMetaObjectForType(int id) -{ - if (id == QMetaType::QObjectStar) - return &QObject::staticMetaObject; - - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - - QmlType *type = data->idToType.value(id); - if (type && type->typeId() == id) - return type->baseMetaObject(); - else - return 0; -} - -const QMetaObject *QmlMetaType::metaObjectForType(int id) -{ - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - QmlType *type = data->idToType.value(id); - lock.unlock(); - - if (type && type->typeId() == id) - return type->metaObject(); - else - return 0; -} - int QmlMetaType::attachedPropertiesFuncId(const QMetaObject *mo) { QReadLocker lock(metaTypeDataLock()); @@ -706,29 +645,6 @@ QMetaMethod QmlMetaType::defaultMethod(QObject *obj) return defaultMethod(metaObject); } -/*! - */ -QMetaProperty QmlMetaType::property(QObject *obj, const QByteArray &bname) -{ - return property(obj, bname.constData()); -} - -/*! - */ -QMetaProperty QmlMetaType::property(QObject *obj, const char *name) -{ - if (!obj) - return QMetaProperty(); - - const QMetaObject *metaObject = obj->metaObject(); - - int idx = metaObject->indexOfProperty(name); - if (-1 == idx) - return QMetaProperty(); - - return metaObject->property(idx); -} - QmlMetaType::TypeCategory QmlMetaType::typeCategory(int userType) { if (userType < 0) @@ -748,16 +664,6 @@ QmlMetaType::TypeCategory QmlMetaType::typeCategory(int userType) return Unknown; } -bool QmlMetaType::isObject(int userType) -{ - if (userType == QMetaType::QObjectStar) - return true; - - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - return userType >= 0 && userType < data->objects.size() && data->objects.testBit(userType); -} - bool QmlMetaType::isInterface(int userType) { QReadLocker lock(metaTypeDataLock()); @@ -884,6 +790,10 @@ QmlType *QmlMetaType::qmlType(const QByteArray &name, int version_major, int ver return 0; } +/*! + Returns the type (if any) that corresponds to the \a metaObject. Returns null if no + type is registered. +*/ QmlType *QmlMetaType::qmlType(const QMetaObject *metaObject) { QReadLocker lock(metaTypeDataLock()); @@ -892,6 +802,25 @@ QmlType *QmlMetaType::qmlType(const QMetaObject *metaObject) return data->metaObjectToType.value(metaObject); } +/*! + Returns the type (if any) that corresponds to the QVariant::Type \a userType. + Returns null if no type is registered. +*/ +QmlType *QmlMetaType::qmlType(int userType) +{ + QReadLocker lock(metaTypeDataLock()); + QmlMetaTypeData *data = metaTypeData(); + + QmlType *type = data->idToType.value(userType); + if (type && type->typeId() == userType) + return type; + else + return 0; +} + +/*! + Returns the list of registered QML type names. +*/ QList<QByteArray> QmlMetaType::qmlTypeNames() { QReadLocker lock(metaTypeDataLock()); @@ -900,6 +829,9 @@ QList<QByteArray> QmlMetaType::qmlTypeNames() return data->nameToType.keys(); } +/*! + Returns the list of registered QML types. +*/ QList<QmlType*> QmlMetaType::qmlTypes() { QReadLocker lock(metaTypeDataLock()); diff --git a/src/declarative/qml/qmlmetatype.h b/src/declarative/qml/qmlmetatype.h index e0c65c5..45ec11d 100644 --- a/src/declarative/qml/qmlmetatype.h +++ b/src/declarative/qml/qmlmetatype.h @@ -72,23 +72,19 @@ public: static QmlType *qmlType(const QByteArray &, int, int); static QmlType *qmlType(const QMetaObject *); + static QmlType *qmlType(int); static QMetaProperty defaultProperty(const QMetaObject *); static QMetaProperty defaultProperty(QObject *); static QMetaMethod defaultMethod(const QMetaObject *); static QMetaMethod defaultMethod(QObject *); - static QMetaProperty property(QObject *, const QByteArray &); - static QMetaProperty property(QObject *, const char *); - static QObject *toQObject(const QVariant &); - static int qmlParserStatusCast(int); - static int qmlPropertyValueSourceCast(int); - static int qmlPropertyValueInterceptorCast(int); + + static bool isQObject(int); + static QObject *toQObject(const QVariant &, bool *ok = 0); + static int listType(int); static bool clear(const QVariant &); static bool append(const QVariant &, const QVariant &); - static QVariant fromObject(QObject *, int type); - static const QMetaObject *rawMetaObjectForType(int); - static const QMetaObject *metaObjectForType(int); static int attachedPropertiesFuncId(const QMetaObject *); static QmlAttachedPropertiesFunc attachedPropertiesFuncById(int); @@ -97,7 +93,6 @@ public: static bool isInterface(int); static const char *interfaceIId(int); - static bool isObject(int); static bool isList(int); static bool isList(const QVariant &); static bool isQmlList(int); diff --git a/src/declarative/util/qmllistaccessor.cpp b/src/declarative/util/qmllistaccessor.cpp index 00b8220..6658949 100644 --- a/src/declarative/util/qmllistaccessor.cpp +++ b/src/declarative/util/qmllistaccessor.cpp @@ -79,10 +79,9 @@ void QmlListAccessor::setList(const QVariant &v, QmlEngine *engine) m_type = VariantList; } else if (d.canConvert(QVariant::Int)) { m_type = Integer; - } else if ((!enginePrivate && QmlMetaType::isObject(d.userType())) || - (enginePrivate && enginePrivate->isObject(d.userType()))) { - QObject *data = 0; - data = *(QObject **)v.constData(); + } else if ((!enginePrivate && QmlMetaType::isQObject(d.userType())) || + (enginePrivate && enginePrivate->isQObject(d.userType()))) { + QObject *data = enginePrivate?enginePrivate->toQObject(v):QmlMetaType::toQObject(v); d = QVariant::fromValue(data); m_type = Instance; } else if ((!enginePrivate && QmlMetaType::isQmlList(d.userType())) || |