diff options
author | flow <thiagodonato300@gmail.com> | 2022-04-15 00:24:57 -0300 |
---|---|---|
committer | flow <flowlnlnln@gmail.com> | 2022-05-23 14:42:27 -0300 |
commit | fcfb2cfc3da9a8f897063db05fdf3aebc41a59ae (patch) | |
tree | 5b2de59599a0c05a23ac8aff0eec4de2c61c9469 /launcher/minecraft/mod/ModFolderLoadTask.cpp | |
parent | e93b9560b5137a5ee7acdc34c0f74992aa02aad6 (diff) | |
download | PrismLauncher-fcfb2cfc3da9a8f897063db05fdf3aebc41a59ae.tar.gz PrismLauncher-fcfb2cfc3da9a8f897063db05fdf3aebc41a59ae.tar.bz2 PrismLauncher-fcfb2cfc3da9a8f897063db05fdf3aebc41a59ae.zip |
feat: use mod metadata for getting mod information
For now this doesn't mean much, but it will help when we need data
exclusive from the metadata, such as addon id and mod provider.
Also removes the metadata when the mod is deleted, and make the Mod.h
file a little more pleasing to look at :)
Diffstat (limited to 'launcher/minecraft/mod/ModFolderLoadTask.cpp')
-rw-r--r-- | launcher/minecraft/mod/ModFolderLoadTask.cpp | 29 |
1 files changed, 23 insertions, 6 deletions
diff --git a/launcher/minecraft/mod/ModFolderLoadTask.cpp b/launcher/minecraft/mod/ModFolderLoadTask.cpp index 88349877..fd4d6008 100644 --- a/launcher/minecraft/mod/ModFolderLoadTask.cpp +++ b/launcher/minecraft/mod/ModFolderLoadTask.cpp @@ -1,18 +1,35 @@ #include "ModFolderLoadTask.h" #include <QDebug> -ModFolderLoadTask::ModFolderLoadTask(QDir dir) : - m_dir(dir), m_result(new Result()) +#include "modplatform/packwiz/Packwiz.h" + +ModFolderLoadTask::ModFolderLoadTask(QDir& mods_dir, QDir& index_dir) : + m_mods_dir(mods_dir), m_index_dir(index_dir), m_result(new Result()) { } void ModFolderLoadTask::run() { - m_dir.refresh(); - for (auto entry : m_dir.entryInfoList()) + // Read metadata first + m_index_dir.refresh(); + for(auto entry : m_index_dir.entryList()){ + // QDir::Filter::NoDotAndDotDot seems to exclude all files for some reason... + if(entry == "." || entry == "..") + continue; + + entry.chop(5); // Remove .toml at the end + Mod mod(m_mods_dir, Packwiz::getIndexForMod(m_index_dir, entry)); + m_result->mods[mod.mmc_id()] = mod; + } + + // Read JAR files that don't have metadata + m_mods_dir.refresh(); + for (auto entry : m_mods_dir.entryInfoList()) { - Mod m(entry); - m_result->mods[m.mmc_id()] = m; + Mod mod(entry); + if(!m_result->mods.contains(mod.mmc_id())) + m_result->mods[mod.mmc_id()] = mod; } + emit succeeded(); } |