2013-07-05 20:46:43 +04:00
|
|
|
/*
|
|
|
|
* Copyright (C) by Klaas Freitag <freitag@owncloud.com>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; version 2 of the License.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PROGRESSDISPATCHER_H
|
|
|
|
#define PROGRESSDISPATCHER_H
|
|
|
|
|
|
|
|
#include <QObject>
|
2013-07-26 15:44:38 +04:00
|
|
|
#include <QHash>
|
2013-07-31 00:22:43 +04:00
|
|
|
#include <QTime>
|
|
|
|
#include <QQueue>
|
2013-10-08 16:07:46 +04:00
|
|
|
#include <QElapsedTimer>
|
2014-03-14 16:03:16 +04:00
|
|
|
#include "syncfileitem.h"
|
2013-07-05 20:46:43 +04:00
|
|
|
|
|
|
|
namespace Mirall {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The FolderScheduler class schedules folders for sync
|
|
|
|
*/
|
2013-08-17 13:21:32 +04:00
|
|
|
namespace Progress
|
2013-07-05 20:46:43 +04:00
|
|
|
{
|
2014-03-14 16:03:16 +04:00
|
|
|
/** Return true is the size need to be taken in account in the total amount of time */
|
|
|
|
inline bool isSizeDependent(csync_instructions_e instruction) {
|
|
|
|
return instruction == CSYNC_INSTRUCTION_CONFLICT || instruction == CSYNC_INSTRUCTION_SYNC
|
|
|
|
|| instruction == CSYNC_INSTRUCTION_NEW;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
struct Info {
|
|
|
|
Info() : _totalFileCount(0), _totalSize(0), _completedFileCount(0), _completedSize(0) {}
|
|
|
|
|
|
|
|
quint64 _totalFileCount;
|
|
|
|
quint64 _totalSize;
|
|
|
|
quint64 _completedFileCount;
|
|
|
|
quint64 _completedSize;
|
|
|
|
|
|
|
|
struct ProgressItem {
|
|
|
|
ProgressItem() : _completedSize(0) {}
|
|
|
|
SyncFileItem _item;
|
|
|
|
quint64 _completedSize;
|
|
|
|
};
|
|
|
|
QHash<QString, ProgressItem> _currentItems;
|
|
|
|
SyncFileItem _lastCompletedItem;
|
|
|
|
|
|
|
|
void setProgressComplete(const SyncFileItem &item) {
|
|
|
|
_currentItems.remove(item._file);
|
|
|
|
if (Progress::isSizeDependent(item._instruction)) {
|
|
|
|
_completedSize += item._size;
|
|
|
|
}
|
|
|
|
_completedFileCount++;
|
|
|
|
_lastCompletedItem = item;
|
|
|
|
}
|
|
|
|
void setProgressItem(const SyncFileItem &item, quint64 size) {
|
|
|
|
_currentItems[item._file]._item = item;
|
|
|
|
_currentItems[item._file]._completedSize = size;
|
|
|
|
_lastCompletedItem = SyncFileItem();
|
|
|
|
}
|
|
|
|
|
|
|
|
quint64 completedSize() const {
|
|
|
|
quint64 r = _completedSize;
|
|
|
|
foreach(const ProgressItem &i, _currentItems) {
|
|
|
|
r += i._completedSize;
|
|
|
|
}
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
QString asActionString( const SyncFileItem& item );
|
|
|
|
QString asResultString( const SyncFileItem& item );
|
2013-11-25 19:16:33 +04:00
|
|
|
|
2014-03-14 20:18:26 +04:00
|
|
|
bool isWarningKind( SyncFileItem::Status );
|
2014-03-14 16:03:16 +04:00
|
|
|
|
2013-08-17 13:21:32 +04:00
|
|
|
}
|
2013-07-05 20:46:43 +04:00
|
|
|
|
2013-07-23 15:32:24 +04:00
|
|
|
/**
|
|
|
|
* @file progressdispatcher.h
|
|
|
|
* @brief A singleton class to provide sync progress information to other gui classes.
|
|
|
|
*
|
|
|
|
* How to use the ProgressDispatcher:
|
|
|
|
* Just connect to the two signals either to progress for every individual file
|
|
|
|
* or the overall sync progress.
|
|
|
|
*
|
|
|
|
*/
|
2013-07-05 20:46:43 +04:00
|
|
|
class ProgressDispatcher : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
2013-07-23 15:32:24 +04:00
|
|
|
|
|
|
|
friend class Folder; // only allow Folder class to access the setting slots.
|
2013-07-05 20:46:43 +04:00
|
|
|
public:
|
|
|
|
static ProgressDispatcher* instance();
|
|
|
|
~ProgressDispatcher();
|
|
|
|
|
|
|
|
signals:
|
2013-07-23 15:32:24 +04:00
|
|
|
/**
|
2013-07-26 15:44:38 +04:00
|
|
|
@brief Signals the progress of data transmission.
|
2013-07-23 15:32:24 +04:00
|
|
|
|
|
|
|
@param[out] folder The folder which is being processed
|
2014-03-14 16:03:16 +04:00
|
|
|
@param[out] progress A struct with all progress info.
|
2013-07-23 15:32:24 +04:00
|
|
|
|
|
|
|
*/
|
2013-07-31 00:22:43 +04:00
|
|
|
void progressInfo( const QString& folder, const Progress::Info& progress );
|
2013-07-05 20:46:43 +04:00
|
|
|
|
2013-07-23 15:32:24 +04:00
|
|
|
protected:
|
2013-11-25 19:16:33 +04:00
|
|
|
void setProgressInfo(const QString& folder, const Progress::Info& progress);
|
2013-07-05 20:46:43 +04:00
|
|
|
|
|
|
|
private:
|
|
|
|
ProgressDispatcher(QObject* parent = 0);
|
2013-10-08 16:07:46 +04:00
|
|
|
|
|
|
|
QElapsedTimer _timer;
|
2013-07-05 20:46:43 +04:00
|
|
|
static ProgressDispatcher* _instance;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif // PROGRESSDISPATCHER_H
|