X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fclient%2Fbuffer.cpp;h=9108d690bafc6e49d972887d496a1e5d3c4299cb;hb=28d1a6cc6e9b153dbed0257241abb8aedf706ac2;hp=54bd81a1c02b06def25a1a8033e0dad492c35c78;hpb=8010224cf5bfe5685dc2cf535e8dc1ec19c4c364;p=quassel.git diff --git a/src/client/buffer.cpp b/src/client/buffer.cpp index 54bd81a1..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,58 +39,3 @@ BufferInfo Buffer::bufferInfo() const { return _bufferInfo; } -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) { - updateActivityLevel(msg); - layoutQueue.append(msg); -} - -bool Buffer::layoutMsg() { - if(layoutQueue.count()) { - AbstractUiMsg *m = Client::layoutMsg(layoutQueue.takeFirst()); - layoutedMsgs.prepend(m); - emit msgPrepended(m); - } - return layoutQueue.count(); -} - -void Buffer::setVisible(bool visible) { - _isVisible = visible; - setActivityLevel(NoActivity); - if(!layoutedMsgs.count()) return; - setLastSeen(layoutedMsgs.last()->timestamp()); -} - -void Buffer::setLastSeen(const QDateTime &seen) { - if(seen.isValid() && seen > lastSeen()) { //qDebug() << "setting:" << bufferInfo().bufferName() << seen; - _lastSeen = seen; - Client::bufferSyncer()->requestSetLastSeen(bufferInfo().bufferId(), seen); - setActivityLevel(NoActivity); - } -} - -void Buffer::setActivityLevel(ActivityLevel level) { - _activityLevel = level; - if(bufferInfo().bufferId() > 0) Client::networkModel()->setBufferActivity(bufferInfo(), level); -} - -void Buffer::updateActivityLevel(const Message &msg) { - if(isVisible()) return; - if(lastSeen().isValid() && lastSeen() >= msg.timestamp()) return; - - ActivityLevel level = activityLevel() | OtherActivity; - if(msg.type() == Message::Plain || msg.type() == Message::Notice) level |= NewMessage; - if(msg.flags() & Message::Highlight) level |= Highlight; - - if(level != activityLevel()) setActivityLevel(level); -}