Commit 00650c8b authored by Ulf Hermann's avatar Ulf Hermann

QmlProfiler: connect category labels to specific models

By listening only to the relevant expandedChanged and rowHeightChanged
signals we avoid accessing invalid data on clearing. When clearing the
models each one is collapsed. The collapsing in turn triggers
rebuilding of the labels. Unrelated labels could access already
cleared data like this.

Change-Id: I3fad45f5c6279019fbc27ec54e758f498a9d55f2
Reviewed-by: default avatarKai Koehne <>
parent dc6c0bce
......@@ -75,12 +75,16 @@ Item {
Connections {
target: qmlProfilerModelProxy
target: qmlProfilerModelProxy.models[modelIndex]
onExpandedChanged: updateDescriptions()
onStateChanged: updateDescriptions()
onRowHeightChanged: updateDescriptions()
Connections {
target: qmlProfilerModelProxy
onStateChanged: updateDescriptions()
Text {
id: txt
x: 5
......@@ -92,6 +92,15 @@ void TimelineModelAggregator::addModel(AbstractTimelineModel *m)
d->modelList << m;
emit modelsChanged();
QVariantList TimelineModelAggregator::models() const
QVariantList ret;
foreach (AbstractTimelineModel *model, d->modelList)
ret << QVariant::fromValue(model);
return ret;
int TimelineModelAggregator::count(int modelIndex) const
......@@ -39,12 +39,14 @@ namespace Internal {
class TimelineModelAggregator : public QObject
Q_PROPERTY(QVariantList models READ models NOTIFY modelsChanged)
TimelineModelAggregator(QObject *parent = 0);
void setModelManager(QmlProfilerModelManager *modelManager);
void addModel(AbstractTimelineModel *m);
QVariantList models() const;
Q_INVOKABLE int count(int modelIndex = -1) const;
void clear();
......@@ -94,6 +96,7 @@ signals:
void stateChanged();
void expandedChanged();
void rowHeightChanged();
void modelsChanged();
protected slots:
void dataChanged();
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment