X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fclient%2Fbuffer.cpp;h=c6737bc579e3524e86831310770983bc99859177;hb=1abcb461979ff68943e16c5c1b3fe0536217ff59;hp=a316ae15a9086cc8bb8b8c38454876af3a99a868;hpb=08aac67d4dc813ed541a81d06fb83d9c4fec5834;p=quassel.git diff --git a/src/client/buffer.cpp b/src/client/buffer.cpp index a316ae15..c6737bc5 100644 --- a/src/client/buffer.cpp +++ b/src/client/buffer.cpp @@ -21,14 +21,20 @@ #include "buffer.h" +#include "buffersyncer.h" #include "client.h" +#include "networkmodel.h" +#include "quasselui.h" #include "util.h" Buffer::Buffer(BufferInfo bufferid, QObject *parent) : QObject(parent), - _bufferInfo(bufferid) + _bufferInfo(bufferid), + _isVisible(false), + _activityLevel(NoActivity) { + } BufferInfo Buffer::bufferInfo() const { @@ -41,12 +47,18 @@ QList Buffer::contents() const { } 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(contents().count() > 0 && msg.msgId() >= contents().first()->msgId()) { + return; + } + updateActivityLevel(msg); layoutQueue.append(msg); } @@ -59,3 +71,50 @@ bool Buffer::layoutMsg() { return layoutQueue.count(); } +void Buffer::setVisible(bool visible) { + _isVisible = visible; + setActivityLevel(NoActivity); + if(!layoutedMsgs.count()) return; + setLastSeenMsg(layoutedMsgs.last()->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) { + 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); +}