X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fclient%2Fbuffer.cpp;h=9108d690bafc6e49d972887d496a1e5d3c4299cb;hb=fa4d0a5606f0c9ed49e196278611fce6b017fb0b;hp=241e2e687ae8eeff26f7be1b0386b8aef1a79fae;hpb=e416a73af88ef581b262745feeea0add49779395;p=quassel.git diff --git a/src/client/buffer.cpp b/src/client/buffer.cpp index 241e2e68..9108d690 100644 --- a/src/client/buffer.cpp +++ b/src/client/buffer.cpp @@ -30,11 +30,8 @@ Buffer::Buffer(BufferInfo bufferid, QObject *parent) : QObject(parent), - _bufferInfo(bufferid), - _isVisible(false), - _activityLevel(NoActivity) + _bufferInfo(bufferid) { - } BufferInfo Buffer::bufferInfo() const { @@ -42,88 +39,3 @@ 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()); - //qDebug() << "setting last seen" << _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); - } -} - -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; - - if(msg.flags() & Message::Self) // don't update activity for our own messages - return; - - if(lastSeenMsg().isValid() && lastSeenMsg() >= msg.msgId()) - return; - - ActivityLevel level = activityLevel() | OtherActivity; - if(msg.type() & (Message::Plain | Message::Notice | Message::Action)) - level |= NewMessage; - - if(msg.flags() & Message::Highlight) - level |= Highlight; - - if(level != activityLevel()) - setActivityLevel(level); -}