aboutsummaryrefslogtreecommitdiff
path: root/launcher/minecraft/mod/tasks/BasicFolderLoadTask.h
diff options
context:
space:
mode:
Diffstat (limited to 'launcher/minecraft/mod/tasks/BasicFolderLoadTask.h')
-rw-r--r--launcher/minecraft/mod/tasks/BasicFolderLoadTask.h37
1 files changed, 24 insertions, 13 deletions
diff --git a/launcher/minecraft/mod/tasks/BasicFolderLoadTask.h b/launcher/minecraft/mod/tasks/BasicFolderLoadTask.h
index cc02a9b9..be0e752d 100644
--- a/launcher/minecraft/mod/tasks/BasicFolderLoadTask.h
+++ b/launcher/minecraft/mod/tasks/BasicFolderLoadTask.h
@@ -10,37 +10,46 @@
#include "tasks/Task.h"
-/** Very simple task that just loads a folder's contents directly.
+/** Very simple task that just loads a folder's contents directly.
*/
-class BasicFolderLoadTask : public Task
-{
+class BasicFolderLoadTask : public Task {
Q_OBJECT
-public:
+ public:
struct Result {
QMap<QString, Resource::Ptr> resources;
};
using ResultPtr = std::shared_ptr<Result>;
- [[nodiscard]] ResultPtr result() const {
- return m_result;
- }
+ [[nodiscard]] ResultPtr result() const { return m_result; }
-public:
- BasicFolderLoadTask(QDir dir) : Task(nullptr, false), m_dir(dir), m_result(new Result) {}
+ public:
+ BasicFolderLoadTask(QDir dir) : Task(nullptr, false), m_dir(dir), m_result(new Result)
+ {
+ m_create_func = [](QFileInfo const& entry) -> Resource* {
+ return new Resource(entry);
+ };
+ }
+ BasicFolderLoadTask(QDir dir, std::function<Resource*(QFileInfo const&)> create_function)
+ : Task(nullptr, false), m_dir(dir), m_result(new Result), m_create_func(std::move(create_function))
+ {}
[[nodiscard]] bool canAbort() const override { return true; }
- bool abort() override { m_aborted = true; return true; }
+ bool abort() override
+ {
+ m_aborted.store(true);
+ return true;
+ }
void executeTask() override
{
m_dir.refresh();
for (auto entry : m_dir.entryInfoList()) {
- auto resource = new Resource(entry);
+ auto resource = m_create_func(entry);
m_result->resources.insert(resource->internal_id(), resource);
}
if (m_aborted)
- emitAborted();
+ emit finished();
else
emitSucceeded();
}
@@ -49,5 +58,7 @@ private:
QDir m_dir;
ResultPtr m_result;
- bool m_aborted = false;
+ std::atomic<bool> m_aborted = false;
+
+ std::function<Resource*(QFileInfo const&)> m_create_func;
};