fix duplicate optional mods dialog appearing when updating a modpack

Signed-off-by: Trial97 <alexandru.tripon97@gmail.com>

tmp
This commit is contained in:
Trial97 2025-03-06 10:16:53 +02:00
parent 79180db663
commit 59a816c696
No known key found for this signature in database
GPG key ID: 55EF5DA53DB36318
2 changed files with 33 additions and 16 deletions

View file

@ -227,6 +227,11 @@ bool FlameCreationTask::updateInstance()
QString relative_path(FS::PathCombine(file.targetFolder, file.version.fileName)); QString relative_path(FS::PathCombine(file.targetFolder, file.version.fileName));
qDebug() << "Scheduling" << relative_path << "for removal"; qDebug() << "Scheduling" << relative_path << "for removal";
m_files_to_remove.append(old_minecraft_dir.absoluteFilePath(relative_path)); m_files_to_remove.append(old_minecraft_dir.absoluteFilePath(relative_path));
if (relative_path.endsWith(".disabled")) { // remove it if it was enabled/disabled by user
m_files_to_remove.append(old_minecraft_dir.absoluteFilePath(relative_path.chopped(9)));
} else {
m_files_to_remove.append(old_minecraft_dir.absoluteFilePath(relative_path + ".disabled"));
}
} }
}); });
connect(job.get(), &Task::failed, this, [](QString reason) { qCritical() << "Failed to get files: " << reason; }); connect(job.get(), &Task::failed, this, [](QString reason) { qCritical() << "Failed to get files: " << reason; });

View file

@ -121,6 +121,11 @@ bool ModrinthCreationTask::updateInstance()
continue; continue;
qDebug() << "Scheduling" << file.path << "for removal"; qDebug() << "Scheduling" << file.path << "for removal";
m_files_to_remove.append(old_minecraft_dir.absoluteFilePath(file.path)); m_files_to_remove.append(old_minecraft_dir.absoluteFilePath(file.path));
if (file.path.endsWith(".disabled")) { // remove it if it was enabled/disabled by user
m_files_to_remove.append(old_minecraft_dir.absoluteFilePath(file.path.chopped(9)));
} else {
m_files_to_remove.append(old_minecraft_dir.absoluteFilePath(file.path + ".disabled"));
}
} }
} }
@ -416,6 +421,7 @@ bool ModrinthCreationTask::parseManifest(const QString& index_path,
} }
if (!optionalFiles.empty()) { if (!optionalFiles.empty()) {
if (show_optional_dialog) {
QStringList oFiles; QStringList oFiles;
for (auto file : optionalFiles) for (auto file : optionalFiles)
oFiles.push_back(file.path); oFiles.push_back(file.path);
@ -434,6 +440,12 @@ bool ModrinthCreationTask::parseManifest(const QString& index_path,
} }
files.push_back(file); files.push_back(file);
} }
} else {
for (auto file : optionalFiles) {
file.path += ".disabled";
files.push_back(file);
}
}
} }
if (set_internal_data) { if (set_internal_data) {
auto dependencies = Json::requireObject(obj, "dependencies", "modrinth.index.json"); auto dependencies = Json::requireObject(obj, "dependencies", "modrinth.index.json");