1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
import QtCreator.QmlProfiler
import QtCreator.Tracing
FlameGraphView {
id: root
model: flameGraphModel
typeIdRole: QmlProfilerFlameGraphModel.TypeIdRole
sourceFileRole: QmlProfilerFlameGraphModel.FilenameRole
sourceLineRole: QmlProfilerFlameGraphModel.LineRole
sourceColumnRole: QmlProfilerFlameGraphModel.ColumnRole
detailsTitleRole: QmlProfilerFlameGraphModel.TypeRole
summaryRole: QmlProfilerFlameGraphModel.DetailsRole
noteRole: QmlProfilerFlameGraphModel.NoteRole
modes: [
QmlProfilerFlameGraphModel.DurationRole,
QmlProfilerFlameGraphModel.MemoryRole,
QmlProfilerFlameGraphModel.AllocationsRole
]
trRoleNames: [
QmlProfilerFlameGraphModel.DurationRole, qsTranslate("QtC::QmlProfiler", "Total Time"),
QmlProfilerFlameGraphModel.CallCountRole, qsTranslate("QtC::QmlProfiler", "Calls"),
QmlProfilerFlameGraphModel.DetailsRole, qsTranslate("QtC::QmlProfiler", "Details"),
QmlProfilerFlameGraphModel.TimePerCallRole, qsTranslate("QtC::QmlProfiler", "Mean Time"),
QmlProfilerFlameGraphModel.LocationRole, qsTranslate("QtC::QmlProfiler", "Location"),
QmlProfilerFlameGraphModel.AllocationsRole, qsTranslate("QtC::QmlProfiler", "Allocations"),
QmlProfilerFlameGraphModel.MemoryRole, qsTranslate("QtC::QmlProfiler", "Memory")
].reduce(toMap, {})
details: function(flameGraph) {
var model = [];
if (!flameGraph.dataValid) {
model.push(trRoleNames[QmlProfilerFlameGraphModel.DetailsRole]);
model.push(qsTranslate("QtC::QmlProfiler", "Various Events"));
} else {
function addDetail(role, format) { root.addDetail(role, format, model, flameGraph); }
addDetail(QmlProfilerFlameGraphModel.DetailsRole, detailFormats.noop);
addDetail(QmlProfilerFlameGraphModel.CallCountRole, detailFormats.noop);
addDetail(QmlProfilerFlameGraphModel.DurationRole, detailFormats.printTime);
addDetail(QmlProfilerFlameGraphModel.TimePerCallRole, detailFormats.printTime);
addDetail(QmlProfilerFlameGraphModel.LocationRole, detailFormats.noop);
addDetail(QmlProfilerFlameGraphModel.MemoryRole, detailFormats.printMemory);
addDetail(QmlProfilerFlameGraphModel.AllocationsRole, detailFormats.noop);
}
return model;
}
summary: function(attached) {
if (!attached.dataValid)
return qsTranslate("QtC::QmlProfiler", "others");
return attached.data(QmlProfilerFlameGraphModel.DetailsRole) + " ("
+ attached.data(QmlProfilerFlameGraphModel.TypeRole) + ", "
+ root.percent(root.sizeRole, attached) + "%)";
}
isHighlighted: function(node) {
function recurse(parentNode, typeId) {
if (!parentNode)
return false;
if (parentNode.typeId === typeId) {
parentNode.isHighlighted = true;
return true;
}
return recurse(parentNode.parent, typeId);
}
return recurse(node.parent, node.typeId);
}
}
|