ssl: Use QSslSocket directly to avoid redundant qobject_casts
[quassel.git] / src / common / transfermanager.cpp
index c90adfb..23273d6 100644 (file)
@@ -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  *
 
 #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<TransferIdList>("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<QUuid> 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<quint32>(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;
 }