/***************************************************************************
- * Copyright (C) 2005-08 by the Quassel IRC Team *
+ * Copyright (C) 2005-2014 by the Quassel Project *
* devel@quassel-irc.org *
* *
* This program is free software; you can redistribute it and/or modify *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
- * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
***************************************************************************/
#include "buffersyncer.h"
-BufferSyncer::BufferSyncer(QObject *parent) : SyncableObject(parent) {
+INIT_SYNCABLE_OBJECT(BufferSyncer)
+BufferSyncer::BufferSyncer(QObject *parent)
+ : SyncableObject(parent)
+{
+}
+BufferSyncer::BufferSyncer(const QHash<BufferId, MsgId> &lastSeenMsg, const QHash<BufferId, MsgId> &markerLines, QObject *parent)
+ : SyncableObject(parent),
+ _lastSeenMsg(lastSeenMsg),
+ _markerLines(markerLines)
+{
}
-QDateTime BufferSyncer::lastSeen(BufferId buffer) const {
- if(_lastSeen.contains(buffer)) return _lastSeen[buffer];
- return QDateTime();
+MsgId BufferSyncer::lastSeenMsg(BufferId buffer) const
+{
+ return _lastSeenMsg.value(buffer, MsgId());
+}
+
+
+bool BufferSyncer::setLastSeenMsg(BufferId buffer, const MsgId &msgId)
+{
+ if (!msgId.isValid())
+ return false;
+
+ const MsgId oldLastSeenMsg = lastSeenMsg(buffer);
+ if (!oldLastSeenMsg.isValid() || oldLastSeenMsg < msgId) {
+ _lastSeenMsg[buffer] = msgId;
+ SYNC(ARG(buffer), ARG(msgId))
+ emit lastSeenMsgSet(buffer, msgId);
+ return true;
+ }
+ return false;
}
-bool BufferSyncer::setLastSeen(BufferId buffer, const QDateTime &time) {
- if(!time.isValid()) return false;
- if(!lastSeen(buffer).isValid() || lastSeen(buffer) < time) {
- _lastSeen[buffer] = time;
- emit lastSeenSet(buffer, time);
+
+MsgId BufferSyncer::markerLine(BufferId buffer) const
+{
+ return _markerLines.value(buffer, MsgId());
+}
+
+
+bool BufferSyncer::setMarkerLine(BufferId buffer, const MsgId &msgId)
+{
+ if (!msgId.isValid())
+ return false;
+
+ if (_markerLines.value(buffer) == msgId)
+ return false;
+
+ _markerLines[buffer] = msgId;
+ SYNC(ARG(buffer), ARG(msgId))
+ emit markerLineSet(buffer, msgId);
return true;
- }
- return false;
}
-QVariantList BufferSyncer::initLastSeen() const {
- QVariantList list;
- foreach(BufferId id, _lastSeen.keys()) {
- list << QVariant::fromValue<BufferId>(id) << _lastSeen[id];
- }
- return list;
+
+QVariantList BufferSyncer::initLastSeenMsg() const
+{
+ QVariantList list;
+ QHash<BufferId, MsgId>::const_iterator iter = _lastSeenMsg.constBegin();
+ while (iter != _lastSeenMsg.constEnd()) {
+ list << QVariant::fromValue<BufferId>(iter.key())
+ << QVariant::fromValue<MsgId>(iter.value());
+ ++iter;
+ }
+ return list;
}
-void BufferSyncer::initSetLastSeen(const QVariantList &list) {
- _lastSeen.clear();
- Q_ASSERT(list.count() % 2 == 0);
- for(int i = 0; i < list.count(); i += 2) {
- setLastSeen(list[i].value<BufferId>(), list[i+1].toDateTime());
- }
+
+void BufferSyncer::initSetLastSeenMsg(const QVariantList &list)
+{
+ _lastSeenMsg.clear();
+ Q_ASSERT(list.count() % 2 == 0);
+ for (int i = 0; i < list.count(); i += 2) {
+ setLastSeenMsg(list.at(i).value<BufferId>(), list.at(i+1).value<MsgId>());
+ }
}
-void BufferSyncer::requestSetLastSeen(BufferId buffer, const QDateTime &time) {
- if(setLastSeen(buffer, time)) emit setLastSeenRequested(buffer, time);
+
+QVariantList BufferSyncer::initMarkerLines() const
+{
+ QVariantList list;
+ QHash<BufferId, MsgId>::const_iterator iter = _markerLines.constBegin();
+ while (iter != _markerLines.constEnd()) {
+ list << QVariant::fromValue<BufferId>(iter.key())
+ << QVariant::fromValue<MsgId>(iter.value());
+ ++iter;
+ }
+ return list;
}
-void BufferSyncer::requestRemoveBuffer(BufferId buffer) {
- emit removeBufferRequested(buffer);
+void BufferSyncer::initSetMarkerLines(const QVariantList &list)
+{
+ _markerLines.clear();
+ Q_ASSERT(list.count() % 2 == 0);
+ for (int i = 0; i < list.count(); i += 2) {
+ setMarkerLine(list.at(i).value<BufferId>(), list.at(i+1).value<MsgId>());
+ }
}
-void BufferSyncer::removeBuffer(BufferId buffer) {
- if(_lastSeen.contains(buffer))
- _lastSeen.remove(buffer);
- emit bufferRemoved(buffer);
+
+void BufferSyncer::removeBuffer(BufferId buffer)
+{
+ if (_lastSeenMsg.contains(buffer))
+ _lastSeenMsg.remove(buffer);
+ if (_markerLines.contains(buffer))
+ _markerLines.remove(buffer);
+ SYNC(ARG(buffer))
+ emit bufferRemoved(buffer);
+}
+
+
+void BufferSyncer::mergeBuffersPermanently(BufferId buffer1, BufferId buffer2)
+{
+ if (_lastSeenMsg.contains(buffer2))
+ _lastSeenMsg.remove(buffer2);
+ if (_markerLines.contains(buffer2))
+ _markerLines.remove(buffer2);
+ SYNC(ARG(buffer1), ARG(buffer2))
+ emit buffersPermanentlyMerged(buffer1, buffer2);
}