summaryrefslogtreecommitdiffstats
path: root/src/declarative/util
diff options
context:
space:
mode:
authorWarwick Allison <warwick.allison@nokia.com>2009-11-09 06:23:42 (GMT)
committerWarwick Allison <warwick.allison@nokia.com>2009-11-09 06:23:42 (GMT)
commitc6101765924d2cc8290f342a945106405bc42129 (patch)
tree82530a1c1bc8514fca14c08a1ab8ab62c8843689 /src/declarative/util
parentdabc2b4f015ab37d4c7ace4a96b5615722a1efc1 (diff)
downloadQt-c6101765924d2cc8290f342a945106405bc42129.zip
Qt-c6101765924d2cc8290f342a945106405bc42129.tar.gz
Qt-c6101765924d2cc8290f342a945106405bc42129.tar.bz2
Fix and test set/get of structured ListModel data.
Diffstat (limited to 'src/declarative/util')
-rw-r--r--src/declarative/util/qmllistmodel.cpp33
1 files changed, 22 insertions, 11 deletions
diff --git a/src/declarative/util/qmllistmodel.cpp b/src/declarative/util/qmllistmodel.cpp
index fbd957c..082d70d 100644
--- a/src/declarative/util/qmllistmodel.cpp
+++ b/src/declarative/util/qmllistmodel.cpp
@@ -221,21 +221,22 @@ struct ModelNode
QList<QVariant> values;
QHash<QString, ModelNode *> properties;
- QmlListModel *model() {
+ QmlListModel *model(const QmlListModel *parent) {
if (!modelCache) {
modelCache = new QmlListModel;
+ QmlEngine::setContextForObject(modelCache,QmlEngine::contextForObject(parent));
+
modelCache->_root = this;
}
return modelCache;
}
- ModelObject *object() {
+ ModelObject *object(const QmlListModel *parent) {
if (!objectCache) {
objectCache = new ModelObject();
QHash<QString, ModelNode *>::iterator it;
for (it = properties.begin(); it != properties.end(); ++it) {
- if (!(*it)->values.isEmpty())
- objectCache->setValue(it.key().toUtf8(), (*it)->values.first());
+ objectCache->setValue(it.key().toUtf8(), parent->valueForNode(*it));
}
}
return objectCache;
@@ -365,7 +366,7 @@ QVariant QmlListModel::valueForNode(ModelNode *node) const
if (!node->properties.isEmpty()) {
// Object
- rv = node->object();
+ rv = node->object(this);
} else if (node->values.count() == 0) {
// Invalid
return QVariant();
@@ -375,15 +376,15 @@ QVariant QmlListModel::valueForNode(ModelNode *node) const
ModelNode *valueNode = qvariant_cast<ModelNode *>(var);
if (valueNode) {
if (!valueNode->properties.isEmpty())
- rv = valueNode->object();
+ rv = valueNode->object(this);
else
- rv = valueNode->model();
+ rv = valueNode->model(this);
} else {
return var;
}
} else if (node->values.count() > 1) {
// List
- rv = node->model();
+ rv = node->model(this);
}
if (rv)
@@ -579,17 +580,27 @@ void QmlListModel::append(const QScriptValue& valuemap)
}
/*!
- \qmlmethod dict ListModel::get(index)
+ \qmlmethod object ListModel::get(index)
Returns the item at \a index in the list model.
\code
- FruitModel.append({"cost": 5.95, "name":"Pizza"})
+ FruitModel.append({"cost": 5.95, "name":"Jackfruit"})
FruitModel.get(0).cost
\endcode
The \a index must be an element in the list.
+ Note that properties of the returned object that are themselves objects
+ will also be models, and this get() method is used to access elements:
+
+ \code
+ FruitModel.append(..., "attributes":
+ [{"name":"spikes","value":"7mm"},
+ {"name":"color","value":"green"}]);
+ FruitModel.get(0).attributes.get(1).value; // == "green"
+ \endcode
+
\sa append()
*/
QScriptValue QmlListModel::get(int index) const
@@ -607,7 +618,7 @@ QScriptValue QmlListModel::get(int index) const
qWarning("Cannot call QmlListModel::get() without a QmlEngine");
return 0;
}
- return QmlEnginePrivate::qmlScriptObject(node->object(), eng);
+ return QmlEnginePrivate::qmlScriptObject(node->object(this), eng);
}
/*!