mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-27 23:14:31 +00:00
Merge pull request #8953 from Chocobo1/constexpr
Add constexpr to various classes
This commit is contained in:
commit
1d25d95740
@ -38,30 +38,30 @@ class IndexInterval
|
||||
public:
|
||||
using IndexType = Index;
|
||||
|
||||
IndexInterval(IndexType first, IndexType last)
|
||||
IndexInterval(IndexType first, IndexType last) // add constexpr when using C++14
|
||||
: m_first {first}
|
||||
, m_last {last}
|
||||
{
|
||||
Q_ASSERT(first <= last);
|
||||
}
|
||||
|
||||
IndexType first() const
|
||||
constexpr IndexType first() const
|
||||
{
|
||||
return m_first;
|
||||
}
|
||||
|
||||
IndexType last() const
|
||||
constexpr IndexType last() const
|
||||
{
|
||||
return m_last;
|
||||
}
|
||||
|
||||
private:
|
||||
IndexType m_first;
|
||||
IndexType m_last;
|
||||
const IndexType m_first;
|
||||
const IndexType m_last;
|
||||
};
|
||||
|
||||
template <typename T>
|
||||
inline IndexInterval<T> makeInterval(T first, T last)
|
||||
constexpr IndexInterval<T> makeInterval(T first, T last)
|
||||
{
|
||||
return {first, last};
|
||||
}
|
||||
@ -99,7 +99,7 @@ public:
|
||||
|
||||
constexpr IndexType end() const
|
||||
{
|
||||
return m_first + m_size;
|
||||
return (m_first + m_size);
|
||||
}
|
||||
|
||||
constexpr IndexDiffType size() const
|
||||
@ -114,12 +114,12 @@ public:
|
||||
|
||||
constexpr IndexType last() const
|
||||
{
|
||||
return m_first + m_size - 1;
|
||||
return (m_first + m_size - 1);
|
||||
}
|
||||
|
||||
constexpr bool isEmpty() const
|
||||
{
|
||||
return m_size == 0;
|
||||
return (m_size == 0);
|
||||
}
|
||||
|
||||
private:
|
||||
|
@ -31,28 +31,3 @@
|
||||
const TriStateBool TriStateBool::Undefined(-1);
|
||||
const TriStateBool TriStateBool::False(0);
|
||||
const TriStateBool TriStateBool::True(1);
|
||||
|
||||
TriStateBool::operator int() const
|
||||
{
|
||||
return m_value;
|
||||
}
|
||||
|
||||
TriStateBool::TriStateBool(int value)
|
||||
{
|
||||
if (value < 0)
|
||||
m_value = -1;
|
||||
else if (value > 0)
|
||||
m_value = 1;
|
||||
else
|
||||
m_value = 0;
|
||||
}
|
||||
|
||||
bool TriStateBool::operator==(const TriStateBool &other) const
|
||||
{
|
||||
return (m_value == other.m_value);
|
||||
}
|
||||
|
||||
bool TriStateBool::operator!=(const TriStateBool &other) const
|
||||
{
|
||||
return !operator==(other);
|
||||
}
|
||||
|
@ -36,15 +36,29 @@ public:
|
||||
static const TriStateBool False;
|
||||
static const TriStateBool True;
|
||||
|
||||
TriStateBool() = default;
|
||||
TriStateBool(const TriStateBool &other) = default;
|
||||
constexpr TriStateBool() = default;
|
||||
constexpr TriStateBool(const TriStateBool &other) = default;
|
||||
explicit constexpr TriStateBool(int value)
|
||||
: m_value(value < 0 ? -1 : (value > 0 ? 1 : 0))
|
||||
{
|
||||
}
|
||||
|
||||
explicit TriStateBool(int value);
|
||||
explicit operator int() const;
|
||||
explicit constexpr operator int() const
|
||||
{
|
||||
return m_value;
|
||||
}
|
||||
|
||||
TriStateBool &operator=(const TriStateBool &other) = default;
|
||||
bool operator==(const TriStateBool &other) const;
|
||||
bool operator!=(const TriStateBool &other) const;
|
||||
TriStateBool &operator=(const TriStateBool &other) = default; // add constexpr when using C++14
|
||||
|
||||
constexpr bool operator==(const TriStateBool &other) const
|
||||
{
|
||||
return (m_value == other.m_value);
|
||||
}
|
||||
|
||||
constexpr bool operator!=(const TriStateBool &other) const
|
||||
{
|
||||
return !operator==(other);
|
||||
}
|
||||
|
||||
private:
|
||||
signed char m_value = -1; // Undefined by default
|
||||
|
@ -84,31 +84,31 @@ namespace Utils
|
||||
{
|
||||
}
|
||||
|
||||
ComponentType majorNumber() const
|
||||
constexpr ComponentType majorNumber() const
|
||||
{
|
||||
static_assert(N >= 1, "The number of version components is too small");
|
||||
return (*this)[0];
|
||||
return m_components[0];
|
||||
}
|
||||
|
||||
ComponentType minorNumber() const
|
||||
constexpr ComponentType minorNumber() const
|
||||
{
|
||||
static_assert(N >= 2, "The number of version components is too small");
|
||||
return (*this)[1];
|
||||
return m_components[1];
|
||||
}
|
||||
|
||||
ComponentType revisionNumber() const
|
||||
constexpr ComponentType revisionNumber() const
|
||||
{
|
||||
static_assert(N >= 3, "The number of version components is too small");
|
||||
return (*this)[2];
|
||||
return m_components[2];
|
||||
}
|
||||
|
||||
ComponentType patchNumber() const
|
||||
constexpr ComponentType patchNumber() const
|
||||
{
|
||||
static_assert(N >= 4, "The number of version components is too small");
|
||||
return (*this)[3];
|
||||
return m_components[3];
|
||||
}
|
||||
|
||||
ComponentType operator[](std::size_t i) const
|
||||
constexpr ComponentType operator[](const std::size_t i) const
|
||||
{
|
||||
return m_components.at(i);
|
||||
}
|
||||
@ -129,19 +129,19 @@ namespace Utils
|
||||
return res;
|
||||
}
|
||||
|
||||
bool operator==(const ThisType &other) const
|
||||
constexpr bool operator==(const ThisType &other) const
|
||||
{
|
||||
return m_components == other.m_components;
|
||||
return (m_components == other.m_components);
|
||||
}
|
||||
|
||||
bool operator<(const ThisType &other) const
|
||||
constexpr bool operator<(const ThisType &other) const
|
||||
{
|
||||
return m_components < other.m_components;
|
||||
return (m_components < other.m_components);
|
||||
}
|
||||
|
||||
bool operator>(const ThisType &other) const
|
||||
constexpr bool operator>(const ThisType &other) const
|
||||
{
|
||||
return m_components > other.m_components;
|
||||
return (m_components > other.m_components);
|
||||
}
|
||||
|
||||
template <typename StringClassWithSplitMethod>
|
||||
@ -150,7 +150,7 @@ namespace Utils
|
||||
try {
|
||||
return Version(s);
|
||||
}
|
||||
catch (std::runtime_error &er) {
|
||||
catch (const std::runtime_error &er) {
|
||||
qDebug() << "Error parsing version:" << er.what();
|
||||
return defaultVersion;
|
||||
}
|
||||
@ -186,10 +186,22 @@ namespace Utils
|
||||
};
|
||||
|
||||
template <typename T, std::size_t N, std::size_t Mandatory>
|
||||
inline bool operator!=(const Version<T, N, Mandatory> &left, const Version<T, N, Mandatory> &right)
|
||||
constexpr bool operator!=(const Version<T, N, Mandatory> &left, const Version<T, N, Mandatory> &right)
|
||||
{
|
||||
return !(left == right);
|
||||
}
|
||||
|
||||
template <typename T, std::size_t N, std::size_t Mandatory>
|
||||
constexpr bool operator<=(const Version<T, N, Mandatory> &left, const Version<T, N, Mandatory> &right)
|
||||
{
|
||||
return !(left > right);
|
||||
}
|
||||
|
||||
template <typename T, std::size_t N, std::size_t Mandatory>
|
||||
constexpr bool operator>=(const Version<T, N, Mandatory> &left, const Version<T, N, Mandatory> &right)
|
||||
{
|
||||
return !(left < right);
|
||||
}
|
||||
}
|
||||
|
||||
#endif // QBITTORRENT_UTILS_VERSION_H
|
||||
|
Loading…
x
Reference in New Issue
Block a user