aboutsummaryrefslogtreecommitdiffstats
path: root/src/libs/tracing/timelineformattime.cpp
blob: 280046565e598b7a88b88512887fb7102f74de3a (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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
/****************************************************************************
**
** Copyright (C) 2016 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of Qt Creator.
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 as published by the Free Software
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
****************************************************************************/

#include "timelineformattime.h"
#include <QtQml>

namespace Timeline {

QString formatTime(qint64 timestamp, qint64 reference)
{
    static const char *decimalUnits[] = {" ns", " \xb5s", " ms", " s"};
    static const double second = 1e9;
    static const double minute = 60;
    static const double hour = 60;

    int round = 1;
    qint64 barrier = 1;

    for (uint i = 0, end = sizeof(decimalUnits) / sizeof(char *); i < end; ++i) {
        const double dividend = barrier;
        if (reference < barrier) {
            round += 3;
            barrier *= 1000;
        } else {
            barrier *= 10;
            if (reference < barrier) {
                round += 2;
                barrier *= 100;
            } else {
                barrier *= 10;
                if (reference < barrier)
                    round += 1;
                barrier *= 10;
            }
        }
        if (timestamp < barrier) {
            return QString::number(timestamp / dividend, 'g', qMax(round, 3))
                    + QString::fromLatin1(decimalUnits[i]);
        }
    }

    double seconds = timestamp / second;
    if (seconds < minute) {
        return QString::number(seconds, 'g', qMax(round, 3)) + " s";
    } else {
        int minutes = seconds / minute;
        seconds -= minutes * minute;
        if (minutes < hour) {
            return QString::fromLatin1("%1m %2s").arg(QString::number(minutes),
                                                      QString::number(seconds, 'g', round));
        } else {
            int hours = minutes / hour;
            minutes -= hours * hour;
            if (reference < barrier * minute) {
                return QString::fromLatin1("%1h %2m %3s").arg(QString::number(hours),
                                                              QString::number(minutes),
                                                              QString::number(seconds, 'g', round));
            } else {
                return QString::fromLatin1("%1h %2m").arg(QString::number(hours),
                                                          QString::number(minutes));
            }

        }
    }
}

}