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
|
// SPDX-FileCopyrightText: 2019 - 2023 UnionTech Software Technology Co., Ltd.
//
// SPDX-License-Identifier: GPL-3.0-or-later
#include "DebugTimeManager.h"
#include <QDateTime>
#include <QDebug>
#include <QLoggingCategory>
#include <sys/time.h>
#include <time.h>
#ifdef QT_DEBUG
Q_LOGGING_CATEGORY(logDebugTime, "org.deepin.log.viewer.debug.timemanager")
#else
Q_LOGGING_CATEGORY(logDebugTime, "org.deepin.log.viewer.debug.timemanager", QtInfoMsg)
#endif
DebugTimeManager::DebugTimeManager()
{
}
void DebugTimeManager::clear()
{
m_MapPoint.clear();
m_MapLinuxPoint.clear();
}
void DebugTimeManager::beginPointLinux(const QString &point, const QString &status)
{
PointInfoLinux info;
info.desc = status;
timespec beginTime;
int result = clock_gettime(CLOCK_MONOTONIC, &beginTime);
if (result) {
return;
}
info.time = beginTime;
m_MapLinuxPoint.insert(point, info);
}
void DebugTimeManager::endPointLinux(const QString &point, const QString &status)
{
if (m_MapLinuxPoint.contains(point)) {
timespec endTime;
int result = clock_gettime(CLOCK_MONOTONIC, &endTime);
if (result) {
return;
}
timespec diffTime = diff(m_MapLinuxPoint[point].time, endTime);
qCInfo(logDebugTime) << QString("[GRABPOINT] %1 %2 %3 time=%4s").arg(point).arg(m_MapLinuxPoint[point].desc).arg(status).arg(QString::number((diffTime.tv_sec * 1000 + (diffTime.tv_nsec) / 1000000) / 1000.0, 'g', 4));
m_MapLinuxPoint.remove(point);
}
}
timespec DebugTimeManager::diff(timespec start, timespec end)
{
timespec temp;
temp.tv_sec = end.tv_sec - start.tv_sec;
temp.tv_nsec = end.tv_nsec - start.tv_nsec;
return temp;
}
|