aboutsummaryrefslogtreecommitdiff
path: root/launcher/DataMigrationTask.h
diff options
context:
space:
mode:
authorSefa Eyeoglu <contact@scrumplex.net>2022-11-21 12:14:49 +0100
committerGitHub <noreply@github.com>2022-11-21 12:14:49 +0100
commitc74f852364d512dd850111f92cc989c0c2ce7392 (patch)
tree7ae2a740b0195b0adcdbcd3460b5e75a68bc7b5d /launcher/DataMigrationTask.h
parent30607c34a153fd32085712e18827983772d77f7b (diff)
parentfe94c3609ef875166b71b9f6c540c45eff97a5ab (diff)
downloadPrismLauncher-c74f852364d512dd850111f92cc989c0c2ce7392.tar.gz
PrismLauncher-c74f852364d512dd850111f92cc989c0c2ce7392.tar.bz2
PrismLauncher-c74f852364d512dd850111f92cc989c0c2ce7392.zip
Merge pull request #243 from Scrumplex/migration-dialog
Closes https://github.com/PrismLauncher/PrismLauncher/issues/46 Closes https://github.com/PrismLauncher/PrismLauncher/issues/204
Diffstat (limited to 'launcher/DataMigrationTask.h')
-rw-r--r--launcher/DataMigrationTask.h42
1 files changed, 42 insertions, 0 deletions
diff --git a/launcher/DataMigrationTask.h b/launcher/DataMigrationTask.h
new file mode 100644
index 00000000..6cc23b1a
--- /dev/null
+++ b/launcher/DataMigrationTask.h
@@ -0,0 +1,42 @@
+// SPDX-FileCopyrightText: 2022 Sefa Eyeoglu <contact@scrumplex.net>
+//
+// SPDX-License-Identifier: GPL-3.0-only
+
+#pragma once
+
+#include "FileSystem.h"
+#include "pathmatcher/IPathMatcher.h"
+#include "tasks/Task.h"
+
+#include <QFuture>
+#include <QFutureWatcher>
+
+/*
+ * Migrate existing data from other MMC-like launchers.
+ */
+
+class DataMigrationTask : public Task {
+ Q_OBJECT
+ public:
+ explicit DataMigrationTask(QObject* parent, const QString& sourcePath, const QString& targetPath, const IPathMatcher::Ptr pathmatcher);
+ ~DataMigrationTask() override = default;
+
+ protected:
+ virtual void executeTask() override;
+
+ protected slots:
+ void dryRunFinished();
+ void dryRunAborted();
+ void copyFinished();
+ void copyAborted();
+
+ private:
+ const QString& m_sourcePath;
+ const QString& m_targetPath;
+ const IPathMatcher::Ptr m_pathMatcher;
+
+ FS::copy m_copy;
+ int m_toCopy = 0;
+ QFuture<bool> m_copyFuture;
+ QFutureWatcher<bool> m_copyFutureWatcher;
+};