2017-01-08 04:58:05 +01:00
|
|
|
/* Copyright 2013-2017 MultiMC Contributors
|
2015-07-21 02:38:15 +02: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()
|
|
|
|
{
|
2016-08-14 02:33:31 +02:00
|
|
|
if(m_aborted)
|
|
|
|
{
|
|
|
|
emitFailed(tr("Task aborted."));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
m_updateTask.reset(m_parent->instance()->createUpdateTask());
|
2015-07-21 02:38:15 +02:00
|
|
|
if(m_updateTask)
|
|
|
|
{
|
|
|
|
connect(m_updateTask.get(), SIGNAL(finished()), this, SLOT(updateFinished()));
|
2015-07-26 17:55:29 +02:00
|
|
|
connect(m_updateTask.get(), &Task::progress, this, &Task::setProgress);
|
2017-05-03 23:11:52 +02:00
|
|
|
connect(m_updateTask.get(), &Task::status, this, &Task::setStatus);
|
2015-07-26 17:55:29 +02:00
|
|
|
emit progressReportingRequest();
|
2015-07-21 02:38:15 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
emitSucceeded();
|
|
|
|
}
|
|
|
|
|
2015-07-26 17:55:29 +02:00
|
|
|
void Update::proceed()
|
|
|
|
{
|
|
|
|
m_updateTask->start();
|
|
|
|
}
|
|
|
|
|
2015-07-21 02:38:15 +02:00
|
|
|
void Update::updateFinished()
|
|
|
|
{
|
|
|
|
if(m_updateTask->successful())
|
|
|
|
{
|
2016-08-14 02:33:31 +02:00
|
|
|
m_updateTask.reset();
|
2015-07-21 02:38:15 +02:00
|
|
|
emitSucceeded();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
QString reason = tr("Instance update failed because: %1.\n\n").arg(m_updateTask->failReason());
|
2016-08-14 02:33:31 +02:00
|
|
|
m_updateTask.reset();
|
2015-07-21 02:38:15 +02:00
|
|
|
emit logLine(reason, MessageLevel::Fatal);
|
|
|
|
emitFailed(reason);
|
|
|
|
}
|
2015-07-26 17:55:29 +02:00
|
|
|
}
|
2016-08-14 02:33:31 +02:00
|
|
|
|
|
|
|
bool Update::canAbort() const
|
|
|
|
{
|
|
|
|
if(m_updateTask)
|
|
|
|
{
|
|
|
|
return m_updateTask->canAbort();
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool Update::abort()
|
|
|
|
{
|
|
|
|
m_aborted = true;
|
|
|
|
if(m_updateTask)
|
|
|
|
{
|
|
|
|
if(m_updateTask->canAbort())
|
|
|
|
{
|
|
|
|
return m_updateTask->abort();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|