mirror of
https://github.com/vcmi/vcmi.git
synced 2025-03-29 21:56:54 +02:00
Automatically install missing mods from preset
This commit is contained in:
parent
a983b5c7d7
commit
ba5ed98da5
@ -857,6 +857,12 @@ void CModListView::installMods(QStringList archives)
|
|||||||
modNames.push_back(modName);
|
modNames.push_back(modName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!activatingPreset.isEmpty())
|
||||||
|
{
|
||||||
|
modStateModel->activatePreset(activatingPreset);
|
||||||
|
activatingPreset.clear();
|
||||||
|
}
|
||||||
|
|
||||||
// uninstall old version of mod, if installed
|
// uninstall old version of mod, if installed
|
||||||
for(QString mod : modNames)
|
for(QString mod : modNames)
|
||||||
{
|
{
|
||||||
@ -1151,6 +1157,17 @@ JsonNode CModListView::exportCurrentPreset() const
|
|||||||
|
|
||||||
void CModListView::importPreset(const JsonNode & data)
|
void CModListView::importPreset(const JsonNode & data)
|
||||||
{
|
{
|
||||||
modStateModel->importPreset(data);
|
const auto & [presetName, modList] = modStateModel->importPreset(data);
|
||||||
modStateModel->reloadLocalState();
|
|
||||||
|
if (modList.empty())
|
||||||
|
{
|
||||||
|
modStateModel->activatePreset(presetName);
|
||||||
|
modStateModel->reloadLocalState();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
activatingPreset = presetName;
|
||||||
|
for (const auto & modID : modList)
|
||||||
|
doInstallMod(modID);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -37,6 +37,7 @@ class CModListView : public QWidget
|
|||||||
CModFilterModel * filterModel;
|
CModFilterModel * filterModel;
|
||||||
CDownloadManager * dlManager;
|
CDownloadManager * dlManager;
|
||||||
JsonNode accumulatedRepositoryData;
|
JsonNode accumulatedRepositoryData;
|
||||||
|
QString activatingPreset;
|
||||||
|
|
||||||
QStringList enqueuedModDownloads;
|
QStringList enqueuedModDownloads;
|
||||||
|
|
||||||
|
@ -163,7 +163,10 @@ JsonNode ModStateModel::exportCurrentPreset() const
|
|||||||
return modManager->exportCurrentPreset();
|
return modManager->exportCurrentPreset();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ModStateModel::importPreset(const JsonNode & data)
|
std::tuple<QString, QStringList> ModStateModel::importPreset(const JsonNode & data)
|
||||||
{
|
{
|
||||||
modManager->importPreset(data);
|
std::tuple<QString, QStringList> result;
|
||||||
|
const auto & [presetName, modList] = modManager->importPreset(data);
|
||||||
|
|
||||||
|
return {QString::fromStdString(presetName), stringListStdToQt(modList)};
|
||||||
}
|
}
|
||||||
|
@ -59,5 +59,5 @@ public:
|
|||||||
QString getActivePreset() const;
|
QString getActivePreset() const;
|
||||||
|
|
||||||
JsonNode exportCurrentPreset() const;
|
JsonNode exportCurrentPreset() const;
|
||||||
void importPreset(const JsonNode & data);
|
std::tuple<QString, QStringList> importPreset(const JsonNode & data);
|
||||||
};
|
};
|
||||||
|
@ -207,7 +207,12 @@ const JsonNode & ModsPresetState::getActivePresetConfig() const
|
|||||||
|
|
||||||
TModList ModsPresetState::getActiveRootMods() const
|
TModList ModsPresetState::getActiveRootMods() const
|
||||||
{
|
{
|
||||||
const JsonNode & modsToActivateJson = getActivePresetConfig()["mods"];
|
return getRootMods(getActivePreset());
|
||||||
|
}
|
||||||
|
|
||||||
|
TModList ModsPresetState::getRootMods(const std::string & presetName) const
|
||||||
|
{
|
||||||
|
const JsonNode & modsToActivateJson = modConfig["presets"][presetName]["mods"];
|
||||||
auto modsToActivate = modsToActivateJson.convertTo<std::vector<TModID>>();
|
auto modsToActivate = modsToActivateJson.convertTo<std::vector<TModID>>();
|
||||||
if (!vstd::contains(modsToActivate, ModScope::scopeBuiltin()))
|
if (!vstd::contains(modsToActivate, ModScope::scopeBuiltin()))
|
||||||
modsToActivate.push_back(ModScope::scopeBuiltin());
|
modsToActivate.push_back(ModScope::scopeBuiltin());
|
||||||
@ -399,7 +404,7 @@ JsonNode ModsPresetState::exportCurrentPreset() const
|
|||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ModsPresetState::importPreset(const JsonNode & newConfig)
|
std::string ModsPresetState::importPreset(const JsonNode & newConfig)
|
||||||
{
|
{
|
||||||
std::string importedPresetName = newConfig["name"].String();
|
std::string importedPresetName = newConfig["name"].String();
|
||||||
|
|
||||||
@ -408,6 +413,8 @@ void ModsPresetState::importPreset(const JsonNode & newConfig)
|
|||||||
|
|
||||||
modConfig["presets"][importedPresetName] = newConfig;
|
modConfig["presets"][importedPresetName] = newConfig;
|
||||||
modConfig["presets"][importedPresetName].Struct().erase("name");
|
modConfig["presets"][importedPresetName].Struct().erase("name");
|
||||||
|
|
||||||
|
return importedPresetName;
|
||||||
}
|
}
|
||||||
|
|
||||||
ModsStorage::ModsStorage(const std::vector<TModID> & modsToLoad, const JsonNode & repositoryList)
|
ModsStorage::ModsStorage(const std::vector<TModID> & modsToLoad, const JsonNode & repositoryList)
|
||||||
@ -826,10 +833,23 @@ JsonNode ModManager::exportCurrentPreset() const
|
|||||||
return modsPreset->exportCurrentPreset();
|
return modsPreset->exportCurrentPreset();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ModManager::importPreset(const JsonNode & data)
|
std::tuple<std::string, TModList> ModManager::importPreset(const JsonNode & data)
|
||||||
{
|
{
|
||||||
modsPreset->importPreset(data);
|
std::string presetName = modsPreset->importPreset(data);
|
||||||
|
|
||||||
|
TModList requiredMods = modsPreset->getRootMods(presetName);
|
||||||
|
TModList installedMods = modsState->getInstalledMods();
|
||||||
|
|
||||||
|
TModList missingMods;
|
||||||
|
for (const auto & modID : requiredMods)
|
||||||
|
{
|
||||||
|
if (!vstd::contains(installedMods, modID))
|
||||||
|
missingMods.push_back(modID);
|
||||||
|
}
|
||||||
|
|
||||||
modsPreset->saveConfigurationState();
|
modsPreset->saveConfigurationState();
|
||||||
|
|
||||||
|
return {presetName, missingMods};
|
||||||
}
|
}
|
||||||
|
|
||||||
VCMI_LIB_NAMESPACE_END
|
VCMI_LIB_NAMESPACE_END
|
||||||
|
@ -59,7 +59,10 @@ public:
|
|||||||
std::string getActivePreset() const;
|
std::string getActivePreset() const;
|
||||||
|
|
||||||
JsonNode exportCurrentPreset() const;
|
JsonNode exportCurrentPreset() const;
|
||||||
void importPreset(const JsonNode & data);
|
|
||||||
|
/// Imports preset from provided json
|
||||||
|
/// Returns name of imported preset on success
|
||||||
|
std::string importPreset(const JsonNode & data);
|
||||||
|
|
||||||
void setModActive(const TModID & modName, bool isActive);
|
void setModActive(const TModID & modName, bool isActive);
|
||||||
|
|
||||||
@ -75,6 +78,8 @@ public:
|
|||||||
|
|
||||||
/// Returns list of currently active root mods (non-submod)
|
/// Returns list of currently active root mods (non-submod)
|
||||||
TModList getActiveRootMods() const;
|
TModList getActiveRootMods() const;
|
||||||
|
/// Returns list of root mods present in specified preset
|
||||||
|
TModList getRootMods(const std::string & presetName) const;
|
||||||
|
|
||||||
/// Returns list of all known settings (submods) for a specified mod
|
/// Returns list of all known settings (submods) for a specified mod
|
||||||
std::map<TModID, bool> getModSettings(const TModID & modID) const;
|
std::map<TModID, bool> getModSettings(const TModID & modID) const;
|
||||||
@ -160,7 +165,10 @@ public:
|
|||||||
std::string getActivePreset() const;
|
std::string getActivePreset() const;
|
||||||
|
|
||||||
JsonNode exportCurrentPreset() const;
|
JsonNode exportCurrentPreset() const;
|
||||||
void importPreset(const JsonNode & data);
|
|
||||||
|
/// Imports preset from provided json
|
||||||
|
/// Returns name of imported preset and list of mods that must be installed to activate preset
|
||||||
|
std::tuple<std::string, TModList> importPreset(const JsonNode & data);
|
||||||
};
|
};
|
||||||
|
|
||||||
VCMI_LIB_NAMESPACE_END
|
VCMI_LIB_NAMESPACE_END
|
||||||
|
Loading…
x
Reference in New Issue
Block a user