Further reduce buggy behaviour
Signed-off-by: TheKodeToad <TheKodeToad@proton.me>
This commit is contained in:
parent
970ec8187c
commit
5d5fcae501
@ -19,6 +19,7 @@
|
|||||||
#include "ModrinthPackExportTask.h"
|
#include "ModrinthPackExportTask.h"
|
||||||
|
|
||||||
#include <qcryptographichash.h>
|
#include <qcryptographichash.h>
|
||||||
|
#include <qtconcurrentrun.h>
|
||||||
#include <QFileInfo>
|
#include <QFileInfo>
|
||||||
#include <QFileInfoList>
|
#include <QFileInfoList>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
@ -56,13 +57,17 @@ void ModrinthPackExportTask::executeTask()
|
|||||||
|
|
||||||
bool ModrinthPackExportTask::abort()
|
bool ModrinthPackExportTask::abort()
|
||||||
{
|
{
|
||||||
if (!task.isNull() && task->abort()) {
|
if (task != nullptr) {
|
||||||
|
if (!task->abort())
|
||||||
|
return false;
|
||||||
|
|
||||||
task = nullptr;
|
task = nullptr;
|
||||||
emitFailed(tr("Aborted"));
|
emitFailed(tr("Aborted"));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
pendingAbort = true;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ModrinthPackExportTask::collectFiles()
|
void ModrinthPackExportTask::collectFiles()
|
||||||
@ -106,6 +111,8 @@ void ModrinthPackExportTask::collectFiles()
|
|||||||
|
|
||||||
void ModrinthPackExportTask::parseApiResponse(QByteArray* response)
|
void ModrinthPackExportTask::parseApiResponse(QByteArray* response)
|
||||||
{
|
{
|
||||||
|
task = nullptr;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
QJsonDocument doc = Json::requireDocument(*response);
|
QJsonDocument doc = Json::requireDocument(*response);
|
||||||
|
|
||||||
@ -137,41 +144,54 @@ void ModrinthPackExportTask::parseApiResponse(QByteArray* response)
|
|||||||
|
|
||||||
void ModrinthPackExportTask::buildZip()
|
void ModrinthPackExportTask::buildZip()
|
||||||
{
|
{
|
||||||
setStatus("Adding files...");
|
QtConcurrent::run(QThreadPool::globalInstance(), [this]() {
|
||||||
QuaZip zip(output);
|
setStatus("Adding files...");
|
||||||
if (!zip.open(QuaZip::mdCreate)) {
|
QuaZip zip(output);
|
||||||
QFile::remove(output);
|
if (!zip.open(QuaZip::mdCreate)) {
|
||||||
emitFailed(tr("Could not create file"));
|
QFile::remove(output);
|
||||||
return;
|
emitFailed(tr("Could not create file"));
|
||||||
}
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
QuaZipFile indexFile(&zip);
|
if (pendingAbort) {
|
||||||
if (!indexFile.open(QIODevice::WriteOnly, QuaZipNewInfo("modrinth.index.json"))) {
|
emitFailed(tr("Aborted"));
|
||||||
QFile::remove(output);
|
return;
|
||||||
emitFailed(tr("Could not create index"));
|
}
|
||||||
return;
|
|
||||||
}
|
|
||||||
indexFile.write(generateIndex());
|
|
||||||
|
|
||||||
QDir mc(instance->gameRoot());
|
QuaZipFile indexFile(&zip);
|
||||||
size_t i = 0;
|
if (!indexFile.open(QIODevice::WriteOnly, QuaZipNewInfo("modrinth.index.json"))) {
|
||||||
for (const QFileInfo& file : files) {
|
QFile::remove(output);
|
||||||
setProgress(i, files.length());
|
emitFailed(tr("Could not create index"));
|
||||||
QString relative = mc.relativeFilePath(file.absoluteFilePath());
|
return;
|
||||||
if (!resolvedFiles.contains(relative) && !JlCompress::compressFile(&zip, file.absoluteFilePath(), "overrides/" + relative))
|
}
|
||||||
qWarning() << "Could not compress" << file;
|
indexFile.write(generateIndex());
|
||||||
i++;
|
|
||||||
}
|
|
||||||
|
|
||||||
zip.close();
|
QDir mc(instance->gameRoot());
|
||||||
|
size_t i = 0;
|
||||||
|
for (const QFileInfo& file : files) {
|
||||||
|
if (pendingAbort) {
|
||||||
|
QFile::remove(output);
|
||||||
|
emitFailed(tr("Aborted"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (zip.getZipError() != 0) {
|
setProgress(i, files.length());
|
||||||
QFile::remove(output);
|
QString relative = mc.relativeFilePath(file.absoluteFilePath());
|
||||||
emitFailed(tr("A zip error occured"));
|
if (!resolvedFiles.contains(relative) && !JlCompress::compressFile(&zip, file.absoluteFilePath(), "overrides/" + relative))
|
||||||
return;
|
qWarning() << "Could not compress" << file;
|
||||||
}
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
emitSucceeded();
|
zip.close();
|
||||||
|
|
||||||
|
if (zip.getZipError() != 0) {
|
||||||
|
QFile::remove(output);
|
||||||
|
emitFailed(tr("A zip error occured"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
emitSucceeded();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
QByteArray ModrinthPackExportTask::generateIndex()
|
QByteArray ModrinthPackExportTask::generateIndex()
|
||||||
|
@ -55,6 +55,7 @@ class ModrinthPackExportTask : public Task {
|
|||||||
QMap<QString, QString> pendingHashes;
|
QMap<QString, QString> pendingHashes;
|
||||||
QMap<QString, ResolvedFile> resolvedFiles;
|
QMap<QString, ResolvedFile> resolvedFiles;
|
||||||
Task::Ptr task;
|
Task::Ptr task;
|
||||||
|
bool pendingAbort = false;
|
||||||
|
|
||||||
void collectFiles();
|
void collectFiles();
|
||||||
void parseApiResponse(QByteArray* response);
|
void parseApiResponse(QByteArray* response);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user