1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-08 00:39:47 +02:00

Merge pull request #5099 from IvanSavenko/bugfixing_beta_3

Fixes for beta bugs reported on Discord
This commit is contained in:
Ivan Savenko 2024-12-15 23:32:24 +02:00 committed by GitHub
commit a9dfd9b7f4
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 36 additions and 7 deletions

View File

@ -27,12 +27,13 @@
#include "../vcmiqt/jsonutils.h" #include "../vcmiqt/jsonutils.h"
#include "../helper.h" #include "../helper.h"
#include "../../lib/VCMIDirs.h"
#include "../../lib/CConfigHandler.h" #include "../../lib/CConfigHandler.h"
#include "../../lib/texts/Languages.h" #include "../../lib/VCMIDirs.h"
#include "../../lib/modding/CModVersion.h"
#include "../../lib/filesystem/Filesystem.h" #include "../../lib/filesystem/Filesystem.h"
#include "../../lib/json/JsonUtils.h"
#include "../../lib/modding/CModVersion.h"
#include "../../lib/texts/CGeneralTextHandler.h" #include "../../lib/texts/CGeneralTextHandler.h"
#include "../../lib/texts/Languages.h"
#include <future> #include <future>
@ -747,7 +748,7 @@ void CModListView::installFiles(QStringList files)
else if(filename.endsWith(".json", Qt::CaseInsensitive)) else if(filename.endsWith(".json", Qt::CaseInsensitive))
{ {
//download and merge additional files //download and merge additional files
const auto &repoData = JsonUtils::jsonFromFile(filename); JsonNode repoData = JsonUtils::jsonFromFile(filename);
if(repoData["name"].isNull()) if(repoData["name"].isNull())
{ {
// This is main repository index. Download all referenced mods // This is main repository index. Download all referenced mods
@ -769,7 +770,7 @@ void CModListView::installFiles(QStringList files)
// This is json of a single mod. Extract name of mod and add it to repo // This is json of a single mod. Extract name of mod and add it to repo
auto modName = QFileInfo(filename).baseName().toStdString(); auto modName = QFileInfo(filename).baseName().toStdString();
auto modNameLower = boost::algorithm::to_lower_copy(modName); auto modNameLower = boost::algorithm::to_lower_copy(modName);
accumulatedRepositoryData[modNameLower] = repoData; JsonUtils::merge(accumulatedRepositoryData[modNameLower], repoData);
} }
} }
else if(filename.endsWith(".png", Qt::CaseInsensitive)) else if(filename.endsWith(".png", Qt::CaseInsensitive))
@ -778,25 +779,34 @@ void CModListView::installFiles(QStringList files)
if (!accumulatedRepositoryData.isNull() && !repositoryFilesEnqueued) if (!accumulatedRepositoryData.isNull() && !repositoryFilesEnqueued)
{ {
logGlobal->info("Installing repository: started");
manager->setRepositoryData(accumulatedRepositoryData); manager->setRepositoryData(accumulatedRepositoryData);
modModel->reloadRepositories(); modModel->reloadRepositories();
static const QString repositoryCachePath = CLauncherDirs::downloadsPath() + "/repositoryCache.json"; static const QString repositoryCachePath = CLauncherDirs::downloadsPath() + "/repositoryCache.json";
JsonUtils::jsonToFile(repositoryCachePath, modStateModel->getRepositoryData()); JsonUtils::jsonToFile(repositoryCachePath, modStateModel->getRepositoryData());
logGlobal->info("Installing repository: ended");
} }
if(!mods.empty()) if(!mods.empty())
{ {
logGlobal->info("Installing mods: started");
installMods(mods); installMods(mods);
modStateModel->reloadLocalState(); modStateModel->reloadLocalState();
modModel->reloadRepositories(); modModel->reloadRepositories();
logGlobal->info("Installing mods: ended");
} }
if(!maps.empty()) if(!maps.empty())
{
logGlobal->info("Installing maps: started");
installMaps(maps); installMaps(maps);
logGlobal->info("Installing maps: ended");
}
if(!exe.empty()) if(!exe.empty())
{ {
logGlobal->info("Installing chronicles: started");
ui->progressBar->setFormat(tr("Installing Heroes Chronicles")); ui->progressBar->setFormat(tr("Installing Heroes Chronicles"));
ui->progressWidget->setVisible(true); ui->progressWidget->setVisible(true);
ui->pushButton->setEnabled(false); ui->pushButton->setEnabled(false);
@ -826,6 +836,7 @@ void CModListView::installFiles(QStringList files)
modStateModel->reloadLocalState(); modStateModel->reloadLocalState();
modModel->reloadRepositories(); modModel->reloadRepositories();
} }
logGlobal->info("Installing chronicles: ended");
} }
if(!images.empty()) if(!images.empty())
@ -849,8 +860,9 @@ void CModListView::installMods(QStringList archives)
// uninstall old version of mod, if installed // uninstall old version of mod, if installed
for(QString mod : modNames) for(QString mod : modNames)
{ {
if(modStateModel->getMod(mod).isInstalled()) if(modStateModel->isModExists(mod) && modStateModel->getMod(mod).isInstalled())
{ {
logGlobal->info("Uninstalling old version of mod '%s'", mod.toStdString());
if (modStateModel->isModEnabled(mod)) if (modStateModel->isModEnabled(mod))
modsToEnable.push_back(mod); modsToEnable.push_back(mod);
@ -865,17 +877,23 @@ void CModListView::installMods(QStringList archives)
for(int i = 0; i < modNames.size(); i++) for(int i = 0; i < modNames.size(); i++)
{ {
logGlobal->info("Installing mod '%s'", modNames[i].toStdString());
ui->progressBar->setFormat(tr("Installing mod %1").arg(modNames[i])); ui->progressBar->setFormat(tr("Installing mod %1").arg(modNames[i]));
manager->installMod(modNames[i], archives[i]); manager->installMod(modNames[i], archives[i]);
} }
if (!modsToEnable.empty()) if (!modsToEnable.empty())
{
manager->enableMods(modsToEnable); manager->enableMods(modsToEnable);
}
checkManagerErrors(); checkManagerErrors();
for(QString archive : archives) for(QString archive : archives)
{
logGlobal->info("Erasing archive '%s'", archive.toStdString());
QFile::remove(archive); QFile::remove(archive);
}
} }
void CModListView::installMaps(QStringList maps) void CModListView::installMaps(QStringList maps)
@ -884,6 +902,7 @@ void CModListView::installMaps(QStringList maps)
for(QString map : maps) for(QString map : maps)
{ {
logGlobal->info("Importing map '%s'", map.toStdString());
QFile(map).rename(destDir + map.section('/', -1, -1)); QFile(map).rename(destDir + map.section('/', -1, -1));
} }
} }

View File

@ -120,6 +120,9 @@ bool ModStateController::disableMod(QString modname)
bool ModStateController::canInstallMod(QString modname) bool ModStateController::canInstallMod(QString modname)
{ {
if (!modList->isModExists(modname))
return true; // for installation of unknown mods, e.g. via "Install from file" option
auto mod = modList->getMod(modname); auto mod = modList->getMod(modname);
if(mod.isSubmod()) if(mod.isSubmod())

View File

@ -23,7 +23,10 @@
void StartGameTab::changeEvent(QEvent *event) void StartGameTab::changeEvent(QEvent *event)
{ {
if(event->type() == QEvent::LanguageChange) if(event->type() == QEvent::LanguageChange)
{
ui->retranslateUi(this); ui->retranslateUi(this);
refreshState();
}
QWidget::changeEvent(event); QWidget::changeEvent(event);
} }

View File

@ -163,7 +163,7 @@ ModsPresetState::ModsPresetState()
CResourceHandler::get("local")->createResource(settingsPath.getOriginalName() + ".json"); CResourceHandler::get("local")->createResource(settingsPath.getOriginalName() + ".json");
} }
if(modConfig["presets"].isNull()) if(modConfig["presets"].isNull() || modConfig["presets"].Struct().empty())
{ {
modConfig["activePreset"] = JsonNode("default"); modConfig["activePreset"] = JsonNode("default");
if(modConfig["activeMods"].isNull()) if(modConfig["activeMods"].isNull())
@ -171,6 +171,10 @@ ModsPresetState::ModsPresetState()
else else
importInitialPreset(); // 1.5 format import importInitialPreset(); // 1.5 format import
} }
auto allPresets = getAllPresets();
if (!vstd::contains(allPresets, modConfig["activePreset"].String()))
modConfig["activePreset"] = JsonNode(allPresets.front());
} }
void ModsPresetState::createInitialPreset() void ModsPresetState::createInitialPreset()