Q_OBJECT
public:
- enum MessageRole {
+ enum MessageModelRole {
DisplayRole = Qt::DisplayRole,
EditRole = Qt::EditRole,
- MsgIdRole = Qt::UserRole,
+ BackgroundRole = Qt::BackgroundRole,
+ MessageRole = Qt::UserRole,
+ MsgIdRole,
BufferIdRole,
TypeRole,
FlagsRole,
MessageModel(QObject *parent);
- inline QModelIndex index(int row, int column, const QModelIndex &/*parent*/ = QModelIndex()) const { return createIndex(row, column); }
+ inline QModelIndex index(int row, int column, const QModelIndex &parent = QModelIndex()) const;
inline QModelIndex parent(const QModelIndex &) const { return QModelIndex(); }
inline int rowCount(const QModelIndex &parent = QModelIndex()) const { return parent.isValid() ? 0 : messageCount(); }
inline int columnCount(const QModelIndex &/*parent*/ = QModelIndex()) const { return 3; }
void clear();
+signals:
+ void finishedBacklogFetch(BufferId bufferId);
+
public slots:
void requestBacklog(BufferId bufferId);
void messagesReceived(BufferId bufferId, int count);
void buffersPermanentlyMerged(BufferId bufferId1, BufferId bufferId2);
+ void insertErrorMessage(BufferInfo bufferInfo, const QString &errorString);
protected:
// virtual MessageModelItem *createMessageModelItem(const Message &) = 0;
QHash<BufferId, int> _messagesWaiting;
};
+// inlines
+QModelIndex MessageModel::index(int row, int column, const QModelIndex &parent) const {
+ if(row < 0 || row >= rowCount(parent) || column < 0 || column >= columnCount(parent))
+ return QModelIndex();
+
+ return createIndex(row, column);
+}
+
// **************************************************
// MessageModelItem
// **************************************************
* Subclasses need to provide Qt::DisplayRole at least, which should describe the plaintext
* strings without formattings (e.g. for searching purposes).
*/
- MessageModelItem(const Message &);
+ MessageModelItem() {}
inline virtual ~MessageModelItem() {}
virtual QVariant data(int column, int role) const;
virtual bool setData(int column, const QVariant &value, int role);
- inline const Message &message() const { return _msg; }
- inline const QDateTime ×tamp() const { return _msg.timestamp(); }
- inline const MsgId &msgId() const { return _msg.msgId(); }
- inline const BufferId &bufferId() const { return _msg.bufferId(); }
- inline void setBufferId(BufferId bufferId) { _msg.setBufferId(bufferId); }
- inline Message::Type msgType() const { return _msg.type(); }
- inline Message::Flags msgFlags() const { return _msg.flags(); }
+ virtual const Message &message() const = 0;
+ virtual const QDateTime ×tamp() const = 0;
+ virtual const MsgId &msgId() const = 0;
+ virtual const BufferId &bufferId() const = 0;
+ virtual void setBufferId(BufferId bufferId) = 0;
+ virtual Message::Type msgType() const = 0;
+ virtual Message::Flags msgFlags() const = 0;
// For sorting
bool operator<(const MessageModelItem &) const;
static bool lessThan(const MessageModelItem *m1, const MessageModelItem *m2);
private:
- Message _msg;
BufferId _redirectedTo;
};