forked from qt-creator/qt-creator
While the format document only uses numbers for these in its examples, the data type is not really specified there and chrome://tracing itself handles strings for them without complaint. On trace-generating side std::thread::id can't easily be serialized as a number, and strings can easily be supported in the viewer. Change-Id: I36c8497049d4933058b9f72a28f24e1d1cf0d5bb Reviewed-by: Alessandro Portale <alessandro.portale@qt.io>
98 lines
2.8 KiB
C++
98 lines
2.8 KiB
C++
// 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 <tracing/timelinemodel.h>
|
|
|
|
#include <QMap>
|
|
#include <QSet>
|
|
#include <QStack>
|
|
#include <QVector>
|
|
|
|
namespace Timeline {
|
|
class TimelineModelAggregator;
|
|
}
|
|
|
|
namespace CtfVisualizer {
|
|
namespace Internal {
|
|
|
|
class CtfTraceManager;
|
|
|
|
class CtfTimelineModel : public Timeline::TimelineModel
|
|
{
|
|
Q_OBJECT
|
|
|
|
friend class CtfTraceManager;
|
|
|
|
public:
|
|
explicit CtfTimelineModel(Timeline::TimelineModelAggregator *parent,
|
|
CtfTraceManager *traceManager,
|
|
const QString &tid,
|
|
const QString &pid);
|
|
|
|
QRgb color(int index) const override;
|
|
QVariantList labels() const override;
|
|
QVariantMap orderedDetails(int index) const override;
|
|
int expandedRow(int index) const override;
|
|
int collapsedRow(int index) const override;
|
|
|
|
int typeId(int index) const override;
|
|
bool handlesTypeId(int typeId) const override;
|
|
float relativeHeight(int index) const override;
|
|
|
|
QPair<bool, qint64> addEvent(const nlohmann::json &event, double traceBegin);
|
|
|
|
void finalize(double traceBegin, double traceEnd, const QString &processName, const QString &threadName);
|
|
|
|
QString tid() const;
|
|
QString eventTitle(int index) const;
|
|
|
|
signals:
|
|
void detailsRequested(const QString &eventName) const;
|
|
|
|
private:
|
|
void updateName();
|
|
|
|
qint64 newStackEvent(const nlohmann::json &event, qint64 normalizedTime,
|
|
const std::string &eventPhase, const std::string &name, int selectionId);
|
|
|
|
qint64 closeStackEvent(const nlohmann::json &event, double timestamp, qint64 normalizedTime);
|
|
|
|
void addCounterValue(const nlohmann::json &event, qint64 normalizedTime, const std::string &name, int selectionId);
|
|
|
|
const QString &reuse(const QString &value);
|
|
|
|
protected:
|
|
CtfTraceManager *const m_traceManager;
|
|
|
|
QString m_threadId;
|
|
QString m_threadName;
|
|
QString m_processId;
|
|
QString m_processName;
|
|
|
|
int m_maxStackSize = 0;
|
|
QVector<int> m_nestingLevels;
|
|
QVector<QMap<int, QPair<QString, QString>>> m_details;
|
|
QSet<int> m_handledTypeIds;
|
|
QStack<int> m_openEventIds;
|
|
QSet<QString> m_reusableStrings;
|
|
|
|
struct CounterData {
|
|
qint64 end = 0;
|
|
int startEventIndex = -1;
|
|
float min = std::numeric_limits<float>::max();
|
|
float max = std::numeric_limits<float>::min();
|
|
};
|
|
|
|
QVector<std::string> m_counterNames;
|
|
QVector<CounterData> m_counterData;
|
|
QVector<float> m_counterValues;
|
|
QVector<int> m_itemToCounterIdx;
|
|
QVector<int> m_counterIndexToRow;
|
|
};
|
|
|
|
} // namespace Internal
|
|
} // namespace CtfVisualizer
|