_properties[object].insert(name, value);
}
+QString Context::defaultPropertyName(const ObjectValue *object)
+{
+ for (const ObjectValue *o = object; o; o = o->prototype(this)) {
+ if (const ASTObjectValue *astObjValue = dynamic_cast<const ASTObjectValue *>(o)) {
+ QString defaultProperty = astObjValue->defaultPropertyName();
+ if (!defaultProperty.isEmpty())
+ return defaultProperty;
+ } else if (const QmlObjectValue *qmlValue = dynamic_cast<const QmlObjectValue *>(o)) {
+ return qmlValue->defaultPropertyName();
+ }
+ }
+ return QString();
+}
+
bool Context::documentImportsPlugins(const QmlJS::Document *doc) const
{
return _documentsImportingPlugins.contains(doc->fileName());
UiObjectInitializer *initializer,
const QmlJS::Document *doc,
Engine *engine)
- : ObjectValue(engine), _typeName(typeName), _initializer(initializer), _doc(doc)
+ : ObjectValue(engine), _typeName(typeName), _initializer(initializer), _doc(doc), _defaultPropertyRef(0)
{
if (_initializer) {
for (UiObjectMemberList *it = _initializer->members; it; it = it->next) {
if (def->type == UiPublicMember::Property && def->name && def->memberType) {
ASTPropertyReference *ref = new ASTPropertyReference(def, _doc, engine);
_properties.append(ref);
+ if (def->defaultToken.isValid())
+ _defaultPropertyRef = ref;
} else if (def->type == UiPublicMember::Signal && def->name) {
ASTSignalReference *ref = new ASTSignalReference(def, _doc, engine);
_signals.append(ref);
ObjectValue::processMembers(processor);
}
+QString ASTObjectValue::defaultPropertyName() const
+{
+ if (_defaultPropertyRef) {
+ UiPublicMember *prop = _defaultPropertyRef->ast();
+ if (prop && prop->name)
+ return prop->name->asString();
+ }
+ return QString();
+}
+
ASTVariableReference::ASTVariableReference(VariableDeclaration *ast, Engine *engine)
: Reference(engine), _ast(ast)
{
const Value *property(const ObjectValue *object, const QString &name) const;
void setProperty(const ObjectValue *object, const QString &name, const Value *value);
+ QString defaultPropertyName(const ObjectValue *object);
+
bool documentImportsPlugins(const Document *doc) const;
void setDocumentImportsPlugins(const Document *doc);
const Document *_doc;
QList<ASTPropertyReference *> _properties;
QList<ASTSignalReference *> _signals;
+ ASTPropertyReference *_defaultPropertyRef;
public:
ASTObjectValue(AST::UiQualifiedId *typeName,
bool getSourceLocation(QString *fileName, int *line, int *column) const;
virtual void processMembers(MemberProcessor *processor) const;
+
+ QString defaultPropertyName() const;
};
} } // end of namespace QmlJS::Interpreter
int &minorVersion, QString &defaultPropertyName)
{
const Interpreter::ObjectValue *value = m_context->lookupType(m_doc.data(), astTypeNode);
+ defaultPropertyName = m_context->defaultPropertyName(value);
+
const Interpreter::QmlObjectValue * qmlValue = dynamic_cast<const Interpreter::QmlObjectValue *>(value);
if (qmlValue) {
typeName = qmlValue->packageName() + QLatin1String("/") + qmlValue->className();
majorVersion = qmlValue->majorVersion();
minorVersion = qmlValue->minorVersion();
- defaultPropertyName = qmlValue->defaultPropertyName();
} else if (value) {
for (UiQualifiedId *iter = astTypeNode; iter; iter = iter->next)
if (!iter->next && iter->name)
QVERIFY(myButtonMetaInfo.property("border.width", true).isValid());
}
-void TestCore::testComponentLoadingTabWidget()
-{
-
-// QSKIP("TODO: fails", SkipAll);
-
- QString fileName = QString(QTCREATORDIR) + "/tests/auto/qml/qmldesigner/data/fx/tabs.qml";
- QFile file(fileName);
- QVERIFY(file.open(QIODevice::ReadOnly | QIODevice::Text));
-
- QPlainTextEdit textEdit;
- textEdit.setPlainText(file.readAll());
- NotIndentingTextEditModifier modifier(&textEdit);
-
- QScopedPointer<Model> model(Model::create("Qt/Item"));
- model->setFileUrl(QUrl::fromLocalFile(fileName));
- QScopedPointer<SubComponentManager> subComponentManager(new SubComponentManager(model->metaInfo(), 0));
- subComponentManager->update(QUrl::fromLocalFile(fileName), modifier.text().toUtf8());
-
- QScopedPointer<TestRewriterView> testRewriterView(new TestRewriterView());
- testRewriterView->setTextModifier(&modifier);
- model->attachView(testRewriterView.data());
-
- QVERIFY(testRewriterView->errors().isEmpty());
- QVERIFY(testRewriterView->rootModelNode().isValid());
-
- ModelNode rootModelNode = testRewriterView->rootModelNode();
- QCOMPARE(rootModelNode.type(), QLatin1String("TabWidget"));
-}
-
void TestCore::testAnchorsAndRewriting()
{
const QString qmlString("import Qt 4.7\n"