X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcommon%2Ftransfermanager.h;h=e1b461b84ad5d22d533a590014f8ab91e2b5bae6;hb=dc0c6b90a8d6788d6a14b164c5685ce45b3b0a49;hp=b8dd185c1fef208a59ed7145744529b503aeaee7;hpb=0a43227b8cd44625f4881cc1545d42c8c8a4876c;p=quassel.git diff --git a/src/common/transfermanager.h b/src/common/transfermanager.h index b8dd185c..e1b461b8 100644 --- a/src/common/transfermanager.h +++ b/src/common/transfermanager.h @@ -20,10 +20,12 @@ #pragma once -#include "syncableobject.h" - +#include +#include #include +#include "syncableobject.h" + class Transfer; class TransferManager : public SyncableObject @@ -31,12 +33,16 @@ class TransferManager : public SyncableObject Q_OBJECT SYNCABLE_OBJECT + Q_PROPERTY(TransferManager::TransferIdList transferIds READ transferIds WRITE setTransferIds) + public: - using SyncableObject::SyncableObject; - inline virtual const QMetaObject *syncMetaObject() const { return &staticMetaObject; } + using TransferIdList = QList; + + TransferManager(QObject *parent = nullptr); + const QMetaObject *syncMetaObject() const override { return &staticMetaObject; } Transfer *transfer(const QUuid &uuid) const; - QList transferIds() const; + TransferIdList transferIds() const; signals: void transferAdded(const QUuid &uuid); @@ -47,9 +53,12 @@ protected: void removeTransfer(const QUuid &uuid); protected slots: - virtual void onCoreTransferAdded(const QUuid &uuid) { Q_UNUSED(uuid) }; + virtual void setTransferIds(const TransferIdList &transferIds) { Q_UNUSED(transferIds) }; + virtual void onCoreTransferAdded(const QUuid &transferId) { Q_UNUSED(transferId) }; private: QHash _transfers; - }; + +QDataStream &operator<<(QDataStream &out, const TransferManager::TransferIdList &transferIds); +QDataStream &operator>>(QDataStream &in, TransferManager::TransferIdList &state);