X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fmessage.h;h=1d366a2eee32ea56ca711461ea46c242af19016f;hp=5641794214a5449611e533d5ab3528276e75b485;hb=af456476e906a564d9faf3381b8bc3111fdb2bbd;hpb=850f5ae9b96c609f70cdb565bb19054131487714 diff --git a/src/common/message.h b/src/common/message.h index 56417942..1d366a2e 100644 --- a/src/common/message.h +++ b/src/common/message.h @@ -18,8 +18,8 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ -#ifndef _MESSAGE_H_ -#define _MESSAGE_H_ +#ifndef MESSAGE_H_ +#define MESSAGE_H_ #include #include @@ -33,19 +33,20 @@ class Message { public: /** The different types a message can have for display */ enum Type { - Plain = 0x0001, - Notice = 0x0002, - Action = 0x0004, - Nick = 0x0008, - Mode = 0x0010, - Join = 0x0020, - Part = 0x0040, - Quit = 0x0080, - Kick = 0x0100, - Kill = 0x0200, - Server = 0x0400, - Info = 0x0800, - Error = 0x1000 + Plain = 0x0001, + Notice = 0x0002, + Action = 0x0004, + Nick = 0x0008, + Mode = 0x0010, + Join = 0x0020, + Part = 0x0040, + Quit = 0x0080, + Kick = 0x0100, + Kill = 0x0200, + Server = 0x0400, + Info = 0x0800, + Error = 0x1000, + DayChange = 0x2000 }; // DO NOT CHANGE without knowing what you do, some of these flags are stored in the database @@ -54,6 +55,7 @@ public: Self = 0x01, Highlight = 0x02, Redirected = 0x04, + ServerMsg = 0x08, Backlog = 0x80 }; Q_DECLARE_FLAGS(Flags, Flag) @@ -63,6 +65,7 @@ public: Message(const QDateTime &ts, const BufferInfo &buffer = BufferInfo(), Type type = Plain, const QString &contents = "", const QString &sender = "", Flags flags = None); + inline static Message ChangeOfDay(const QDateTime &day) { return Message(day, BufferInfo(), DayChange, tr("Day changed to %1").arg(day.toString("dddd MMMM d yyyy"))); } inline MsgId msgId() const { return _msgId; } inline void setMsgId(MsgId id) { _msgId = id; } @@ -75,6 +78,8 @@ public: void setFlags(Flags flags); + inline bool operator<(const Message &other) const { return _msgId < other._msgId; } + private: QDateTime _timestamp; MsgId _msgId; @@ -86,12 +91,14 @@ private: QString _formattedTimestamp, _formattedSender, _formattedText; // cache - friend QDataStream &operator>>(QDataStream &in, Message &msg); }; +typedef QList MessageList; + QDataStream &operator<<(QDataStream &out, const Message &msg); QDataStream &operator>>(QDataStream &in, Message &msg); +QDebug operator<<(QDebug dbg, const Message &msg); Q_DECLARE_METATYPE(Message) Q_DECLARE_OPERATORS_FOR_FLAGS(Message::Flags)