X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fmessagemodel.h;h=33321d53d1c1ab88f32e38767e72dfdd3387a718;hp=5b756dfecde7feb031787e954dacc505137264c6;hb=f824db0e31b54969e0b7fa0b5405b1e9173d482c;hpb=348384bd80c0896b665d807763d8d837e3b1fb3d diff --git a/src/client/messagemodel.h b/src/client/messagemodel.h index 5b756dfe..33321d53 100644 --- a/src/client/messagemodel.h +++ b/src/client/messagemodel.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel IRC Team * + * Copyright (C) 2005-09 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -44,6 +44,7 @@ public: TimestampRole, FormatRole, ColumnTypeRole, + RedirectedToRole, UserRole }; @@ -55,7 +56,7 @@ public: inline QModelIndex index(int row, int column, const QModelIndex &/*parent*/ = QModelIndex()) const { return createIndex(row, column); } inline QModelIndex parent(const QModelIndex &) const { return QModelIndex(); } - inline int rowCount(const QModelIndex &/*parent*/ = QModelIndex()) const { return _messageList.count(); } + inline int rowCount(const QModelIndex &parent = QModelIndex()) const { return parent.isValid() ? 0 : _messageList.count(); } inline int columnCount(const QModelIndex &/*parent*/ = QModelIndex()) const { return 3; } virtual QVariant data(const QModelIndex &index, int role) const; @@ -68,6 +69,11 @@ public: void clear(); +public slots: + void requestBacklog(BufferId bufferId); + void messagesReceived(BufferId bufferId, int count); + void buffersPermanentlyMerged(BufferId bufferId1, BufferId bufferId2); + protected: virtual MessageModelItem *createMessageModelItem(const Message &) = 0; virtual void customEvent(QEvent *event); @@ -84,6 +90,7 @@ private: QList _messageBuffer; QTimer _dayChangeTimer; QDateTime _nextDayChange; + QHash _messagesWaiting; }; // ************************************************** @@ -100,11 +107,12 @@ public: inline virtual ~MessageModelItem() {} virtual QVariant data(int column, int role) const; - virtual bool setData(int column, const QVariant &value, int role) = 0; + virtual bool setData(int column, const QVariant &value, int role); inline const QDateTime &timeStamp() const { return _timestamp; } inline MsgId msgId() const { return _msgId; } inline BufferId bufferId() const { return _bufferId; } + inline void setBufferId(BufferId bufferId) { _bufferId = bufferId; } inline Message::Type msgType() const { return _type; } inline Message::Flags msgFlags() const { return _flags; } @@ -118,8 +126,11 @@ private: QDateTime _timestamp; MsgId _msgId; BufferId _bufferId; + BufferId _redirectedTo; Message::Type _type; Message::Flags _flags; }; +QDebug operator<<(QDebug dbg, const MessageModelItem &msgItem); + #endif