diff options
author | Michael Brasser <michael.brasser@nokia.com> | 2009-08-18 00:23:21 (GMT) |
---|---|---|
committer | Michael Brasser <michael.brasser@nokia.com> | 2009-08-18 00:23:21 (GMT) |
commit | 39a2e72700aa481fefc7df7fa64d8dc8c1670d2e (patch) | |
tree | bd3abb779a0e934c9d1905532d1019613703cfd5 /src/declarative | |
parent | c9f4ad424949085209acda6cff07babbe8d29001 (diff) | |
parent | 41335c52ef2844589030cddb4773c68cf38331af (diff) | |
download | Qt-39a2e72700aa481fefc7df7fa64d8dc8c1670d2e.zip Qt-39a2e72700aa481fefc7df7fa64d8dc8c1670d2e.tar.gz Qt-39a2e72700aa481fefc7df7fa64d8dc8c1670d2e.tar.bz2 |
Merge branch 'kinetic-declarativeui' of git@scm.dev.nokia.troll.no:qt/kinetic into kinetic-declarativeui
Diffstat (limited to 'src/declarative')
-rw-r--r-- | src/declarative/fx/qfxborderimage.cpp | 12 | ||||
-rw-r--r-- | src/declarative/fx/qfxborderimage.h | 7 | ||||
-rw-r--r-- | src/declarative/fx/qfximage.h | 2 | ||||
-rw-r--r-- | src/declarative/fx/qfxitem.cpp | 2 | ||||
-rw-r--r-- | src/declarative/qml/qmlcompiler.cpp | 15 | ||||
-rw-r--r-- | src/declarative/qml/qmlcompiler_p.h | 1 | ||||
-rw-r--r-- | src/declarative/qml/qmlcompositetypemanager.cpp | 4 | ||||
-rw-r--r-- | src/declarative/qml/qmldom.cpp | 2 | ||||
-rw-r--r-- | src/declarative/qml/qmlengine.cpp | 34 | ||||
-rw-r--r-- | src/declarative/qml/qmlengine_p.h | 2 | ||||
-rw-r--r-- | src/declarative/qml/qmlmetaproperty.cpp | 10 | ||||
-rw-r--r-- | src/declarative/qml/qmlmetatype.cpp | 158 | ||||
-rw-r--r-- | src/declarative/qml/qmlmetatype.h | 17 |
13 files changed, 100 insertions, 166 deletions
diff --git a/src/declarative/fx/qfxborderimage.cpp b/src/declarative/fx/qfxborderimage.cpp index f8c79a6..67b05fd 100644 --- a/src/declarative/fx/qfxborderimage.cpp +++ b/src/declarative/fx/qfxborderimage.cpp @@ -284,7 +284,11 @@ QFxBorderImage::TileMode QFxBorderImage::horizontalTileMode() const void QFxBorderImage::setHorizontalTileMode(TileMode t) { Q_D(QFxBorderImage); - d->horizontalTileMode = t; + if (t != d->horizontalTileMode) { + d->horizontalTileMode = t; + emit tileModeChanged(); + update(); + } } QFxBorderImage::TileMode QFxBorderImage::verticalTileMode() const @@ -296,7 +300,11 @@ QFxBorderImage::TileMode QFxBorderImage::verticalTileMode() const void QFxBorderImage::setVerticalTileMode(TileMode t) { Q_D(QFxBorderImage); - d->verticalTileMode = t; + if (t != d->verticalTileMode) { + d->verticalTileMode = t; + emit tileModeChanged(); + update(); + } } void QFxBorderImage::setGridScaledImage(const QFxGridScaledImage& sci) diff --git a/src/declarative/fx/qfxborderimage.h b/src/declarative/fx/qfxborderimage.h index b0ec3bc..c6885fb 100644 --- a/src/declarative/fx/qfxborderimage.h +++ b/src/declarative/fx/qfxborderimage.h @@ -59,8 +59,8 @@ class Q_DECLARATIVE_EXPORT QFxBorderImage : public QFxImageBase Q_ENUMS(TileMode) Q_PROPERTY(QFxScaleGrid *border READ border CONSTANT) - Q_PROPERTY(TileMode horizontalTileMode READ horizontalTileMode WRITE setHorizontalTileMode) - Q_PROPERTY(TileMode verticalTileMode READ verticalTileMode WRITE setVerticalTileMode) + Q_PROPERTY(TileMode horizontalTileMode READ horizontalTileMode WRITE setHorizontalTileMode NOTIFY tileModeChanged) + Q_PROPERTY(TileMode verticalTileMode READ verticalTileMode WRITE setVerticalTileMode NOTIFY tileModeChanged) public: QFxBorderImage(QFxItem *parent=0); @@ -79,6 +79,9 @@ public: void paint(QPainter *, const QStyleOptionGraphicsItem *, QWidget *); void setSource(const QUrl &url); +signals: + void tileModeChanged(); + protected: QFxBorderImage(QFxBorderImagePrivate &dd, QFxItem *parent); diff --git a/src/declarative/fx/qfximage.h b/src/declarative/fx/qfximage.h index c8e21ea..4f46495 100644 --- a/src/declarative/fx/qfximage.h +++ b/src/declarative/fx/qfximage.h @@ -57,7 +57,7 @@ class Q_DECLARATIVE_EXPORT QFxImage : public QFxImageBase Q_ENUMS(FillMode) Q_PROPERTY(QPixmap pixmap READ pixmap WRITE setPixmap DESIGNABLE false) - Q_PROPERTY(FillMode fillMode READ fillMode WRITE setFillMode NOTIFY fillModeChanged); + Q_PROPERTY(FillMode fillMode READ fillMode WRITE setFillMode NOTIFY fillModeChanged) public: QFxImage(QFxItem *parent=0); diff --git a/src/declarative/fx/qfxitem.cpp b/src/declarative/fx/qfxitem.cpp index f5f502c..572fcc7 100644 --- a/src/declarative/fx/qfxitem.cpp +++ b/src/declarative/fx/qfxitem.cpp @@ -658,6 +658,7 @@ signals: void downPressed(QFxKeyEvent *event); void asteriskPressed(QFxKeyEvent *event); + void numberSignPressed(QFxKeyEvent *event); void escapePressed(QFxKeyEvent *event); void returnPressed(QFxKeyEvent *event); void enterPressed(QFxKeyEvent *event); @@ -713,6 +714,7 @@ const QFxKeysAttached::SigMap QFxKeysAttached::sigMap[] = { { Qt::Key_Up, "upPressed" }, { Qt::Key_Down, "downPressed" }, { Qt::Key_Asterisk, "asteriskPressed" }, + { Qt::Key_NumberSign, "numberSignPressed" }, { Qt::Key_Escape, "escapePressed" }, { Qt::Key_Return, "returnPressed" }, { Qt::Key_Enter, "enterPressed" }, diff --git a/src/declarative/qml/qmlcompiler.cpp b/src/declarative/qml/qmlcompiler.cpp index caf78e8..dea41ab 100644 --- a/src/declarative/qml/qmlcompiler.cpp +++ b/src/declarative/qml/qmlcompiler.cpp @@ -576,6 +576,7 @@ bool QmlCompiler::compile(QmlEngine *engine, Q_ASSERT(root); this->engine = engine; + this->unit = unit; compileTree(root); if (!isError()) { @@ -1036,7 +1037,7 @@ bool QmlCompiler::buildSubObject(Object *obj, const BindingContext &ctxt) int QmlCompiler::componentTypeRef() { - QmlType *t = QmlMetaType::qmlType("Qt/4.6/Component"); + QmlType *t = QmlMetaType::qmlType("Qt/Component",4,6); for (int ii = output->types.count() - 1; ii >= 0; --ii) { if (output->types.at(ii).type == t) return ii; @@ -1148,7 +1149,9 @@ bool QmlCompiler::buildProperty(QmlParser::Property *prop, COMPILE_EXCEPTION(prop, "Attached properties cannot be used here"); } - QmlType *type = QmlMetaType::qmlType("Qt/4.6/"+prop->name); // XXX Should not hard-code namespace + QmlType *type = 0; + QmlEnginePrivate::get(engine)->resolveType(unit->imports, prop->name, &type, 0); + // 0: attached properties not supported in QML component files if (!type || !type->attachedPropertiesType()) COMPILE_EXCEPTION(prop, "Non-existant attached object"); @@ -1156,6 +1159,8 @@ bool QmlCompiler::buildProperty(QmlParser::Property *prop, if (!prop->value) COMPILE_EXCEPTION(prop, "Invalid attached object assignment"); + Q_ASSERT(type->attachedPropertiesFunction()); + prop->index = type->index(); prop->value->metatype = type->attachedPropertiesType(); } else { // Setup regular property data @@ -1428,10 +1433,8 @@ bool QmlCompiler::buildAttachedProperty(QmlParser::Property *prop, const BindingContext &ctxt) { Q_ASSERT(prop->value); - int id = QmlMetaType::attachedPropertiesFuncId(prop->name); - Q_ASSERT(id != -1); // This is checked in compileProperty() + Q_ASSERT(prop->index != -1); // This is set in buildProperty() - prop->index = id; obj->addAttachedProperty(prop); COMPILE_CHECK(buildSubObject(prop->value, ctxt.incr())); @@ -1715,7 +1718,7 @@ bool QmlCompiler::buildPropertyObjectAssignment(QmlParser::Property *prop, QmlParser::Object *root = v->object; QmlParser::Object *component = new QmlParser::Object; component->type = componentTypeRef(); - component->typeName = "Qt/4.6/Component"; + component->typeName = "Qt/Component"; component->metatype = &QmlComponent::staticMetaObject; component->location = root->location; QmlParser::Value *componentValue = new QmlParser::Value; diff --git a/src/declarative/qml/qmlcompiler_p.h b/src/declarative/qml/qmlcompiler_p.h index 4f56169..58279c4 100644 --- a/src/declarative/qml/qmlcompiler_p.h +++ b/src/declarative/qml/qmlcompiler_p.h @@ -267,6 +267,7 @@ private: QList<QmlError> exceptions; QmlCompiledData *output; QmlEngine *engine; + QmlCompositeTypeData *unit; }; QT_END_NAMESPACE diff --git a/src/declarative/qml/qmlcompositetypemanager.cpp b/src/declarative/qml/qmlcompositetypemanager.cpp index b0a8642..97391e6 100644 --- a/src/declarative/qml/qmlcompositetypemanager.cpp +++ b/src/declarative/qml/qmlcompositetypemanager.cpp @@ -247,7 +247,9 @@ void QmlCompositeTypeManager::setData(QmlCompositeTypeData *unit, unit->errors << unit->data.errors(); } else { foreach (QmlScriptParser::Import imp, unit->data.imports()) { - if (!QmlEnginePrivate::get(engine)->addToImport(&unit->imports, imp.uri, imp.qualifier, imp.version, imp.type)) { + int dot = imp.version.indexOf(QLatin1Char('.')); + if (dot < 0) dot = imp.version.length(); + if (!QmlEnginePrivate::get(engine)->addToImport(&unit->imports, imp.uri, imp.qualifier, imp.version.left(dot).toInt(), imp.version.mid(dot+1).toInt(), imp.type)) { QmlError error; error.setUrl(url); error.setDescription(tr("Import %1 unavailable").arg(imp.uri)); diff --git a/src/declarative/qml/qmldom.cpp b/src/declarative/qml/qmldom.cpp index c6b7192..cdd5eef 100644 --- a/src/declarative/qml/qmldom.cpp +++ b/src/declarative/qml/qmldom.cpp @@ -967,7 +967,7 @@ QByteArray QmlDomObject::customTypeData() const bool QmlDomObject::isComponent() const { return d->isVirtualComponent || - (d->object && d->object->typeName == "Qt/4.6/Component"); + (d->object && d->object->typeName == "Qt/Component"); } /*! diff --git a/src/declarative/qml/qmlengine.cpp b/src/declarative/qml/qmlengine.cpp index 68f0833..6756642 100644 --- a/src/declarative/qml/qmlengine.cpp +++ b/src/declarative/qml/qmlengine.cpp @@ -1041,19 +1041,22 @@ void QmlObjectScriptClass::setProperty(QScriptValue &object, struct QmlEnginePrivate::ImportedNamespace { QStringList urls; - QStringList versions; + QList<int> majversions; + QList<int> minversions; QList<bool> isLibrary; QUrl find(const QString& type) const { for (int i=0; i<urls.count(); ++i) { QUrl url = QUrl(urls.at(i) + QLatin1String("/") + type + QLatin1String(".qml")); - QString version = versions.at(i); + int vmaj = majversions.at(i); + int vmin = minversions.at(i); // XXX search non-files too! (eg. zip files, see QT-524) QFileInfo f(url.toLocalFile()); if (f.exists()) { bool ok=true; - if (!version.isEmpty()) { + if (vmaj || vmin) { + QString version = QString::number(vmaj) + QLatin1String(".") + QString::number(vmin); ok=false; // Check version file - XXX cache these in QmlEngine! QFile qmldir(urls.at(i)+QLatin1String("/qmldir")); @@ -1086,14 +1089,12 @@ struct QmlEnginePrivate::ImportedNamespace { QmlType *findBuiltin(const QByteArray& type, QByteArray* found=0) const { for (int i=0; i<urls.count(); ++i) { - QByteArray version = versions.at(i).toLatin1(); + int vmaj = majversions.at(i); + int vmin = minversions.at(i); QByteArray qt = urls.at(i).toLatin1(); - if (version.isEmpty()) - qt += "/"; - else - qt += "/" + version + "/"; + qt += "/"; qt += type; - QmlType *t = QmlMetaType::qmlType(qt); + QmlType *t = QmlMetaType::qmlType(qt,vmaj,vmin); if (found) *found = qt; if (t) return t; } @@ -1103,11 +1104,11 @@ struct QmlEnginePrivate::ImportedNamespace { class QmlImportsPrivate { public: - bool add(const QUrl& base, const QString& uri, const QString& prefix, const QString& version, QmlScriptParser::Import::Type importType, const QStringList& importPath) + bool add(const QUrl& base, const QString& uri, const QString& prefix, int vmaj, int vmin, QmlScriptParser::Import::Type importType, const QStringList& importPath) { QmlEnginePrivate::ImportedNamespace *s; if (prefix.isEmpty()) { - if (importType == QmlScriptParser::Import::Library && version.isEmpty()) { + if (importType == QmlScriptParser::Import::Library && !vmaj && !vmin) { // unversioned library imports are always qualified - if only by final URI component int lastdot = uri.lastIndexOf(QLatin1Char('.')); QString defaultprefix = uri.mid(lastdot+1); @@ -1141,7 +1142,8 @@ public: url = base.resolved(QUrl(url)).toString(); } s->urls.append(url); - s->versions.append(version); + s->majversions.append(vmaj); + s->minversions.append(vmin); s->isLibrary.append(importType == QmlScriptParser::Import::Library); return true; } @@ -1252,11 +1254,11 @@ void QmlEngine::addImportPath(const QString& path) The base URL must already have been set with Import::setBaseUrl(). */ -bool QmlEnginePrivate::addToImport(Imports* imports, const QString& uri, const QString& prefix, const QString& version, QmlScriptParser::Import::Type importType) const +bool QmlEnginePrivate::addToImport(Imports* imports, const QString& uri, const QString& prefix, int vmaj, int vmin, QmlScriptParser::Import::Type importType) const { - bool ok = imports->d->add(imports->base,uri,prefix,version,importType,fileImportPath); + bool ok = imports->d->add(imports->base,uri,prefix,vmaj,vmin,importType,fileImportPath); if (qmlImportTrace()) - qDebug() << "QmlEngine::addToImport(" << imports << uri << prefix << version << (importType==QmlScriptParser::Import::Library? "Library" : "File") << ": " << ok; + qDebug() << "QmlEngine::addToImport(" << imports << uri << prefix << vmaj << "." << vmin << (importType==QmlScriptParser::Import::Library? "Library" : "File") << ": " << ok; return ok; } @@ -1281,7 +1283,7 @@ bool QmlEnginePrivate::resolveType(const Imports& imports, const QByteArray& typ } if (type_return) { QmlType* t = imports.d->findBuiltin(type); - if (!t) t = QmlMetaType::qmlType(type); + if (!t) t = QmlMetaType::qmlType(type,0,0); // Try global namespace if (t) { if (type_return) *type_return = t; if (qmlImportTrace()) diff --git a/src/declarative/qml/qmlengine_p.h b/src/declarative/qml/qmlengine_p.h index d2e3ef4..aaf679f 100644 --- a/src/declarative/qml/qmlengine_p.h +++ b/src/declarative/qml/qmlengine_p.h @@ -196,7 +196,7 @@ public: QmlImportsPrivate *d; }; struct ImportedNamespace; - bool addToImport(Imports*, const QString& uri, const QString& prefix, const QString& version, QmlScriptParser::Import::Type type) const; + bool addToImport(Imports*, const QString& uri, const QString& prefix, int vmaj, int vmin, QmlScriptParser::Import::Type importType) const; bool resolveType(const Imports&, const QByteArray& type, QmlType** type_return, QUrl* url_return, ImportedNamespace** ns_return=0) const; void resolveTypeInNamespace(ImportedNamespace*, const QByteArray& type, QmlType** type_return, QUrl* url_return ) const; diff --git a/src/declarative/qml/qmlmetaproperty.cpp b/src/declarative/qml/qmlmetaproperty.cpp index d986077..c1736cb 100644 --- a/src/declarative/qml/qmlmetaproperty.cpp +++ b/src/declarative/qml/qmlmetaproperty.cpp @@ -218,9 +218,13 @@ void QmlMetaPropertyPrivate::initProperty(QObject *obj, const QString &name) if (name.at(0).isUpper()) { // Attached property - attachedFunc = QmlMetaType::attachedPropertiesFuncId(name.toLatin1()); - if (attachedFunc != -1) - type = QmlMetaProperty::Property | QmlMetaProperty::Attached; + // XXX name should be resolved with QmlEngine::resolveType(), not like this! + QmlType *t = QmlMetaType::qmlType("Qt/"+name.toLatin1(),-1,-1); + if (t && t->attachedPropertiesFunction()) { + attachedFunc = t->index(); + if (attachedFunc != -1) + type = QmlMetaProperty::Property | QmlMetaProperty::Attached; + } return; } else if (name.count() >= 3 && diff --git a/src/declarative/qml/qmlmetatype.cpp b/src/declarative/qml/qmlmetatype.cpp index 512650f..5ebe970 100644 --- a/src/declarative/qml/qmlmetatype.cpp +++ b/src/declarative/qml/qmlmetatype.cpp @@ -110,6 +110,9 @@ public: bool m_isInterface : 1; const char *m_iid; QByteArray m_name; + int m_version_maj; + int m_version_min_from; + int m_version_min_to; int m_typeId; int m_listId; int m_qmlListId; QmlPrivate::Func m_opFunc; const QMetaObject *m_baseMetaObject; @@ -146,10 +149,14 @@ QmlType::QmlType(int type, int listType, int qmlListType, d->m_opFunc = opFunc; d->m_index = index; d->m_isSetup = true; + d->m_version_maj = 0; + d->m_version_min_from = 0; + d->m_version_min_to = 0; } QmlType::QmlType(int type, int listType, int qmlListType, QmlPrivate::Func opFunc, const char *qmlName, + int version_maj, int version_min_from, int version_min_to, const QMetaObject *metaObject, QmlAttachedPropertiesFunc attachedPropertiesFunc, const QMetaObject *attachedType, @@ -159,6 +166,9 @@ QmlType::QmlType(int type, int listType, int qmlListType, : d(new QmlTypePrivate) { d->m_name = qmlName; + d->m_version_maj = version_maj; + d->m_version_min_from = version_min_from; + d->m_version_min_to = version_min_to; d->m_typeId = type; d->m_listId = listType; d->m_qmlListId = qmlListType; @@ -180,6 +190,11 @@ QmlType::~QmlType() delete d; } +bool QmlType::availableInVersion(int vmajor, int vminor) const +{ + return vmajor == d->m_version_maj && vminor >= d->m_version_min_from && vminor <= d->m_version_min_to; +} + void QmlTypePrivate::init() const { if (m_isSetup) return; @@ -401,6 +416,7 @@ int QmlMetaType::registerInterface(const QmlPrivate::MetaTypeIds &id, data->idToType.insert(type->typeId(), type); data->idToType.insert(type->qListTypeId(), type); data->idToType.insert(type->qmlListTypeId(), type); + // XXX No insertMulti, so no multi-version interfaces? if (!type->qmlTypeName().isEmpty()) data->nameToType.insert(type->qmlTypeName(), type); @@ -422,48 +438,7 @@ int QmlMetaType::registerType(const QmlPrivate::MetaTypeIds &id, QmlPrivate::Fun const QMetaObject *mo, QmlAttachedPropertiesFunc attach, const QMetaObject *attachMo, int pStatus, int object, QmlPrivate::CreateFunc extFunc, const QMetaObject *extmo, QmlCustomParser *parser) { - QByteArray version; - if (uri && (version_maj || version_min_from || version_min_to)) { - if (version_min_from != version_min_to) { - int r=-1; - for (int min=version_min_from; min<=version_min_to; ++min) { - int e = registerType(id,func,uri,version_maj,min,min,cname,mo,attach,attachMo,pStatus,object,extFunc,extmo,parser); - if (e<0) return -1; - if (r<0) r = e; - } - return r; // returns index of FIRST version of type (not currently used anywhere though) - } - version = QByteArray::number(version_maj) + '.' + QByteArray::number(version_min_from); - } else { - // No URI? No version! - Q_ASSERT(!version_maj && !version_min_from && !version_min_to); - } - return registerType(id,func,uri,version,cname,mo,attach,attachMo,pStatus,object,extFunc,extmo,parser); -} - - -int QmlMetaType::registerType(const QmlPrivate::MetaTypeIds &id, QmlPrivate::Func func, - const char *uri, const char *version, const char *cname, - const QMetaObject *mo, QmlAttachedPropertiesFunc attach, const QMetaObject *attachMo, - int pStatus, int object, QmlPrivate::CreateFunc extFunc, const QMetaObject *extmo, QmlCustomParser *parser) -{ Q_UNUSED(object); - QByteArray name; - if (uri) { - // Convert to path - name = uri; - name.replace('.','/'); - if (version) { - name += '/'; - name += version; - } - name += '/'; - name += cname; - } else { - // No URI? No version! - name = cname; - Q_ASSERT(!version); - } if (cname) { for (int ii = 0; cname[ii]; ++ii) { @@ -476,11 +451,16 @@ int QmlMetaType::registerType(const QmlPrivate::MetaTypeIds &id, QmlPrivate::Fun QWriteLocker lock(metaTypeDataLock()); QmlMetaTypeData *data = metaTypeData(); - int index = data->types.count(); + QByteArray name = uri; + if (uri) + name += "/"; + name += cname; + name.replace('.','/'); + QmlType *type = new QmlType(id.typeId, id.listId, id.qmlListId, - func, name, mo, attach, attachMo, pStatus, extFunc, + func, name, version_maj, version_min_from, version_min_to, mo, attach, attachMo, pStatus, extFunc, extmo, index, parser); data->types.append(type); @@ -489,7 +469,7 @@ int QmlMetaType::registerType(const QmlPrivate::MetaTypeIds &id, QmlPrivate::Fun data->idToType.insert(type->qmlListTypeId(), type); if (!type->qmlTypeName().isEmpty()) - data->nameToType.insert(type->qmlTypeName(), type); + data->nameToType.insertMulti(type->qmlTypeName(), type); data->metaObjectToType.insert(type->baseMetaObject(), type); @@ -503,7 +483,7 @@ int QmlMetaType::registerType(const QmlPrivate::MetaTypeIds &id, QmlPrivate::Fun data->qmllists.setBit(id.qmlListId, true); data->lists.setBit(id.listId, true); - return index; // Note: multi-version call only uses first. + return index; } int QmlMetaType::qmlParserStatusCast(int userType) @@ -587,19 +567,6 @@ bool QmlMetaType::append(const QVariant &list, const QVariant &item) } } -QObject *QmlMetaType::create(const QByteArray &name) -{ - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - lock.unlock(); - - QmlType *type = data->nameToType.value(name); - if (type) - return type->create(); - else - return 0; -} - QVariant QmlMetaType::fromObject(QObject *obj, int typeId) { QReadLocker lock(metaTypeDataLock()); @@ -624,18 +591,6 @@ const QMetaObject *QmlMetaType::rawMetaObjectForType(int id) return 0; } -const QMetaObject *QmlMetaType::rawMetaObjectForType(const QByteArray &name) -{ - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - - QmlType *type = data->nameToType.value(name); - if (type) - return type->baseMetaObject(); - else - return 0; -} - const QMetaObject *QmlMetaType::metaObjectForType(int id) { QReadLocker lock(metaTypeDataLock()); @@ -649,43 +604,6 @@ const QMetaObject *QmlMetaType::metaObjectForType(int id) return 0; } -const QMetaObject *QmlMetaType::metaObjectForType(const QByteArray &name) -{ - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - QmlType *type = data->nameToType.value(name); - lock.unlock(); - - if (type) - return type->metaObject(); - else - return 0; -} - -int QmlMetaType::type(const QByteArray &name) -{ - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - - QmlType *type = data->nameToType.value(name); - if (type) - return type->typeId(); - else - return 0; -} - -int QmlMetaType::attachedPropertiesFuncId(const QByteArray &name) -{ - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - - QmlType *type = data->nameToType.value("Qt/4.6/"+name); // XXX Should not hard-code namespace - if (type && type->attachedPropertiesFunction()) - return type->index(); - else - return -1; -} - int QmlMetaType::attachedPropertiesFuncId(const QMetaObject *mo) { QReadLocker lock(metaTypeDataLock()); @@ -707,18 +625,6 @@ QmlAttachedPropertiesFunc QmlMetaType::attachedPropertiesFuncById(int id) return data->types.at(id)->attachedPropertiesFunction(); } -QmlAttachedPropertiesFunc -QmlMetaType::attachedPropertiesFunc(const QByteArray &name) -{ - QReadLocker lock(metaTypeDataLock()); - QmlMetaTypeData *data = metaTypeData(); - QmlType *type = data->nameToType.value(name); - if (type) - return type->attachedPropertiesFunction(); - else - return 0; -} - QMetaProperty QmlMetaType::defaultProperty(const QMetaObject *metaObject) { int idx = metaObject->indexOfClassInfo("DefaultProperty"); @@ -939,12 +845,22 @@ QmlMetaType::StringConverter QmlMetaType::customStringConverter(int type) return data->stringConverters.value(type); } -QmlType *QmlMetaType::qmlType(const QByteArray &name) +/*! + Returns the type (if any) of URI-qualified named \a name in version specified + by \a version_major and \a version_minor. +*/ +QmlType *QmlMetaType::qmlType(const QByteArray &name, int version_major, int version_minor) { QReadLocker lock(metaTypeDataLock()); QmlMetaTypeData *data = metaTypeData(); - return data->nameToType.value(name); + QList<QmlType*> types = data->nameToType.values(name); + foreach (QmlType *t, types) { + // XXX version_major<0 just a kludge for QmlMetaPropertyPrivate::initProperty + if (version_major<0 || t->availableInVersion(version_major,version_minor)) + return t; + } + return 0; } QmlType *QmlMetaType::qmlType(const QMetaObject *metaObject) diff --git a/src/declarative/qml/qmlmetatype.h b/src/declarative/qml/qmlmetatype.h index 9cbf7f3..94029ce 100644 --- a/src/declarative/qml/qmlmetatype.h +++ b/src/declarative/qml/qmlmetatype.h @@ -59,7 +59,6 @@ class QmlCustomParser; class Q_DECLARATIVE_EXPORT QmlMetaType { public: - static int registerType(const QmlPrivate::MetaTypeIds &, QmlPrivate::Func, const char *, const char *version, const char *qmlName, const QMetaObject *, QmlAttachedPropertiesFunc, const QMetaObject *, int pStatus, int object, QmlPrivate::CreateFunc extFunc, const QMetaObject *extmo, QmlCustomParser *); static int registerType(const QmlPrivate::MetaTypeIds &, QmlPrivate::Func, const char *, int vmaj, int vmin_from, int vmin_to, const char *qmlName, const QMetaObject *, QmlAttachedPropertiesFunc, const QMetaObject *, int pStatus, int object, QmlPrivate::CreateFunc extFunc, const QMetaObject *extmo, QmlCustomParser *); static int registerInterface(const QmlPrivate::MetaTypeIds &, QmlPrivate::Func, const char *); @@ -67,7 +66,7 @@ public: static QList<QByteArray> qmlTypeNames(); - static QmlType *qmlType(const QByteArray &); + static QmlType *qmlType(const QByteArray &, int, int); static QmlType *qmlType(const QMetaObject *); static QMetaProperty defaultProperty(const QMetaObject *); @@ -79,20 +78,13 @@ public: static QObject *toQObject(const QVariant &); static int qmlParserStatusCast(int); static int listType(int); - static int type(const QByteArray &); - static int type(const QString &); static bool clear(const QVariant &); static bool append(const QVariant &, const QVariant &); static QVariant fromObject(QObject *, int type); - static QObject *create(const QByteArray &); - static const QMetaObject *rawMetaObjectForType(const QByteArray &); static const QMetaObject *rawMetaObjectForType(int); - static const QMetaObject *metaObjectForType(const QByteArray &); static const QMetaObject *metaObjectForType(int); - static int attachedPropertiesFuncId(const QByteArray &); static int attachedPropertiesFuncId(const QMetaObject *); static QmlAttachedPropertiesFunc attachedPropertiesFuncById(int); - static QmlAttachedPropertiesFunc attachedPropertiesFunc(const QByteArray &); enum TypeCategory { Unknown, Object, List, QmlList }; static TypeCategory typeCategory(int); @@ -119,6 +111,7 @@ class Q_DECLARATIVE_EXPORT QmlType public: QByteArray typeName() const; QByteArray qmlTypeName() const; + bool availableInVersion(int vmajor, int vminor) const; QByteArray hash() const; @@ -151,7 +144,7 @@ private: friend class QmlMetaType; friend class QmlTypePrivate; QmlType(int, int, int, QmlPrivate::Func, const char *, int); - QmlType(int, int, int, QmlPrivate::Func, const char *, const QMetaObject *, QmlAttachedPropertiesFunc, const QMetaObject *, int, QmlPrivate::CreateFunc, const QMetaObject *, int, QmlCustomParser *); + QmlType(int, int, int, QmlPrivate::Func, const char *, int, int, int, const QMetaObject *, QmlAttachedPropertiesFunc, const QMetaObject *, int, QmlPrivate::CreateFunc, const QMetaObject *, int, QmlCustomParser *); ~QmlType(); QmlTypePrivate *d; @@ -167,7 +160,7 @@ int qmlRegisterType(const char *typeName) qRegisterMetaType<T *>(QByteArray("QmlList<" + name + "*>*").constData()) }; - return QmlMetaType::registerType(ids, QmlPrivate::list_nocreate_op<T>, 0, 0, 0, + return QmlMetaType::registerType(ids, QmlPrivate::list_nocreate_op<T>, 0, 0, 0, 0, 0, &T::staticMetaObject, QmlPrivate::attachedPropertiesFunc<T>(), QmlPrivate::attachedPropertiesMetaObject<T>(), @@ -215,7 +208,7 @@ int qmlRegisterExtendedType(const char *typeName) attachedMo = QmlPrivate::attachedPropertiesMetaObject<T>(); } - return QmlMetaType::registerType(ids, QmlPrivate::list_nocreate_op<T>, 0, 0, 0, + return QmlMetaType::registerType(ids, QmlPrivate::list_nocreate_op<T>, 0, 0, 0, 0, 0, &T::staticMetaObject, attached, attachedMo, QmlPrivate::StaticCastSelector<T,QmlParserStatus>::cast(), QmlPrivate::StaticCastSelector<T,QObject>::cast(), |