X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fmessagemodel.cpp;h=02fc8740e6b7e8b86257df72867c22dfd5a6cc99;hp=28872dc7edac30cba7af997c0d2bfa8e2e20d458;hb=3258b69cab16d7a5cf80a27d166c0a3628fe60d2;hpb=22128f214112de5e4f3111e0a90f7d5d99e82dac diff --git a/src/client/messagemodel.cpp b/src/client/messagemodel.cpp index 28872dc7..02fc8740 100644 --- a/src/client/messagemodel.cpp +++ b/src/client/messagemodel.cpp @@ -99,16 +99,17 @@ void MessageModel::insertMessages(const QList &msglist) { } void MessageModel::insertMessageGroup(const QList &msglist) { - // the msglist can be assumed to be non empty - int idx = indexForId(msglist.first().msgId()); - int start = idx; - int end = idx + msglist.count() - 1; + Q_ASSERT(!msglist.isEmpty()); // the msglist can be assumed to be non empty + int start = indexForId(msglist.first().msgId()); + int end = start + msglist.count() - 1; MessageModelItem *dayChangeItem = 0; - - if(idx > 0) { - int prevIdx = idx - 1; - if(_messageList[prevIdx]->msgType() == Message::DayChange - && _messageList[prevIdx]->timeStamp() > msglist.value(0).timestamp()) { + bool relocatedMsg = false; + if(start > 0) { + // check if the preceeding msg is a daychange message and if so if + // we have to drop or relocate it at the end of this chunk + int prevIdx = start - 1; + if(_messageList.at(prevIdx)->msgType() == Message::DayChange + && _messageList.at(prevIdx)->timeStamp() > msglist.at(0).timestamp()) { beginRemoveRows(QModelIndex(), prevIdx, prevIdx); MessageModelItem *oldItem = _messageList.takeAt(prevIdx); if(msglist.last().timestamp() < oldItem->timeStamp()) { @@ -119,12 +120,19 @@ void MessageModel::insertMessageGroup(const QList &msglist) { } delete oldItem; endRemoveRows(); - idx--; + start--; + end--; + relocatedMsg = true; } } - if(!dayChangeItem && idx < _messageList.count() && _messageList[idx]->msgType() != Message::DayChange) { - QDateTime nextTs = _messageList[idx]->timeStamp(); + if(!dayChangeItem && start < _messageList.count()) { + // check if we need to insert a daychange message at the end of the this group + + // if this assert triggers then indexForId() would have found a spot right before a DayChangeMsg + // this should never happen as daychange messages share the msgId with the preceeding message + Q_ASSERT(_messageList[start]->msgType() != Message::DayChange); + QDateTime nextTs = _messageList[start]->timeStamp(); QDateTime prevTs = msglist.last().timestamp(); nextTs.setTimeSpec(Qt::UTC); prevTs.setTimeSpec(Qt::UTC); @@ -142,15 +150,29 @@ void MessageModel::insertMessageGroup(const QList &msglist) { if(dayChangeItem) end++; + Q_ASSERT(start == 0 || _messageList[start - 1]->msgId() < msglist.first().msgId()); + + if(start < _messageList.count()) { // && _messageList[start]->msgId() <= msglist.last().msgId()) { + qDebug() << *(_messageList[start]) << "<=" << msglist.last(); + qDebug() << start << end << msglist.count() << dayChangeItem << relocatedMsg; + } + Q_ASSERT(start == _messageList.count() || _messageList[start]->msgId() > msglist.last().msgId()); + + beginInsertRows(QModelIndex(), start, end); + int pos = start; foreach(Message msg, msglist) { - _messageList.insert(idx, createMessageModelItem(msg)); - idx++; + _messageList.insert(pos, createMessageModelItem(msg)); + pos++; } if(dayChangeItem) { - _messageList.insert(idx, dayChangeItem); + _messageList.insert(pos, dayChangeItem); + pos++; // needed for the following assert } endInsertRows(); + Q_ASSERT(start == 0 || _messageList[start - 1]->msgId() < _messageList[start]->msgId()); + Q_ASSERT(end + 1 == _messageList.count() || _messageList[end]->msgId() < _messageList[end + 1]->msgId()); + Q_ASSERT(pos - 1 == end); } int MessageModel::insertMessagesGracefully(const QList &msglist) { @@ -302,7 +324,6 @@ int MessageModel::indexForId(MsgId id) { void MessageModel::changeOfDay() { _dayChangeTimer.setInterval(86400000); - qDebug() << _nextDayChange; if(!_messageList.isEmpty()) { int idx = _messageList.count(); while(idx > 0 && _messageList[idx - 1]->timeStamp() > _nextDayChange) { @@ -359,3 +380,12 @@ bool MessageModelItem::operator==(const MessageModelItem &other) const { bool MessageModelItem::operator>(const MessageModelItem &other) const { return _msgId > other._msgId; } + +QDebug operator<<(QDebug dbg, const MessageModelItem &msgItem) { + dbg.nospace() << qPrintable(QString("MessageModelItem(MsgId:")) << msgItem.msgId() + << qPrintable(QString(",")) << msgItem.timeStamp() + << qPrintable(QString(", Type:")) << msgItem.msgType() + << qPrintable(QString(", Flags:")) << msgItem.msgFlags() << qPrintable(QString(")")) + << msgItem.data(1, Qt::DisplayRole).toString() << ":" << msgItem.data(2, Qt::DisplayRole).toString(); + return dbg; +}