Files
qt-creator/src/plugins/ctfvisualizer/ctfstatisticsmodel.cpp
Kai Köhne 56baf8c058 Remove GPL-3.0+ from license identifiers
Since we also license under GPL-3.0 WITH Qt-GPL-exception-1.0,
this applies only to a hypothetical newer version of GPL, that doesn't
exist yet. If such a version emerges, we can still decide to relicense...

While at it, replace (deprecated) GPL-3.0 with more explicit GPL-3.0-only

Change was done by running

  find . -type f -exec perl -pi -e "s/LicenseRef-Qt-Commercial OR GPL-3.0\+ OR GPL-3.0 WITH Qt-GPL-exception-1.0/LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0/g" {} \;

Change-Id: I5097e6ce8d10233993ee30d7e25120e2659eb10b
Reviewed-by: Eike Ziller <eike.ziller@qt.io>
2023-01-06 11:15:13 +00:00

191 lines
5.4 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
#include "ctfstatisticsmodel.h"
#include "ctfvisualizerconstants.h"
#include "ctfvisualizertr.h"
#include <tracing/timelineformattime.h>
namespace CtfVisualizer {
namespace Internal {
using json = nlohmann::json;
using namespace Constants;
CtfStatisticsModel::CtfStatisticsModel(QObject *parent)
: QAbstractTableModel(parent)
{
}
void CtfStatisticsModel::beginLoading()
{
beginResetModel();
m_data.clear();
}
void CtfStatisticsModel::addEvent(const QString &title, qint64 durationInNs)
{
EventData &data = m_data[title];
++data.count;
if (durationInNs >= 0) {
data.totalDuration += durationInNs;
data.minDuration = std::min(data.minDuration, durationInNs);
data.maxDuration = std::max(data.maxDuration, durationInNs);
}
}
void CtfStatisticsModel::setMeasurementDuration(qint64 timeInNs)
{
m_measurementDurationInNs = timeInNs;
}
void CtfStatisticsModel::endLoading()
{
endResetModel();
}
int CtfStatisticsModel::rowCount(const QModelIndex &parent) const
{
return parent.isValid() ? 0 : m_data.size();
}
int CtfStatisticsModel::columnCount(const QModelIndex &parent) const
{
return parent.isValid() ? 0 : Column::COUNT;
}
QVariant CtfStatisticsModel::data(const QModelIndex &index, int role) const
{
if (!index.isValid())
return QVariant();
auto it = m_data.cbegin();
std::advance(it, index.row());
const QString &title = it.key();
switch (role) {
case Qt::TextAlignmentRole:
switch (index.column()) {
case Column::Title:
return Qt::AlignLeft;
case Column::Count:
case Column::TotalDuration:
case Column::RelativeDuration:
case Column::MinDuration:
case Column::AvgDuration:
case Column::MaxDuration:
return Qt::AlignRight;
default:
Q_UNREACHABLE();
return QVariant();
}
case SortRole:
switch (index.column()) {
case Column::Title:
return title;
case Column::Count:
return m_data.value(title).count;
case Column::TotalDuration:
return m_data.value(title).totalDuration;
case Column::RelativeDuration:
return m_data.value(title).totalDuration;
case Column::MinDuration:
{
auto minDuration = m_data.value(title).minDuration;
return minDuration != std::numeric_limits<qint64>::max() ? minDuration : 0;
}
case Column::AvgDuration:
{
auto data = m_data.value(title);
if (data.totalDuration > 0 && data.count > 0)
return double(data.totalDuration) / data.count;
return 0;
}
case Column::MaxDuration:
return m_data.value(title).maxDuration;
default:
return QVariant();
}
case Qt::DisplayRole:
switch (index.column()) {
case Column::Title:
return title;
case Column::Count:
return m_data.value(title).count;
case Column::TotalDuration:
{
auto totalDuration = m_data.value(title).totalDuration;
if (totalDuration > 0)
return Timeline::formatTime(totalDuration);
else
return "-";
}
case Column::RelativeDuration:
{
auto totalDuration = m_data.value(title).totalDuration;
if (m_measurementDurationInNs > 0 && totalDuration > 0) {
const double percent = (totalDuration / double(m_measurementDurationInNs)) * 100;
return QString("%1 %").arg(percent, 0, 'f', 2);
} else {
return "-";
}
}
case Column::MinDuration:
{
auto minDuration = m_data.value(title).minDuration;
if (minDuration != std::numeric_limits<qint64>::max())
return Timeline::formatTime(minDuration);
else
return "-";
}
case Column::AvgDuration:
{
auto data = m_data.value(title);
if (data.totalDuration > 0 && data.count > 0)
return Timeline::formatTime(data.totalDuration / data.count);
return "-";
}
case Column::MaxDuration:
{
auto maxDuration = m_data.value(title).maxDuration;
if (maxDuration > 0)
return Timeline::formatTime(maxDuration);
else
return "-";
}
}
}
return QVariant();
}
QVariant CtfStatisticsModel::headerData(int section, Qt::Orientation orientation, int role) const
{
if (role != Qt::DisplayRole || orientation != Qt::Horizontal)
return QAbstractTableModel::headerData(section, orientation, role);
switch (section) {
case Column::Title:
return Tr::tr("Title");
case Column::Count:
return Tr::tr("Count");
case Column::TotalDuration:
return Tr::tr("Total Time");
case Column::RelativeDuration:
return Tr::tr("Percentage");
case Column::MinDuration:
return Tr::tr("Minimum Time");
case Column::AvgDuration:
return Tr::tr("Average Time");
case Column::MaxDuration:
return Tr::tr("Maximum Time");
default:
return "";
}
}
} // Internal
} // CtfVisualizer