X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Ftypes.h;h=e2a9aab5e359f7242d637a8aaee73c6d97fe15cd;hp=d7b44044303f323bc6d60480f678f418561add21;hb=579e559a6322209df7cd51c34801fecff5fe734b;hpb=6a835281b265df6a06b7f41109ad2d449899fed0 diff --git a/src/common/types.h b/src/common/types.h index d7b44044..e2a9aab5 100644 --- a/src/common/types.h +++ b/src/common/types.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2018 by the Quassel Project * + * Copyright (C) 2005-2019 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -22,13 +22,12 @@ #include +#include #include +#include #include -#include -#include #include -#include -#include +#include class SignedId { @@ -40,29 +39,52 @@ public: inline qint32 toInt() const { return id; } inline bool isValid() const { return id > 0; } - inline bool operator==(const SignedId &other) const { return id == other.id; } - inline bool operator!=(const SignedId &other) const { return id != other.id; } - inline bool operator<(const SignedId &other) const { return id < other.id; } - inline bool operator<=(const SignedId &other) const { return id <= other.id; } - inline bool operator>(const SignedId &other) const { return id > other.id; } - inline bool operator>=(const SignedId &other) const { return id >= other.id; } + inline bool operator==(const SignedId& other) const { return id == other.id; } + inline bool operator!=(const SignedId& other) const { return id != other.id; } + inline bool operator<(const SignedId& other) const { return id < other.id; } + inline bool operator<=(const SignedId& other) const { return id <= other.id; } + inline bool operator>(const SignedId& other) const { return id > other.id; } + inline bool operator>=(const SignedId& other) const { return id >= other.id; } inline bool operator==(int i) const { return id == i; } inline bool operator!=(int i) const { return id != i; } inline bool operator<(int i) const { return id < i; } inline bool operator>(int i) const { return id > i; } inline bool operator<=(int i) const { return id <= i; } - inline SignedId operator++(int) { id++; return *this; } - //inline operator int() const { return toInt(); } // no automatic conversion! + inline SignedId operator++(int) + { + id++; + return *this; + } + // inline operator int() const { return toInt(); } // no automatic conversion! - friend QDataStream &operator>>(QDataStream &in, SignedId &signedId); + friend QDataStream& operator>>(QDataStream& in, SignedId& signedId); }; -inline QDataStream &operator<<(QDataStream &out, const SignedId &signedId) { out << signedId.toInt(); return out; } -inline QDataStream &operator>>(QDataStream &in, SignedId &signedId) { in >> signedId.id; return in; } -inline QTextStream &operator<<(QTextStream &out, const SignedId &signedId) { out << QString::number(signedId.toInt()); return out; } -inline QDebug operator<<(QDebug dbg, const SignedId &signedId) { dbg.space() << signedId.toInt(); return dbg; } -inline uint qHash(const SignedId &id) { return qHash(id.toInt()); } +inline QDataStream& operator<<(QDataStream& out, const SignedId& signedId) +{ + out << signedId.toInt(); + return out; +} +inline QDataStream& operator>>(QDataStream& in, SignedId& signedId) +{ + in >> signedId.id; + return in; +} +inline QTextStream& operator<<(QTextStream& out, const SignedId& signedId) +{ + out << QString::number(signedId.toInt()); + return out; +} +inline QDebug operator<<(QDebug dbg, const SignedId& signedId) +{ + dbg.space() << signedId.toInt(); + return dbg; +} +inline uint qHash(const SignedId& id) +{ + return qHash(id.toInt()); +} class SignedId64 { @@ -74,57 +96,90 @@ public: inline qint64 toQint64() const { return id; } inline bool isValid() const { return id > 0; } - inline bool operator==(const SignedId64 &other) const { return id == other.id; } - inline bool operator!=(const SignedId64 &other) const { return id != other.id; } - inline bool operator<(const SignedId64 &other) const { return id < other.id; } - inline bool operator<=(const SignedId64 &other) const { return id <= other.id; } - inline bool operator>(const SignedId64 &other) const { return id > other.id; } - inline bool operator>=(const SignedId64 &other) const { return id >= other.id; } + inline bool operator==(const SignedId64& other) const { return id == other.id; } + inline bool operator!=(const SignedId64& other) const { return id != other.id; } + inline bool operator<(const SignedId64& other) const { return id < other.id; } + inline bool operator<=(const SignedId64& other) const { return id <= other.id; } + inline bool operator>(const SignedId64& other) const { return id > other.id; } + inline bool operator>=(const SignedId64& other) const { return id >= other.id; } inline bool operator==(qint64 i) const { return id == i; } inline bool operator!=(qint64 i) const { return id != i; } inline bool operator<(qint64 i) const { return id < i; } inline bool operator>(qint64 i) const { return id > i; } inline bool operator<=(qint64 i) const { return id <= i; } - inline SignedId64 operator++(int) { id++; return *this; } - //inline operator int() const { return toQint64(); } // no automatic conversion! + inline SignedId64 operator++(int) + { + id++; + return *this; + } + // inline operator int() const { return toQint64(); } // no automatic conversion! - friend QDataStream &operator>>(QDataStream &in, SignedId64 &signedId); + friend QDataStream& operator>>(QDataStream& in, SignedId64& signedId); }; -QDataStream &operator<<(QDataStream &out, const SignedId64 &signedId); -QDataStream &operator>>(QDataStream &in, SignedId64 &signedId); -inline QTextStream &operator<<(QTextStream &out, const SignedId64 &signedId) { out << QString::number(signedId.toQint64()); return out; } -inline QDebug operator<<(QDebug dbg, const SignedId64 &signedId) { dbg.space() << signedId.toQint64(); return dbg; } -inline uint qHash(const SignedId64 &id) { return qHash(id.toQint64()); } +QDataStream& operator<<(QDataStream& out, const SignedId64& signedId); +QDataStream& operator>>(QDataStream& in, SignedId64& signedId); +inline QTextStream& operator<<(QTextStream& out, const SignedId64& signedId) +{ + out << QString::number(signedId.toQint64()); + return out; +} +inline QDebug operator<<(QDebug dbg, const SignedId64& signedId) +{ + dbg.space() << signedId.toQint64(); + return dbg; +} +inline uint qHash(const SignedId64& id) +{ + return qHash(id.toQint64()); +} -struct UserId : public SignedId { - inline UserId(int _id = 0) : SignedId(_id) {} - //inline operator QVariant() const { return QVariant::fromValue(*this); } // no automatic conversion! +struct UserId : public SignedId +{ + inline UserId(int _id = 0) + : SignedId(_id) + {} + // inline operator QVariant() const { return QVariant::fromValue(*this); } // no automatic conversion! }; -struct MsgId : public SignedId64 { - inline MsgId(qint64 _id = 0) : SignedId64(_id) {} - //inline operator QVariant() const { return QVariant::fromValue(*this); } +struct MsgId : public SignedId64 +{ + inline MsgId(qint64 _id = 0) + : SignedId64(_id) + {} + // inline operator QVariant() const { return QVariant::fromValue(*this); } }; -struct BufferId : public SignedId { - inline BufferId(int _id = 0) : SignedId(_id) {} - //inline operator QVariant() const { return QVariant::fromValue(*this); } +struct BufferId : public SignedId +{ + inline BufferId(int _id = 0) + : SignedId(_id) + {} + // inline operator QVariant() const { return QVariant::fromValue(*this); } }; -struct NetworkId : public SignedId { - inline NetworkId(int _id = 0) : SignedId(_id) {} - //inline operator QVariant() const { return QVariant::fromValue(*this); } +struct NetworkId : public SignedId +{ + inline NetworkId(int _id = 0) + : SignedId(_id) + {} + // inline operator QVariant() const { return QVariant::fromValue(*this); } }; -struct IdentityId : public SignedId { - inline IdentityId(int _id = 0) : SignedId(_id) {} - //inline operator QVariant() const { return QVariant::fromValue(*this); } +struct IdentityId : public SignedId +{ + inline IdentityId(int _id = 0) + : SignedId(_id) + {} + // inline operator QVariant() const { return QVariant::fromValue(*this); } }; -struct AccountId : public SignedId { - inline AccountId(int _id = 0) : SignedId(_id) {} +struct AccountId : public SignedId +{ + inline AccountId(int _id = 0) + : SignedId(_id) + {} }; Q_DECLARE_METATYPE(UserId) @@ -137,9 +192,10 @@ Q_DECLARE_METATYPE(AccountId) Q_DECLARE_METATYPE(QHostAddress) // a few typedefs -typedef QList MsgIdList; -typedef QList BufferIdList; +using MsgIdList = QList; +using BufferIdList = QList; +#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) /** * Catch-all stream serialization operator for enum types. * @@ -147,9 +203,9 @@ typedef QList BufferIdList; * @param[in] value Value to serialize * @returns A reference to the stream */ -template::value>::type> -QDataStream &operator<<(QDataStream &out, T value) { +template::value>::type> +QDataStream& operator<<(QDataStream& out, T value) +{ out << static_cast::type>(value); return out; } @@ -161,11 +217,38 @@ QDataStream &operator<<(QDataStream &out, T value) { * @param[out] value Value to deserialize into * @returns A reference to the stream */ -template::value>::type> -QDataStream &operator>>(QDataStream &in, T &value) { +template::value>::type> +QDataStream& operator>>(QDataStream& in, T& value) +{ typename std::underlying_type::type v; in >> v; value = static_cast(v); return in; } +#endif + +// STL-compliant hash functor for Qt types +template +struct Hash +{ + uint operator()(const T& t) const + { + return qHash(t); + } +}; + +// Exceptions + +/** + * Thrown during initialization to enforce exiting the application before the event loop is started + */ +struct ExitException +{ + int exitCode; + QString errorString; + + ExitException(int code = EXIT_FAILURE, QString error = {}) + : exitCode(code) + , errorString(std::move(error)) + {} +};