summaryrefslogtreecommitdiff
path: root/meshmc/launcher/tasks/Task.cpp
diff options
context:
space:
mode:
authorMehmet Samet Duman <yongdohyun@projecttick.org>2026-04-02 18:45:07 +0300
committerMehmet Samet Duman <yongdohyun@projecttick.org>2026-04-02 18:45:07 +0300
commit31b9a8949ed0a288143e23bf739f2eb64fdc63be (patch)
tree8a984fa143c38fccad461a77792d6864f3e82cd3 /meshmc/launcher/tasks/Task.cpp
parent934382c8a1ce738589dee9ee0f14e1cec812770e (diff)
parentfad6a1066616b69d7f5fef01178efdf014c59537 (diff)
downloadProject-Tick-31b9a8949ed0a288143e23bf739f2eb64fdc63be.tar.gz
Project-Tick-31b9a8949ed0a288143e23bf739f2eb64fdc63be.zip
Add 'meshmc/' from commit 'fad6a1066616b69d7f5fef01178efdf014c59537'
git-subtree-dir: meshmc git-subtree-mainline: 934382c8a1ce738589dee9ee0f14e1cec812770e git-subtree-split: fad6a1066616b69d7f5fef01178efdf014c59537
Diffstat (limited to 'meshmc/launcher/tasks/Task.cpp')
-rw-r--r--meshmc/launcher/tasks/Task.cpp189
1 files changed, 189 insertions, 0 deletions
diff --git a/meshmc/launcher/tasks/Task.cpp b/meshmc/launcher/tasks/Task.cpp
new file mode 100644
index 0000000000..9f55b38699
--- /dev/null
+++ b/meshmc/launcher/tasks/Task.cpp
@@ -0,0 +1,189 @@
+/* SPDX-FileCopyrightText: 2026 Project Tick
+ * SPDX-FileContributor: Project Tick
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ *
+ * MeshMC - A Custom Launcher for Minecraft
+ * Copyright (C) 2026 Project Tick
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <https://www.gnu.org/licenses/>.
+ *
+ * This file incorporates work covered by the following copyright and
+ * permission notice:
+ *
+ * Copyright 2013-2021 MultiMC Contributors
+ *
+ * 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 "Task.h"
+
+#include <QDebug>
+#include <QPointer>
+
+Task::Task(QObject* parent) : QObject(parent) {}
+
+void Task::setStatus(const QString& new_status)
+{
+ if (m_status != new_status) {
+ m_status = new_status;
+ emit status(m_status);
+ }
+}
+
+void Task::setProgress(qint64 current, qint64 total)
+{
+ m_progress = current;
+ m_progressTotal = total;
+ emit progress(m_progress, m_progressTotal);
+}
+
+void Task::start()
+{
+ switch (m_state) {
+ case State::Inactive: {
+ qDebug() << "Task" << describe() << "starting for the first time";
+ break;
+ }
+ case State::AbortedByUser: {
+ qDebug() << "Task" << describe()
+ << "restarting for after being aborted by user";
+ break;
+ }
+ case State::Failed: {
+ qDebug() << "Task" << describe()
+ << "restarting for after failing at first";
+ break;
+ }
+ case State::Succeeded: {
+ qDebug() << "Task" << describe()
+ << "restarting for after succeeding at first";
+ break;
+ }
+ case State::Running: {
+ qWarning() << "MeshMC tried to start task" << describe()
+ << "while it was already running!";
+ return;
+ }
+ }
+ // NOTE: only fall thorugh to here in end states
+ m_state = State::Running;
+ emit started();
+ executeTask();
+}
+
+void Task::emitFailed(QString reason)
+{
+ // Don't fail twice.
+ if (!isRunning()) {
+ qCritical() << "Task" << describe()
+ << "failed while not running!!!!: " << reason;
+ return;
+ }
+ m_state = State::Failed;
+ m_failReason = reason;
+ qCritical() << "Task" << describe() << "failed: " << reason;
+ QPointer<Task> guard(this);
+ emit failed(reason);
+ if (guard)
+ emit finished();
+}
+
+void Task::emitAborted()
+{
+ // Don't abort twice.
+ if (!isRunning()) {
+ qCritical() << "Task" << describe() << "aborted while not running!!!!";
+ return;
+ }
+ m_state = State::AbortedByUser;
+ m_failReason = "Aborted.";
+ qDebug() << "Task" << describe() << "aborted.";
+ QPointer<Task> guard(this);
+ emit failed(m_failReason);
+ if (guard)
+ emit finished();
+}
+
+void Task::emitSucceeded()
+{
+ // Don't succeed twice.
+ if (!isRunning()) {
+ qCritical() << "Task" << describe()
+ << "succeeded while not running!!!!";
+ return;
+ }
+ m_state = State::Succeeded;
+ qDebug() << "Task" << describe() << "succeeded";
+ QPointer<Task> guard(this);
+ emit succeeded();
+ if (guard)
+ emit finished();
+}
+
+QString Task::describe()
+{
+ QString outStr;
+ QTextStream out(&outStr);
+ out << metaObject()->className() << QChar('(');
+ auto name = objectName();
+ if (name.isEmpty()) {
+ out << QString("0x%1").arg((quintptr)this, 0, 16);
+ } else {
+ out << name;
+ }
+ out << QChar(')');
+ out.flush();
+ return outStr;
+}
+
+bool Task::isRunning() const
+{
+ return m_state == State::Running;
+}
+
+bool Task::isFinished() const
+{
+ return m_state != State::Running && m_state != State::Inactive;
+}
+
+bool Task::wasSuccessful() const
+{
+ return m_state == State::Succeeded;
+}
+
+QString Task::failReason() const
+{
+ return m_failReason;
+}
+
+void Task::logWarning(const QString& line)
+{
+ qWarning() << line;
+ m_Warnings.append(line);
+}
+
+QStringList Task::warnings() const
+{
+ return m_Warnings;
+}