refactor packwiz file write
Signed-off-by: Trial97 <alexandru.tripon97@gmail.com>
This commit is contained in:
parent
3098aecf97
commit
d25e89a4c1
@ -122,7 +122,7 @@ void ModFolderLoadTask::getFromMetadata()
|
|||||||
auto metadata = Metadata::get(m_index_dir, entry);
|
auto metadata = Metadata::get(m_index_dir, entry);
|
||||||
|
|
||||||
if (!metadata.isValid()) {
|
if (!metadata.isValid()) {
|
||||||
return;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto* mod = new Mod(m_mods_dir, metadata);
|
auto* mod = new Mod(m_mods_dir, metadata);
|
||||||
|
@ -21,6 +21,8 @@
|
|||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
|
#include <sstream>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
#include "FileSystem.h"
|
#include "FileSystem.h"
|
||||||
#include "StringUtils.h"
|
#include "StringUtils.h"
|
||||||
@ -161,31 +163,36 @@ void V1::updateModIndex(QDir& index_dir, Mod& mod)
|
|||||||
|
|
||||||
// Put TOML data into the file
|
// Put TOML data into the file
|
||||||
QTextStream in_stream(&index_file);
|
QTextStream in_stream(&index_file);
|
||||||
auto addToStream = [&in_stream](QString&& key, QString value) { in_stream << QString("%1 = \"%2\"\n").arg(key, value); };
|
|
||||||
|
|
||||||
{
|
{
|
||||||
addToStream("name", mod.name);
|
toml::table update;
|
||||||
addToStream("filename", mod.filename);
|
|
||||||
addToStream("side", mod.side);
|
|
||||||
|
|
||||||
in_stream << QString("\n[download]\n");
|
|
||||||
addToStream("mode", mod.mode);
|
|
||||||
addToStream("url", mod.url.toString());
|
|
||||||
addToStream("hash-format", mod.hash_format);
|
|
||||||
addToStream("hash", mod.hash);
|
|
||||||
|
|
||||||
in_stream << QString("\n[update]\n");
|
|
||||||
in_stream << QString("[update.%1]\n").arg(ProviderCaps.name(mod.provider));
|
|
||||||
switch (mod.provider) {
|
switch (mod.provider) {
|
||||||
case (ModPlatform::ResourceProvider::FLAME):
|
case (ModPlatform::ResourceProvider::FLAME):
|
||||||
in_stream << QString("file-id = %1\n").arg(mod.file_id.toString());
|
update = toml::table{
|
||||||
in_stream << QString("project-id = %1\n").arg(mod.project_id.toString());
|
{ "file-id", mod.file_id.toInt() },
|
||||||
|
{ "project-id", mod.project_id.toInt() },
|
||||||
|
};
|
||||||
break;
|
break;
|
||||||
case (ModPlatform::ResourceProvider::MODRINTH):
|
case (ModPlatform::ResourceProvider::MODRINTH):
|
||||||
addToStream("mod-id", mod.mod_id().toString());
|
update = toml::table{
|
||||||
addToStream("version", mod.version().toString());
|
{ "mod-id", mod.mod_id().toString().toStdString() },
|
||||||
|
{ "version", mod.version().toString().toStdString() },
|
||||||
|
};
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
auto tbl = toml::table{ { "name", mod.name.toStdString() },
|
||||||
|
{ "filename", mod.filename.toStdString() },
|
||||||
|
{ "side", mod.side.toStdString() },
|
||||||
|
{ "download",
|
||||||
|
toml::table{
|
||||||
|
{ "mode", mod.mode.toStdString() },
|
||||||
|
{ "url", mod.url.toString().toStdString() },
|
||||||
|
{ "hash-format", mod.hash_format.toStdString() },
|
||||||
|
{ "hash", mod.hash.toStdString() },
|
||||||
|
} },
|
||||||
|
{ "update", toml::table{ { ProviderCaps.name(mod.provider), update } } } };
|
||||||
|
std::stringstream ss;
|
||||||
|
ss << tbl;
|
||||||
|
in_stream << QString::fromStdString(ss.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
index_file.flush();
|
index_file.flush();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user