2019-08-04 03:27:53 +02:00
|
|
|
#pragma once
|
2022-04-15 20:35:17 -03:00
|
|
|
|
2019-08-04 03:27:53 +02:00
|
|
|
#include <QDebug>
|
|
|
|
#include <QObject>
|
2022-04-15 20:35:17 -03:00
|
|
|
|
|
|
|
#include "minecraft/mod/Mod.h"
|
|
|
|
#include "minecraft/mod/ModDetails.h"
|
2019-08-04 03:27:53 +02:00
|
|
|
|
refactor: move general code from mod model to its own model
This aims to continue decoupling other types of resources (e.g. resource
packs, shader packs, etc) from mods, so that we don't have to
continuously watch our backs for changes to one of them affecting the
others.
To do so, this creates a more general list model for resources, based on
the mods one, that allows you to extend it with functionality for other
resources.
I had to do some template and preprocessor stuff to get around the
QObject limitation of not allowing templated classes, so that's sadge :c
On the other hand, I tried cleaning up most general-purpose code in the
mod model, and added some documentation, because it looks nice :D
Signed-off-by: flow <flowlnlnln@gmail.com>
2022-08-09 01:58:22 -03:00
|
|
|
#include "tasks/Task.h"
|
|
|
|
|
2022-12-10 00:52:50 -07:00
|
|
|
namespace ModUtils {
|
|
|
|
|
|
|
|
ModDetails ReadFabricModInfo(QByteArray contents);
|
|
|
|
ModDetails ReadQuiltModInfo(QByteArray contents);
|
|
|
|
ModDetails ReadForgeInfo(QByteArray contents);
|
|
|
|
ModDetails ReadLiteModInfo(QByteArray contents);
|
|
|
|
|
|
|
|
enum class ProcessingLevel { Full, BasicInfoOnly };
|
|
|
|
|
|
|
|
bool process(Mod& mod, ProcessingLevel level = ProcessingLevel::Full);
|
|
|
|
|
|
|
|
bool processZIP(Mod& mod, ProcessingLevel level = ProcessingLevel::Full);
|
|
|
|
bool processFolder(Mod& mod, ProcessingLevel level = ProcessingLevel::Full);
|
|
|
|
bool processLitemod(Mod& mod, ProcessingLevel level = ProcessingLevel::Full);
|
|
|
|
|
|
|
|
/** Checks whether a file is valid as a mod or not. */
|
|
|
|
bool validate(QFileInfo file);
|
2023-05-04 23:42:42 -07:00
|
|
|
|
|
|
|
bool processIconPNG(const Mod& mod, QByteArray&& raw_data);
|
|
|
|
bool loadIconFile(const Mod& mod);
|
2022-12-10 00:52:50 -07:00
|
|
|
} // namespace ModUtils
|
|
|
|
|
2022-12-26 14:29:13 -07:00
|
|
|
class LocalModParseTask : public Task {
|
2019-08-04 03:27:53 +02:00
|
|
|
Q_OBJECT
|
2022-12-26 14:29:13 -07:00
|
|
|
public:
|
2019-08-04 03:27:53 +02:00
|
|
|
struct Result {
|
2022-08-12 17:06:20 -03:00
|
|
|
ModDetails details;
|
2019-08-04 03:27:53 +02:00
|
|
|
};
|
|
|
|
using ResultPtr = std::shared_ptr<Result>;
|
2022-12-26 14:29:13 -07:00
|
|
|
ResultPtr result() const { return m_result; }
|
2019-08-04 03:27:53 +02:00
|
|
|
|
2022-08-12 17:09:56 -03:00
|
|
|
[[nodiscard]] bool canAbort() const override { return true; }
|
|
|
|
bool abort() override;
|
|
|
|
|
2022-12-26 14:29:13 -07:00
|
|
|
LocalModParseTask(int token, ResourceType type, const QFileInfo& modFile);
|
refactor: move general code from mod model to its own model
This aims to continue decoupling other types of resources (e.g. resource
packs, shader packs, etc) from mods, so that we don't have to
continuously watch our backs for changes to one of them affecting the
others.
To do so, this creates a more general list model for resources, based on
the mods one, that allows you to extend it with functionality for other
resources.
I had to do some template and preprocessor stuff to get around the
QObject limitation of not allowing templated classes, so that's sadge :c
On the other hand, I tried cleaning up most general-purpose code in the
mod model, and added some documentation, because it looks nice :D
Signed-off-by: flow <flowlnlnln@gmail.com>
2022-08-09 01:58:22 -03:00
|
|
|
void executeTask() override;
|
2019-08-04 03:27:53 +02:00
|
|
|
|
refactor: move general code from mod model to its own model
This aims to continue decoupling other types of resources (e.g. resource
packs, shader packs, etc) from mods, so that we don't have to
continuously watch our backs for changes to one of them affecting the
others.
To do so, this creates a more general list model for resources, based on
the mods one, that allows you to extend it with functionality for other
resources.
I had to do some template and preprocessor stuff to get around the
QObject limitation of not allowing templated classes, so that's sadge :c
On the other hand, I tried cleaning up most general-purpose code in the
mod model, and added some documentation, because it looks nice :D
Signed-off-by: flow <flowlnlnln@gmail.com>
2022-08-09 01:58:22 -03:00
|
|
|
[[nodiscard]] int token() const { return m_token; }
|
2019-08-04 03:27:53 +02:00
|
|
|
|
2022-12-26 14:29:13 -07:00
|
|
|
private:
|
2019-08-04 03:27:53 +02:00
|
|
|
void processAsZip();
|
|
|
|
void processAsFolder();
|
|
|
|
void processAsLitemod();
|
|
|
|
|
2022-12-26 14:29:13 -07:00
|
|
|
private:
|
2019-08-04 03:27:53 +02:00
|
|
|
int m_token;
|
refactor: move general code from mod model to its own model
This aims to continue decoupling other types of resources (e.g. resource
packs, shader packs, etc) from mods, so that we don't have to
continuously watch our backs for changes to one of them affecting the
others.
To do so, this creates a more general list model for resources, based on
the mods one, that allows you to extend it with functionality for other
resources.
I had to do some template and preprocessor stuff to get around the
QObject limitation of not allowing templated classes, so that's sadge :c
On the other hand, I tried cleaning up most general-purpose code in the
mod model, and added some documentation, because it looks nice :D
Signed-off-by: flow <flowlnlnln@gmail.com>
2022-08-09 01:58:22 -03:00
|
|
|
ResourceType m_type;
|
2019-08-04 03:27:53 +02:00
|
|
|
QFileInfo m_modFile;
|
|
|
|
ResultPtr m_result;
|
2022-08-12 17:09:56 -03:00
|
|
|
|
2022-09-03 13:25:05 -03:00
|
|
|
std::atomic<bool> m_aborted = false;
|
2019-08-04 03:27:53 +02:00
|
|
|
};
|