2017-11-11 01:38:31 +01:00
|
|
|
#include "MinecraftLoadAndCheck.h"
|
|
|
|
#include "MinecraftInstance.h"
|
2020-06-27 12:02:31 +02:00
|
|
|
#include "PackProfile.h"
|
2017-11-11 01:38:31 +01:00
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
MinecraftLoadAndCheck::MinecraftLoadAndCheck(MinecraftInstance* inst, QObject* parent) : Task(parent), m_inst(inst) {}
|
2017-11-11 01:38:31 +01:00
|
|
|
|
|
|
|
void MinecraftLoadAndCheck::executeTask()
|
|
|
|
{
|
2018-07-15 14:51:05 +02:00
|
|
|
// add offline metadata load task
|
2020-06-27 12:02:31 +02:00
|
|
|
auto components = m_inst->getPackProfile();
|
2018-07-15 14:51:05 +02:00
|
|
|
components->reload(Net::Mode::Offline);
|
|
|
|
m_task = components->getCurrentTask();
|
2017-11-11 01:38:31 +01:00
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
if (!m_task) {
|
2018-07-15 14:51:05 +02:00
|
|
|
emitSucceeded();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
connect(m_task.get(), &Task::succeeded, this, &MinecraftLoadAndCheck::subtaskSucceeded);
|
|
|
|
connect(m_task.get(), &Task::failed, this, &MinecraftLoadAndCheck::subtaskFailed);
|
2023-08-02 18:35:35 +02:00
|
|
|
connect(m_task.get(), &Task::aborted, this, [this] { subtaskFailed(tr("Aborted")); });
|
2018-07-15 14:51:05 +02:00
|
|
|
connect(m_task.get(), &Task::progress, this, &MinecraftLoadAndCheck::progress);
|
2023-07-26 16:20:30 -04:00
|
|
|
connect(m_task.get(), &Task::stepProgress, this, &MinecraftLoadAndCheck::propagateStepProgress);
|
2018-07-15 14:51:05 +02:00
|
|
|
connect(m_task.get(), &Task::status, this, &MinecraftLoadAndCheck::setStatus);
|
2017-11-11 01:38:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void MinecraftLoadAndCheck::subtaskSucceeded()
|
|
|
|
{
|
2023-08-02 18:35:35 +02:00
|
|
|
if (isFinished()) {
|
2018-11-11 23:55:50 +01:00
|
|
|
qCritical() << "MinecraftUpdate: Subtask" << sender() << "succeeded, but work was already done!";
|
2018-07-15 14:51:05 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
emitSucceeded();
|
2017-11-11 01:38:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void MinecraftLoadAndCheck::subtaskFailed(QString error)
|
|
|
|
{
|
2023-08-02 18:35:35 +02:00
|
|
|
if (isFinished()) {
|
2018-11-11 23:55:50 +01:00
|
|
|
qCritical() << "MinecraftUpdate: Subtask" << sender() << "failed, but work was already done!";
|
2018-07-15 14:51:05 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
emitFailed(error);
|
2017-11-11 01:38:31 +01:00
|
|
|
}
|