X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Ftransfermanager.cpp;h=23273d6b3aa6158ee1d978890d409d5170a40b8b;hp=c90adfb37cf6da855b3091253f5f7ff7152d3417;hb=c0d6dc0dec628f2e143e37ecc95cec45e636f8a5;hpb=dd711790dddee81442e2138b3917764dac39c487 diff --git a/src/common/transfermanager.cpp b/src/common/transfermanager.cpp index c90adfb3..23273d6b 100644 --- a/src/common/transfermanager.cpp +++ b/src/common/transfermanager.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2015 by the Quassel Project * + * Copyright (C) 2005-2020 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -22,28 +22,27 @@ #include "transfer.h" - -INIT_SYNCABLE_OBJECT(TransferManager) -TransferManager::TransferManager(QObject *parent) - : SyncableObject(parent) +TransferManager::TransferManager(QObject* parent) + : SyncableObject("TransferManager", parent) { - + static auto regTypes = []() -> bool { + qRegisterMetaTypeStreamOperators("TransferManager::TransferIdList"); + return true; + }(); + Q_UNUSED(regTypes); } - -Transfer *TransferManager::transfer(const QUuid &uuid) const +Transfer* TransferManager::transfer(const QUuid& uuid) const { return _transfers.value(uuid, nullptr); } - -QList TransferManager::transferIds() const +TransferManager::TransferIdList TransferManager::transferIds() const { return _transfers.keys(); } - -void TransferManager::addTransfer(Transfer *transfer) +void TransferManager::addTransfer(Transfer* transfer) { QUuid uuid = transfer->uuid(); if (_transfers.contains(uuid)) { @@ -55,5 +54,39 @@ void TransferManager::addTransfer(Transfer *transfer) _transfers[uuid] = transfer; SYNC_OTHER(onCoreTransferAdded, ARG(uuid)); - emit transferAdded(transfer); + emit transferAdded(uuid); +} + +void TransferManager::removeTransfer(const QUuid& uuid) +{ + if (!_transfers.contains(uuid)) { + qWarning() << "Can not find transfer" << uuid << "to remove!"; + return; + } + emit transferRemoved(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; }