ssl: Use QSslSocket directly to avoid redundant qobject_casts
[quassel.git] / src / common / transfermanager.cpp
index e2506f4..23273d6 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-2016 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"
 
+TransferManager::TransferManager(QObject* parent)
+    : SyncableObject("TransferManager", parent)
+{
+    static auto regTypes = []() -> bool {
+        qRegisterMetaTypeStreamOperators<TransferIdList>("TransferManager::TransferIdList");
+        return true;
+    }();
+    Q_UNUSED(regTypes);
+}
 
-INIT_SYNCABLE_OBJECT(TransferManager)
-
-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)) {
@@ -52,7 +57,6 @@ void TransferManager::addTransfer(Transfer *transfer)
     emit transferAdded(uuid);
 }
 
-
 void TransferManager::removeTransfer(const QUuid& uuid)
 {
     if (!_transfers.contains(uuid)) {
@@ -63,3 +67,26 @@ void TransferManager::removeTransfer(const QUuid& 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;
+}