2021-01-18 07:28:54 +00:00
|
|
|
/* Copyright 2013-2021 MultiMC Contributors
|
2015-07-21 01:38:15 +01:00
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "Update.h"
|
|
|
|
#include <launch/LaunchTask.h>
|
|
|
|
|
|
|
|
void Update::executeTask()
|
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
if(m_aborted)
|
|
|
|
{
|
|
|
|
emitFailed(tr("Task aborted."));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
m_updateTask.reset(m_parent->instance()->createUpdateTask(m_mode));
|
|
|
|
if(m_updateTask)
|
|
|
|
{
|
2023-04-18 01:51:34 +01:00
|
|
|
connect(m_updateTask.get(), &Task::finished, this, &Update::updateFinished);
|
|
|
|
connect(m_updateTask.get(), &Task::progress, this, &Update::setProgress);
|
2023-07-01 07:50:13 +01:00
|
|
|
connect(m_updateTask.get(), &Task::stepProgress, this, &Update::propagateStepProgress);
|
2023-04-18 01:51:34 +01:00
|
|
|
connect(m_updateTask.get(), &Task::status, this, &Update::setStatus);
|
2023-04-01 03:25:01 +01:00
|
|
|
connect(m_updateTask.get(), &Task::details, this, &Update::setDetails);
|
2018-07-15 13:51:05 +01:00
|
|
|
emit progressReportingRequest();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
emitSucceeded();
|
2015-07-21 01:38:15 +01:00
|
|
|
}
|
|
|
|
|
2015-07-26 16:55:29 +01:00
|
|
|
void Update::proceed()
|
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
m_updateTask->start();
|
2015-07-26 16:55:29 +01:00
|
|
|
}
|
|
|
|
|
2015-07-21 01:38:15 +01:00
|
|
|
void Update::updateFinished()
|
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
if(m_updateTask->wasSuccessful())
|
|
|
|
{
|
|
|
|
m_updateTask.reset();
|
|
|
|
emitSucceeded();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2018-11-26 02:06:58 +00:00
|
|
|
QString reason = tr("Instance update failed because: %1\n\n").arg(m_updateTask->failReason());
|
2018-07-15 13:51:05 +01:00
|
|
|
m_updateTask.reset();
|
|
|
|
emit logLine(reason, MessageLevel::Fatal);
|
|
|
|
emitFailed(reason);
|
|
|
|
}
|
2015-07-26 16:55:29 +01:00
|
|
|
}
|
2016-08-14 01:33:31 +01:00
|
|
|
|
|
|
|
bool Update::canAbort() const
|
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
if(m_updateTask)
|
|
|
|
{
|
|
|
|
return m_updateTask->canAbort();
|
|
|
|
}
|
|
|
|
return true;
|
2016-08-14 01:33:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool Update::abort()
|
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
m_aborted = true;
|
|
|
|
if(m_updateTask)
|
|
|
|
{
|
|
|
|
if(m_updateTask->canAbort())
|
|
|
|
{
|
|
|
|
return m_updateTask->abort();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
2016-08-14 01:33:31 +01:00
|
|
|
}
|