X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcoretransfermanager.cpp;h=12279d32b128a0fa3e7e8e6ab69767894828cd10;hp=a11927abcc0e4156155b5f6833ded2d577834e8a;hb=e31a348f6e0b54941a7b6ee5243da429f910f34c;hpb=f5bb6544096b45cde4642e821654c48e26a9f79c diff --git a/src/core/coretransfermanager.cpp b/src/core/coretransfermanager.cpp index a11927ab..12279d32 100644 --- a/src/core/coretransfermanager.cpp +++ b/src/core/coretransfermanager.cpp @@ -20,8 +20,7 @@ #include "coretransfermanager.h" -#include "transfer.h" - +#include "coretransfer.h" INIT_SYNCABLE_OBJECT(CoreTransferManager) CoreTransferManager::CoreTransferManager(QObject *parent) @@ -31,20 +30,26 @@ CoreTransferManager::CoreTransferManager(QObject *parent) } -void CoreTransferManager::onTransferAdded(const Transfer *transfer) +CoreTransfer *CoreTransferManager::transfer(const QUuid &uuid) const { - connect(transfer, SIGNAL(accepted(PeerPtr)), SLOT(onTransferAccepted(PeerPtr))); - connect(transfer, SIGNAL(rejected(PeerPtr)), SLOT(onTransferRejected(PeerPtr))); + return qobject_cast(transfer_(uuid)); } -void CoreTransferManager::onTransferAccepted(PeerPtr peer) +void CoreTransferManager::addTransfer(CoreTransfer *transfer) { - + TransferManager::addTransfer(transfer); } -void CoreTransferManager::onTransferRejected(PeerPtr peer) +void CoreTransferManager::onTransferAdded(const Transfer *transfer) { - + // for core-side use, publishing a non-const pointer is ok + CoreTransfer *t = const_cast(qobject_cast(transfer)); + if (!t) { + qWarning() << "Invalid Transfer added to CoreTransferManager!"; + return; + } + + emit transferAdded(t); }