feat(ui): adapt SequentialTask to nested SequentialTasks
This commit is contained in:
parent
c86c719e1a
commit
eaa5ce4467
@ -1,13 +1,12 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "modplatform/ModIndex.h"
|
||||||
|
|
||||||
#include <QString>
|
#include <QString>
|
||||||
#include <QUrl>
|
#include <QUrl>
|
||||||
#include <QVariant>
|
#include <QVariant>
|
||||||
|
|
||||||
namespace ModPlatform {
|
namespace ModPlatform {
|
||||||
enum class Provider;
|
|
||||||
class IndexedPack;
|
|
||||||
class IndexedVersion;
|
|
||||||
} // namespace ModPlatform
|
} // namespace ModPlatform
|
||||||
|
|
||||||
class QDir;
|
class QDir;
|
||||||
|
@ -53,12 +53,18 @@ void SequentialTask::startNext()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Task::Ptr next = m_queue[m_currentIndex];
|
Task::Ptr next = m_queue[m_currentIndex];
|
||||||
|
|
||||||
connect(next.get(), SIGNAL(failed(QString)), this, SLOT(subTaskFailed(QString)));
|
connect(next.get(), SIGNAL(failed(QString)), this, SLOT(subTaskFailed(QString)));
|
||||||
connect(next.get(), SIGNAL(status(QString)), this, SLOT(subTaskStatus(QString)));
|
|
||||||
connect(next.get(), SIGNAL(progress(qint64, qint64)), this, SLOT(subTaskProgress(qint64, qint64)));
|
|
||||||
connect(next.get(), SIGNAL(succeeded()), this, SLOT(startNext()));
|
connect(next.get(), SIGNAL(succeeded()), this, SLOT(startNext()));
|
||||||
|
|
||||||
|
connect(next.get(), SIGNAL(status(QString)), this, SLOT(subTaskStatus(QString)));
|
||||||
|
connect(next.get(), SIGNAL(stepStatus(QString)), this, SLOT(subTaskStatus(QString)));
|
||||||
|
|
||||||
|
connect(next.get(), SIGNAL(progress(qint64, qint64)), this, SLOT(subTaskProgress(qint64, qint64)));
|
||||||
|
|
||||||
setStatus(tr("Executing task %1 out of %2").arg(m_currentIndex + 1).arg(m_queue.size()));
|
setStatus(tr("Executing task %1 out of %2").arg(m_currentIndex + 1).arg(m_queue.size()));
|
||||||
|
setStepStatus(next->isMultiStep() ? next->getStepStatus() : next->getStatus());
|
||||||
|
|
||||||
next->start();
|
next->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -68,7 +74,7 @@ void SequentialTask::subTaskFailed(const QString& msg)
|
|||||||
}
|
}
|
||||||
void SequentialTask::subTaskStatus(const QString& msg)
|
void SequentialTask::subTaskStatus(const QString& msg)
|
||||||
{
|
{
|
||||||
setStepStatus(m_queue[m_currentIndex]->getStatus());
|
setStepStatus(msg);
|
||||||
}
|
}
|
||||||
void SequentialTask::subTaskProgress(qint64 current, qint64 total)
|
void SequentialTask::subTaskProgress(qint64 current, qint64 total)
|
||||||
{
|
{
|
||||||
|
@ -32,13 +32,10 @@ slots:
|
|||||||
void subTaskStatus(const QString &msg);
|
void subTaskStatus(const QString &msg);
|
||||||
void subTaskProgress(qint64 current, qint64 total);
|
void subTaskProgress(qint64 current, qint64 total);
|
||||||
|
|
||||||
signals:
|
protected:
|
||||||
void stepStatus(QString status);
|
void setStepStatus(QString status) { m_step_status = status; emit stepStatus(status); };
|
||||||
|
|
||||||
private:
|
protected:
|
||||||
void setStepStatus(QString status) { m_step_status = status; };
|
|
||||||
|
|
||||||
private:
|
|
||||||
QString m_name;
|
QString m_name;
|
||||||
QString m_step_status;
|
QString m_step_status;
|
||||||
|
|
||||||
|
@ -92,6 +92,7 @@ class Task : public QObject {
|
|||||||
void aborted();
|
void aborted();
|
||||||
void failed(QString reason);
|
void failed(QString reason);
|
||||||
void status(QString status);
|
void status(QString status);
|
||||||
|
void stepStatus(QString status);
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
virtual void start();
|
virtual void start();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user