X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcommon%2Ftransfermanager.cpp;h=285b3bf077a472e829bfedca15f8b36d0b097558;hb=ef3a1eebb101c108dea196e21e29cc4f6f00459a;hp=5e5af46ebdf1b5f15a886b8fa3d4e053289f84ca;hpb=1cb02004ee5973b89368bd84f234d4652794690d;p=quassel.git diff --git a/src/common/transfermanager.cpp b/src/common/transfermanager.cpp index 5e5af46e..285b3bf0 100644 --- a/src/common/transfermanager.cpp +++ b/src/common/transfermanager.cpp @@ -24,16 +24,10 @@ INIT_SYNCABLE_OBJECT(TransferManager) -TransferManager::TransferManager(QObject *parent) - : SyncableObject(parent) -{ - -} - -Transfer *TransferManager::transfer_(const QUuid &uuid) const +Transfer *TransferManager::transfer(const QUuid &uuid) const { - return _transfers.value(uuid, 0); + return _transfers.value(uuid, nullptr); } @@ -55,5 +49,17 @@ 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(); }