blob: 94b5b1d7ca1c184bccb1a7f9cef28ef81d8b0e53 (
plain)
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
|
// Copyright (C) 2019 Klarälvdalens Datakonsult AB, a KDAB Group company,
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#pragma once
#include "json/json.hpp"
#include <QHash>
#include <QList>
#include <QMap>
#include <QObject>
namespace Timeline { class TimelineModelAggregator; }
namespace CtfVisualizer::Internal {
class CtfStatisticsModel;
class CtfTimelineModel;
class CtfTraceManager : public QObject
{
Q_OBJECT
public:
explicit CtfTraceManager(QObject *parent,
Timeline::TimelineModelAggregator *modelAggregator,
CtfStatisticsModel *statisticsModel);
qint64 traceDuration() const;
qint64 traceBegin() const;
qint64 traceEnd() const;
void addEvent(const nlohmann::json &event);
void finalize();
bool isEmpty() const;
int getSelectionId(const std::string &name);
QList<CtfTimelineModel *> getSortedThreads() const;
void setThreadRestriction(const QString &tid, bool restrictToThisThread);
bool isRestrictedTo(const QString &tid) const;
void updateStatistics();
void clearAll();
QString errorString() const;
signals:
void detailsRequested(const QString &title);
protected:
void addModelForThread(const QString &threadId, const QString &processId);
void addModelsToAggregator();
Timeline::TimelineModelAggregator *const m_modelAggregator;
CtfStatisticsModel *const m_statisticsModel;
QHash<QString, CtfTimelineModel *> m_threadModels;
QHash<QString, QString> m_processNames;
QHash<QString, QString> m_threadNames;
QMap<std::string, int> m_name2selectionId;
QHash<QString, bool> m_threadRestrictions;
double m_traceBegin = std::numeric_limits<double>::max();
double m_traceEnd = std::numeric_limits<double>::min();
double m_timeOffset = -1.0;
QString m_errorString;
};
} // namespace CtfVisualizer::Internal
|