fix: proper null padded version comparison
Signed-off-by: Rachel Powers <508861+Ryex@users.noreply.github.com>
This commit is contained in:
parent
9934537e19
commit
7ed993b54e
@ -15,9 +15,9 @@ bool Version::operator<(const Version &other) const
|
|||||||
const int size = qMax(m_sections.size(), other.m_sections.size());
|
const int size = qMax(m_sections.size(), other.m_sections.size());
|
||||||
for (int i = 0; i < size; ++i)
|
for (int i = 0; i < size; ++i)
|
||||||
{
|
{
|
||||||
const Section sec1 = (i >= m_sections.size()) ? Section("0") : m_sections.at(i);
|
const Section sec1 = (i >= m_sections.size()) ? Section("") : m_sections.at(i);
|
||||||
const Section sec2 =
|
const Section sec2 =
|
||||||
(i >= other.m_sections.size()) ? Section("0") : other.m_sections.at(i);
|
(i >= other.m_sections.size()) ? Section("") : other.m_sections.at(i);
|
||||||
if (sec1 != sec2)
|
if (sec1 != sec2)
|
||||||
{
|
{
|
||||||
return sec1 < sec2;
|
return sec1 < sec2;
|
||||||
@ -35,9 +35,9 @@ bool Version::operator>(const Version &other) const
|
|||||||
const int size = qMax(m_sections.size(), other.m_sections.size());
|
const int size = qMax(m_sections.size(), other.m_sections.size());
|
||||||
for (int i = 0; i < size; ++i)
|
for (int i = 0; i < size; ++i)
|
||||||
{
|
{
|
||||||
const Section sec1 = (i >= m_sections.size()) ? Section("0") : m_sections.at(i);
|
const Section sec1 = (i >= m_sections.size()) ? Section("") : m_sections.at(i);
|
||||||
const Section sec2 =
|
const Section sec2 =
|
||||||
(i >= other.m_sections.size()) ? Section("0") : other.m_sections.at(i);
|
(i >= other.m_sections.size()) ? Section("") : other.m_sections.at(i);
|
||||||
if (sec1 != sec2)
|
if (sec1 != sec2)
|
||||||
{
|
{
|
||||||
return sec1 > sec2;
|
return sec1 > sec2;
|
||||||
@ -55,9 +55,9 @@ bool Version::operator==(const Version &other) const
|
|||||||
const int size = qMax(m_sections.size(), other.m_sections.size());
|
const int size = qMax(m_sections.size(), other.m_sections.size());
|
||||||
for (int i = 0; i < size; ++i)
|
for (int i = 0; i < size; ++i)
|
||||||
{
|
{
|
||||||
const Section sec1 = (i >= m_sections.size()) ? Section("0") : m_sections.at(i);
|
const Section sec1 = (i >= m_sections.size()) ? Section("") : m_sections.at(i);
|
||||||
const Section sec2 =
|
const Section sec2 =
|
||||||
(i >= other.m_sections.size()) ? Section("0") : other.m_sections.at(i);
|
(i >= other.m_sections.size()) ? Section("") : other.m_sections.at(i);
|
||||||
if (sec1 != sec2)
|
if (sec1 != sec2)
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
@ -103,8 +103,11 @@ QDebug operator<<(QDebug debug, const Version& v)
|
|||||||
|
|
||||||
debug.nospace() << "Version{ string: " << v.toString() << ", sections: [ ";
|
debug.nospace() << "Version{ string: " << v.toString() << ", sections: [ ";
|
||||||
|
|
||||||
|
bool first = true;
|
||||||
for (auto s : v.m_sections) {
|
for (auto s : v.m_sections) {
|
||||||
debug.nospace() << s.m_fullString << ", ";
|
if (!first) debug.nospace() << ", ";
|
||||||
|
debug.nospace() << s.m_fullString;
|
||||||
|
first = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
debug.nospace() << " ]" << " }";
|
debug.nospace() << " ]" << " }";
|
||||||
|
@ -69,6 +69,7 @@ private:
|
|||||||
explicit Section(const QString &fullString)
|
explicit Section(const QString &fullString)
|
||||||
{
|
{
|
||||||
m_fullString = fullString;
|
m_fullString = fullString;
|
||||||
|
m_isNull = true;
|
||||||
int cutoff = m_fullString.size();
|
int cutoff = m_fullString.size();
|
||||||
for(int i = 0; i < m_fullString.size(); i++)
|
for(int i = 0; i < m_fullString.size(); i++)
|
||||||
{
|
{
|
||||||
@ -86,6 +87,7 @@ private:
|
|||||||
if(numPart.size())
|
if(numPart.size())
|
||||||
{
|
{
|
||||||
numValid = true;
|
numValid = true;
|
||||||
|
m_isNull = false;
|
||||||
m_numPart = numPart.toInt();
|
m_numPart = numPart.toInt();
|
||||||
}
|
}
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
|
||||||
@ -95,6 +97,7 @@ private:
|
|||||||
#endif
|
#endif
|
||||||
if(stringPart.size())
|
if(stringPart.size())
|
||||||
{
|
{
|
||||||
|
m_isNull = false;
|
||||||
m_stringPart = stringPart.toString();
|
m_stringPart = stringPart.toString();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -103,9 +106,17 @@ private:
|
|||||||
int m_numPart = 0;
|
int m_numPart = 0;
|
||||||
QString m_stringPart;
|
QString m_stringPart;
|
||||||
QString m_fullString;
|
QString m_fullString;
|
||||||
|
bool m_isNull;
|
||||||
|
|
||||||
inline bool operator!=(const Section &other) const
|
inline bool operator!=(const Section &other) const
|
||||||
{
|
{
|
||||||
|
if (m_isNull && other.numValid) {
|
||||||
|
return 0 != other.m_numPart;
|
||||||
|
} else if (numValid && other.m_isNull) {
|
||||||
|
return m_numPart != 0;
|
||||||
|
} else if (m_isNull || other.m_isNull) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if(numValid && other.numValid)
|
if(numValid && other.numValid)
|
||||||
{
|
{
|
||||||
return m_numPart != other.m_numPart || m_stringPart != other.m_stringPart;
|
return m_numPart != other.m_numPart || m_stringPart != other.m_stringPart;
|
||||||
@ -116,7 +127,14 @@ private:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
inline bool operator<(const Section &other) const
|
inline bool operator<(const Section &other) const
|
||||||
{
|
{
|
||||||
|
if (m_isNull && other.numValid) {
|
||||||
|
return 0 < other.m_numPart;
|
||||||
|
} else if (numValid && other.m_isNull) {
|
||||||
|
return m_numPart < 0;
|
||||||
|
} else if (m_isNull || other.m_isNull) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
if(numValid && other.numValid)
|
if(numValid && other.numValid)
|
||||||
{
|
{
|
||||||
if(m_numPart < other.m_numPart)
|
if(m_numPart < other.m_numPart)
|
||||||
@ -132,6 +150,13 @@ private:
|
|||||||
}
|
}
|
||||||
inline bool operator>(const Section &other) const
|
inline bool operator>(const Section &other) const
|
||||||
{
|
{
|
||||||
|
if (m_isNull && other.numValid) {
|
||||||
|
return 0 > other.m_numPart;
|
||||||
|
} else if (numValid && other.m_isNull) {
|
||||||
|
return m_numPart > 0;
|
||||||
|
} else if (m_isNull || other.m_isNull) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if(numValid && other.numValid)
|
if(numValid && other.numValid)
|
||||||
{
|
{
|
||||||
if(m_numPart > other.m_numPart)
|
if(m_numPart > other.m_numPart)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user