X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fbuffersyncer.cpp;h=ca146b55b8b6590cf0c3980eb19b6ed4523dc43e;hp=a1b5b63b44a3122bc4eb460bcd0b4bdf76e66b90;hb=fd16e241d2fd1f33f4625b3255956f025a67273b;hpb=502b47a608a55374bd28b6b698971f9f697e2d20 diff --git a/src/common/buffersyncer.cpp b/src/common/buffersyncer.cpp index a1b5b63b..ca146b55 100644 --- a/src/common/buffersyncer.cpp +++ b/src/common/buffersyncer.cpp @@ -27,10 +27,11 @@ BufferSyncer::BufferSyncer(QObject *parent) } -BufferSyncer::BufferSyncer(const QHash &lastSeenMsg, const QHash &markerLines, QObject *parent) +BufferSyncer::BufferSyncer(const QHash &lastSeenMsg, const QHash &markerLines, const QHash &activities, QObject *parent) : SyncableObject(parent), _lastSeenMsg(lastSeenMsg), - _markerLines(markerLines) + _markerLines(markerLines), + _bufferActivities(activities) { } @@ -124,6 +125,35 @@ void BufferSyncer::initSetMarkerLines(const QVariantList &list) } +QVariantList BufferSyncer::initActivities() const +{ + QVariantList list; + QHash::const_iterator iter = _bufferActivities.constBegin(); + while (iter != _bufferActivities.constEnd()) { + list << QVariant::fromValue(iter.key()) + << QVariant::fromValue((int) iter.value()); + ++iter; + } + return list; +} + + +void BufferSyncer::initSetActivities(const QVariantList &list) +{ + _bufferActivities.clear(); + Q_ASSERT(list.count() % 2 == 0); + for (int i = 0; i < list.count(); i += 2) { + setBufferActivity(list.at(i).value(), list.at(i+1).value()); + } +} + + +Message::Types BufferSyncer::activity(BufferId buffer) const +{ + return _bufferActivities.value(buffer, Message::Types()); +} + + void BufferSyncer::removeBuffer(BufferId buffer) { if (_lastSeenMsg.contains(buffer))