pollymc/logic/tasks/Task.cpp

75 lines
1.5 KiB
C++
Raw Normal View History

2015-02-02 14:25:30 -08:00
/* Copyright 2013-2015 MultiMC Contributors
2013-02-05 13:40:43 -06: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
*
2013-02-05 13:40:43 -06:00
* 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 "Task.h"
#include <QDebug>
2013-02-05 13:40:43 -06:00
2015-04-26 23:04:50 +02:00
Task::Task(QObject *parent) : QObject(parent)
2013-02-05 13:40:43 -06:00
{
}
void Task::setStatus(const QString &new_status)
2013-02-05 13:40:43 -06:00
{
emit status(new_status);
2013-02-05 13:40:43 -06:00
}
void Task::setProgress(int new_progress)
2013-02-05 13:40:43 -06:00
{
emit progress(new_progress, 100);
2013-02-05 13:40:43 -06:00
}
void Task::start()
{
m_running = true;
emit started();
executeTask();
}
void Task::emitFailed(QString reason)
{
m_running = false;
m_succeeded = false;
m_failReason = reason;
qCritical() << "Task failed: " << reason;
emit failed(reason);
2015-05-02 23:42:33 +02:00
emit finished();
}
void Task::emitSucceeded()
{
2014-09-06 18:16:56 +02:00
if (!m_running) { return; } // Don't succeed twice.
m_running = false;
m_succeeded = true;
qDebug() << "Task succeeded";
emit succeeded();
2015-05-02 23:42:33 +02:00
emit finished();
}
2013-08-05 03:29:50 +02:00
bool Task::isRunning() const
{
return m_running;
2013-02-05 13:40:43 -06:00
}
bool Task::successful() const
{
return m_succeeded;
}
QString Task::failReason() const
{
return m_failReason;
}