Add accessors for the amount of transferred data to Transfer classes
authorManuel Nickschas <sputnick@quassel-irc.org>
Wed, 2 Mar 2016 00:12:03 +0000 (01:12 +0100)
committerManuel Nickschas <sputnick@quassel-irc.org>
Wed, 2 Mar 2016 00:12:03 +0000 (01:12 +0100)
Also fixes more inconsistent/missing uses of 'override'.

src/client/clienttransfer.cpp
src/client/clienttransfer.h
src/common/transfer.h
src/core/coretransfer.cpp
src/core/coretransfer.h

index f42e14e..2aac8cf 100644 (file)
@@ -31,6 +31,15 @@ ClientTransfer::ClientTransfer(const QUuid &uuid, QObject *parent)
 }
 
 
+quint64 ClientTransfer::transferred() const
+{
+    if (status() == Status::Completed)
+        return fileSize();
+
+    return _file ? _file->size() : 0;
+}
+
+
 void ClientTransfer::cleanUp()
 {
     if (_file) {
index 4f54ef0..a1d062b 100644 (file)
@@ -37,6 +37,8 @@ public:
 
     QString savePath() const;
 
+    quint64 transferred() const override;
+
 public slots:
     // called on the client side
     void accept(const QString &savePath) const override;
index 9a22253..48deb5b 100644 (file)
@@ -62,7 +62,7 @@ public:
 
     Transfer(const QUuid &uuid, QObject *parent = 0); // for creating a syncable object client-side
     Transfer(Direction direction, const QString &nick, const QString &fileName, const QHostAddress &address, quint16 port, quint64 size = 0, QObject *parent = 0);
-    inline virtual const QMetaObject *syncMetaObject() const { return &staticMetaObject; }
+    inline const QMetaObject *syncMetaObject() const override { return &staticMetaObject; }
 
     QUuid uuid() const;
     Status status() const;
@@ -74,6 +74,8 @@ public:
     quint64 fileSize() const;
     QString nick() const;
 
+    virtual quint64 transferred() const = 0;
+
 public slots:
     // called on the client side
     virtual void accept(const QString &savePath) const { Q_UNUSED(savePath); }
index aced4c6..0d454ae 100644 (file)
@@ -39,6 +39,12 @@ CoreTransfer::CoreTransfer(Direction direction, const QString &nick, const QStri
 }
 
 
+quint64 CoreTransfer::transferred() const
+{
+    return _pos;
+}
+
+
 void CoreTransfer::cleanUp()
 {
     if (_socket) {
index 3244efd..66028b5 100644 (file)
@@ -36,12 +36,14 @@ class CoreTransfer : public Transfer
 public:
     CoreTransfer(Direction direction, const QString &nick, const QString &fileName, const QHostAddress &address, quint16 port, quint64 size = 0, QObject *parent = 0);
 
+    quint64 transferred() const override;
+
 public slots:
     void start();
 
     // called through sync calls
-    void requestAccepted(PeerPtr peer);
-    void requestRejected(PeerPtr peer);
+    void requestAccepted(PeerPtr peer) override;
+    void requestRejected(PeerPtr peer) override;
 
 private slots:
     void startReceiving();
@@ -52,7 +54,7 @@ private slots:
 private:
     void setupConnectionForReceive();
     bool relayData(const QByteArray &data, bool requireChunkSize);
-    virtual void cleanUp();
+    void cleanUp() override;
 
     QPointer<Peer> _peer;
     QTcpSocket *_socket;