-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathversionnumber.h
107 lines (93 loc) · 4.79 KB
/
versionnumber.h
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
/*
Copyright (C) 2008 Tim Fechtner < urwald at users dot sourceforge dot net >
Modfied by Adrian @MXLinux
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of
the License or (at your option) version 3 or any later version
accepted by the membership of KDE e.V. (or its successor approved
by the membership of KDE e.V.), which shall act as a proxy
defined in Section 14 of version 3 of the license.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include <QMetaType>
#include <QStringList>
/** \brief A data type for version numbers.
*
* This class provides a data type for version numbers. Think of it
* as a \e QString which provides special behavior for version
* numbers in the six relational operators (\<, \<=, \>, \>=, ==, !=).
*
* The behavior of the relational operators is similar to the behavior
* of RPM when comparing versions. "Similar" means that it is \e not
* \e equal! See http://rpm.org/wiki/PackagerDocs/Dependencies for a
* good description of the algorithm used by RPM to determinate
* version ordering.
*
* You can assign values of the type \e QString and even \e qint64
* (which will be converted to a QString) and of course of the
* type \e %VersionNumber itself
* to it. You can use the assignment operator or the constructor
* for initiation. The data type is made available to QMetaType and
* is this way available in for example QVariant. If you want to use
* it in in non-template based functions like \e queued signal
* and slot connections, do something like
* <tt>int id = qRegisterMetaType<VersionNumber>("VersionNumber");</tt>
* at the begin of your main function.
* This will register the type also for this use case. <tt>id</tt>
* will contain the type identifier used by QMetaObject. However,
* for most cases <tt>id</tt> isn't intresting.
*
* You can convert to a string with toString(). This function returns
* always exactly the string which was used to initialize this object.
*
* To compare version numbers, the QString is segmented into small
* parts. See http://rpm.org/wiki/PackagerDocs/Dependencies for details.
* The algorithm of \e %VersionNumber differs in some points from the
* algorithm of RPM:
* \li It accepts \e all strings, also with special characters.
* \li You can use not only "." but also "-" as often as you want. (Each
* new dash separates a new part in the number.)
* \li You can safely use special characters. If they aren't "." or "-",
* then they are treated as normal characters. The very last
* segmentation (e.g. "12#rc1" to "12", "#", "rc", "1") does not only
* differ between QChar::isDigit() and QChar::isLetter (like RPM does), but has
* a third category for characters who are neither digit nor letter.
* \li The very first occurrence of ":" is treated as separator for the epoch.
* Each following occurrence of ":" is treated as normal character.
* */
class VersionNumber
{
public:
VersionNumber() = default;
VersionNumber(const VersionNumber &value) = default;
explicit VersionNumber(const QString &value);
[[nodiscard]] QString toString() const;
VersionNumber &operator=(const VersionNumber &value) = default;
VersionNumber &operator=(const QString &value);
[[nodiscard]] bool operator<(const VersionNumber &value) const;
[[nodiscard]] bool operator<=(const VersionNumber &value) const;
[[nodiscard]] bool operator>(const VersionNumber &value) const;
[[nodiscard]] bool operator>=(const VersionNumber &value) const;
[[nodiscard]] bool operator==(const VersionNumber &value) const;
[[nodiscard]] bool operator!=(const VersionNumber &value) const;
private:
QString str; // Full version string
int epoch {};
QStringList upstream_version; // A string list of characters, numbers are grouped together
QStringList debian_revision;
// Add characters to separate elements, groups digits together
[[nodiscard]] static QStringList groupDigits(const QString &value);
void setStrings(const QString &value);
// 1 for > second, -1 for < second, 0 for equal
[[nodiscard]] int compare(const VersionNumber &first, const VersionNumber &second) const;
[[nodiscard]] static int compare(const QStringList &first, const QStringList &second);
[[nodiscard]] static int compare(QChar first, QChar second);
};
Q_DECLARE_METATYPE(VersionNumber)