X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Ftransfermanager.cpp;h=8564d4e33dde87b2437eb22e768a50af2bed7d54;hp=099d3d38119d0fa08b777171673cc884511f7394;hb=8443ab1e0a812d76d5efa816d5bd3d476d67ab2d;hpb=bac817e9c9af8ea5f9ff90d8673310ec22a1cc88 diff --git a/src/common/transfermanager.cpp b/src/common/transfermanager.cpp index 099d3d38..8564d4e3 100644 --- a/src/common/transfermanager.cpp +++ b/src/common/transfermanager.cpp @@ -25,13 +25,24 @@ INIT_SYNCABLE_OBJECT(TransferManager) +TransferManager::TransferManager(QObject *parent) + : SyncableObject(parent) +{ + static auto regTypes = []() -> bool { + qRegisterMetaType("TransferManager::TransferIdList"); + qRegisterMetaTypeStreamOperators("TransferManager::TransferIdList"); + return true; + }(); + Q_UNUSED(regTypes); +} + Transfer *TransferManager::transfer(const QUuid &uuid) const { return _transfers.value(uuid, nullptr); } -QList TransferManager::transferIds() const +TransferManager::TransferIdList TransferManager::transferIds() const { return _transfers.keys(); } @@ -63,3 +74,28 @@ void TransferManager::removeTransfer(const QUuid &uuid) auto transfer = _transfers.take(uuid); transfer->deleteLater(); } + + +QDataStream &operator<<(QDataStream &out, const TransferManager::TransferIdList &transferIds) +{ + out << static_cast(transferIds.size()); + for (auto &&id : transferIds) { + out << id; + } + return out; +} + + +QDataStream &operator>>(QDataStream &in, TransferManager::TransferIdList &transferIds) +{ + quint32 count; + in >> count; + transferIds.clear(); + transferIds.reserve(count); + for (quint32 i = 0; i < count; ++i) { + QUuid id; + in >> id; + transferIds << id; + } + return in; +}