X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fbuffer.cpp;h=df7863967efcb3f8c06ca234928c14afc1af0eb4;hp=de3bfcf6d7bbb686a4a5ee672936a65395232575;hb=e1b6d538b7c4cc279f9218614e23adb5d8a81fe5;hpb=df0846fca1b6a8427498a125b32f4da6d236a7fc;ds=sidebyside diff --git a/src/client/buffer.cpp b/src/client/buffer.cpp index de3bfcf6..df786396 100644 --- a/src/client/buffer.cpp +++ b/src/client/buffer.cpp @@ -42,53 +42,17 @@ BufferInfo Buffer::bufferInfo() const { return _bufferInfo; } -const QList &Buffer::contents() const { - return layoutedMsgs; -} - -void Buffer::appendMsg(const Message &msg) { - updateActivityLevel(msg); - AbstractUiMsg *m = Client::layoutMsg(msg); - layoutedMsgs.append(m); - emit msgAppended(m); -} - -void Buffer::prependMsg(const Message &msg) { - // check for duplicate first - if(!layoutedMsgs.isEmpty() && msg.msgId() >= layoutedMsgs.first()->msgId()) { - return; - } - updateActivityLevel(msg); - layoutQueue.append(msg); -} - -bool Buffer::layoutMsg() { - if(layoutQueue.isEmpty()) - return false; - - AbstractUiMsg *m = Client::layoutMsg(layoutQueue.takeFirst()); - layoutedMsgs.prepend(m); - emit msgPrepended(m); - - return !layoutQueue.isEmpty(); -} - void Buffer::setVisible(bool visible) { _isVisible = visible; setActivityLevel(NoActivity); - if(layoutedMsgs.isEmpty()) - return; - setLastSeenMsg(layoutedMsgs.last()->msgId()); + if(_lastRcvdMsg.msgId() > 0) setLastSeenMsg(_lastRcvdMsg.msgId()); } void Buffer::setLastSeenMsg(const MsgId &msgId) { - // qDebug() << "want to set lastSeen:" << bufferInfo() << seen << lastSeen(); const MsgId oldLastSeen = lastSeenMsg(); if(!oldLastSeen.isValid() || (msgId.isValid() && msgId > oldLastSeen)) { - //qDebug() << "setting:" << bufferInfo().bufferName() << seen; _lastSeenMsg = msgId; Client::setBufferLastSeenMsg(bufferInfo().bufferId(), msgId); - //qDebug() << "setting lastSeen:" << bufferInfo() << lastSeen(); setActivityLevel(NoActivity); } } @@ -97,11 +61,14 @@ void Buffer::setActivityLevel(ActivityLevel level) { _activityLevel = level; if(bufferInfo().bufferId() > 0) { Client::networkModel()->setBufferActivity(bufferInfo(), level); - //qDebug() << "setting level:" << bufferInfo() << lastSeen() << level; } } void Buffer::updateActivityLevel(const Message &msg) { + // FIXME dirty hack to allow the lastSeen stuff to continue to work + // will be made much nicer once Buffer dies, I hope... + if(msg.msgId() > _lastRcvdMsg.msgId()) _lastRcvdMsg = msg; + if(isVisible()) return;