X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fclient%2Fclienttransfer.cpp;h=337d75745734bb5ff1588582a24d4999d0a4fe97;hb=6c561d2b7b1bb303cfcd8a013179b1838d315910;hp=f42e14edf00fca3920600444bee0f411be79e224;hpb=8092ddfe050c4b5044d4f9bb07ffb1900d8c9084;p=quassel.git diff --git a/src/client/clienttransfer.cpp b/src/client/clienttransfer.cpp index f42e14ed..337d7574 100644 --- a/src/client/clienttransfer.cpp +++ b/src/client/clienttransfer.cpp @@ -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 * @@ -18,58 +18,60 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ -#include - #include "clienttransfer.h" -INIT_SYNCABLE_OBJECT(ClientTransfer) -ClientTransfer::ClientTransfer(const QUuid &uuid, QObject *parent) - : Transfer(uuid, parent), - _file(0) +#include + +ClientTransfer::ClientTransfer(const QUuid& uuid, QObject* parent) + : Transfer(uuid, parent) + , _file(nullptr) { - connect(this, SIGNAL(statusChanged(Transfer::Status)), SLOT(onStatusChanged(Transfer::Status))); + connect(this, &Transfer::statusChanged, this, &ClientTransfer::onStatusChanged); } +quint64 ClientTransfer::transferred() const +{ + if (status() == Status::Completed) + return fileSize(); + + return _file ? _file->size() : 0; +} void ClientTransfer::cleanUp() { if (_file) { _file->close(); _file->deleteLater(); - _file = 0; + _file = nullptr; } } - QString ClientTransfer::savePath() const { return _savePath; } - -void ClientTransfer::accept(const QString &savePath) const +void ClientTransfer::accept(const QString& savePath) const { _savePath = savePath; - PeerPtr ptr = 0; + PeerPtr ptr = nullptr; REQUEST_OTHER(requestAccepted, ARG(ptr)); emit accepted(); } - void ClientTransfer::reject() const { - PeerPtr ptr = 0; + PeerPtr ptr = nullptr; REQUEST_OTHER(requestRejected, ARG(ptr)); emit rejected(); } - -void ClientTransfer::dataReceived(PeerPtr, const QByteArray &data) +void ClientTransfer::dataReceived(PeerPtr, const QByteArray& data) { // TODO: proper error handling (relay to core) if (!_file) { _file = new QFile(_savePath, this); - if (!_file->open(QFile::WriteOnly|QFile::Truncate)) { + if (!_file->open(QFile::WriteOnly | QFile::Truncate)) { qWarning() << Q_FUNC_INFO << "Could not open file:" << _file->errorString(); return; } @@ -82,21 +84,22 @@ void ClientTransfer::dataReceived(PeerPtr, const QByteArray &data) qWarning() << Q_FUNC_INFO << "Could not write to file:" << _file->errorString(); return; } -} + emit transferredChanged(transferred()); +} void ClientTransfer::onStatusChanged(Transfer::Status status) { - switch(status) { - case Status::Completed: - if (_file) - _file->close(); - break; - case Status::Failed: - if (_file) - _file->remove(); - break; - default: - ; + switch (status) { + case Status::Completed: + if (_file) + _file->close(); + break; + case Status::Failed: + if (_file) + _file->remove(); + break; + default: + ; } }