X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Ftypes.h;h=949306b8faae2433ec7dc92862074596155d0029;hp=9e62ffd830c418d52a45a3a7dccf4371a8805979;hb=0c9cd0eef379e1d3e10a75cc8506a7e65f95fd67;hpb=d6b056e936ec441258d291b7a8af7b83f9f53016 diff --git a/src/common/types.h b/src/common/types.h index 9e62ffd8..949306b8 100644 --- a/src/common/types.h +++ b/src/common/types.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-07 by the Quassel IRC Team * + * Copyright (C) 2005-08 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -21,12 +21,74 @@ #ifndef _TYPES_H_ #define _TYPES_H_ +#include #include +#include -typedef uint UserId; //!< Identifies a core user. -typedef uint MsgId; //!< Identifies a message. -typedef uint BufferId; //!< Identifies a buffer. -typedef uint NetworkId; //!< Identifies an IRC Network. +class SignedId { + protected: + qint32 id; + + public: + inline SignedId(int _id = 0) { id = _id; } + 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==(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! + + 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 QDebug operator<<(QDebug dbg, const SignedId &signedId) { dbg.space() << signedId.toInt(); return dbg; } +inline uint qHash(const SignedId &id) { return qHash(id.toInt()); } + +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 SignedId { + inline MsgId(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 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) {}; +}; + +Q_DECLARE_METATYPE(UserId); +Q_DECLARE_METATYPE(MsgId); +Q_DECLARE_METATYPE(BufferId); +Q_DECLARE_METATYPE(NetworkId); +Q_DECLARE_METATYPE(IdentityId); +Q_DECLARE_METATYPE(AccountId); //! Base class for exceptions. struct Exception {