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

Merge pull request #5062 from Laserlicht/launcher_fix

Launcher fix
This commit is contained in:
Ivan Savenko 2024-12-12 13:37:05 +02:00 committed by GitHub
commit f6b1aea5a7
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 34 additions and 19 deletions

View File

@ -83,6 +83,8 @@ QString Innoextract::getHashError(QString exeFile, QString binFile, QString exeF
}; };
std::vector<data> knownHashes = { std::vector<data> knownHashes = {
// { H3_COMPLETE, "english", 973162040, 0, "7cf1ecec73e8c2f2c2619415cd16749be5641942", "" }, // setup_homm_3_complete_4.0_(10665).exe
// { H3_COMPLETE, "french", ???, 0, "7e5a737c51530a1888033d188ab0635825ee622f", "" }, // setup_homm_3_complete_french_4.0_(10665).exe
{ H3_COMPLETE, "english", 822520, 1005040617, "66646a353b06417fa12c6384405688c84a315cc1", "c624e2071f4e35386765ab044ad5860ac245b7f4" }, // setup_heroes_of_might_and_magic_3_complete_4.0_(28740).exe { H3_COMPLETE, "english", 822520, 1005040617, "66646a353b06417fa12c6384405688c84a315cc1", "c624e2071f4e35386765ab044ad5860ac245b7f4" }, // setup_heroes_of_might_and_magic_3_complete_4.0_(28740).exe
{ H3_COMPLETE, "french", 824960, 997305870, "072f1d4466ff16444d8c7949c6530448a9c53cfa", "9b6b451d2bd2f8b4be159e62fa6d32e87ee10455" }, // setup_heroes_of_might_and_magic_3_complete_4.0_(french)_(28740).exe { H3_COMPLETE, "french", 824960, 997305870, "072f1d4466ff16444d8c7949c6530448a9c53cfa", "9b6b451d2bd2f8b4be159e62fa6d32e87ee10455" }, // setup_heroes_of_might_and_magic_3_complete_4.0_(french)_(28740).exe
{ H3_COMPLETE, "polish", 822288, 849286313, "74ffde00156dd5a8e237668f87213387f0dd9c7c", "2523cf9943043ae100186f89e4ebf7c28be09804" }, // setup_heroes_of_might_and_magic_3_complete_4.0_(polish)_(28740).exe { H3_COMPLETE, "polish", 822288, 849286313, "74ffde00156dd5a8e237668f87213387f0dd9c7c", "2523cf9943043ae100186f89e4ebf7c28be09804" }, // setup_heroes_of_might_and_magic_3_complete_4.0_(polish)_(28740).exe

View File

@ -77,6 +77,8 @@ MainWindow::MainWindow(QWidget * parent)
ui->setupUi(this); ui->setupUi(this);
setAcceptDrops(true);
setWindowIcon(QIcon{":/icons/menu-game.png"}); setWindowIcon(QIcon{":/icons/menu-game.png"});
ui->modslistButton->setIcon(QIcon{":/icons/menu-mods.png"}); ui->modslistButton->setIcon(QIcon{":/icons/menu-mods.png"});
ui->settingsButton->setIcon(QIcon{":/icons/menu-settings.png"}); ui->settingsButton->setIcon(QIcon{":/icons/menu-settings.png"});
@ -164,6 +166,10 @@ void MainWindow::switchToStartTab()
ui->startGameButton->setEnabled(true); ui->startGameButton->setEnabled(true);
ui->startGameButton->setChecked(true); ui->startGameButton->setChecked(true);
ui->tabListWidget->setCurrentIndex(TabRows::START); ui->tabListWidget->setCurrentIndex(TabRows::START);
auto* startGameTabWidget = qobject_cast<StartGameTab*>(ui->tabListWidget->widget(TabRows::START));
if(startGameTabWidget)
startGameTabWidget->refreshState();
} }
void MainWindow::switchToModsTab() void MainWindow::switchToModsTab()
@ -247,6 +253,9 @@ void MainWindow::dropEvent(QDropEvent* event)
void MainWindow::manualInstallFile(QString filePath) void MainWindow::manualInstallFile(QString filePath)
{ {
if(filePath.endsWith(".zip", Qt::CaseInsensitive) || filePath.endsWith(".exe", Qt::CaseInsensitive))
switchToModsTab();
QString fileName = QFileInfo{filePath}.fileName(); QString fileName = QFileInfo{filePath}.fileName();
if(filePath.endsWith(".zip", Qt::CaseInsensitive)) if(filePath.endsWith(".zip", Qt::CaseInsensitive))
getModView()->downloadFile(fileName.toLower() getModView()->downloadFile(fileName.toLower()
@ -279,7 +288,7 @@ void MainWindow::manualInstallFile(QString filePath)
} }
} }
else else
getModView()->downloadFile(fileName, QUrl::fromLocalFile(filePath), fileName); getModView()->installFiles(QStringList{filePath});
} }
ETranslationStatus MainWindow::getTranslationStatus() ETranslationStatus MainWindow::getTranslationStatus()

View File

@ -129,16 +129,14 @@ void ChroniclesExtractor::createBaseMod() const
for(auto & dataPath : VCMIDirs::get().dataPaths()) for(auto & dataPath : VCMIDirs::get().dataPaths())
{ {
auto file = dataPath / "config" / "heroes" / "portraitsChronicles.json"; auto file = pathToQString(dataPath / "config" / "heroes" / "portraitsChronicles.json");
auto destFolder = VCMIDirs::get().userDataPath() / "Mods" / "chronicles" / "content" / "config"; auto destFolder = VCMIDirs::get().userDataPath() / "Mods" / "chronicles" / "content" / "config";
if(boost::filesystem::exists(file)) auto destFile = pathToQString(destFolder / "portraitsChronicles.json");
if(QFile::exists(file))
{ {
boost::filesystem::create_directories(destFolder); QDir().mkpath(pathToQString(destFolder));
#if BOOST_VERSION >= 107400 QFile::remove(destFile);
boost::filesystem::copy_file(file, destFolder / "portraitsChronicles.json", boost::filesystem::copy_options::overwrite_existing); QFile::copy(file, destFile);
#else
boost::filesystem::copy_file(file, destFolder / "portraitsChronicles.json", boost::filesystem::copy_option::overwrite_if_exists);
#endif
} }
} }
} }
@ -235,16 +233,19 @@ void ChroniclesExtractor::installChronicles(QStringList exe)
for(QString f : exe) for(QString f : exe)
{ {
extractionFile++; extractionFile++;
QFile file(f);
if(!createTempDir())
continue;
QString filepath = tempDir.filePath("chr.exe");
QFile(f).copy(filepath);
QFile file(filepath);
int chronicleNo = getChronicleNo(file); int chronicleNo = getChronicleNo(file);
if(!chronicleNo) if(!chronicleNo)
continue; continue;
if(!createTempDir()) if(!extractGogInstaller(filepath))
continue;
if(!extractGogInstaller(f))
continue; continue;
createBaseMod(); createBaseMod();

View File

@ -110,8 +110,6 @@ CModListView::CModListView(QWidget * parent)
{ {
ui->setupUi(this); ui->setupUi(this);
setAcceptDrops(true);
ui->uninstallButton->setIcon(QIcon{":/icons/mod-delete.png"}); ui->uninstallButton->setIcon(QIcon{":/icons/mod-delete.png"});
ui->enableButton->setIcon(QIcon{":/icons/mod-enabled.png"}); ui->enableButton->setIcon(QIcon{":/icons/mod-enabled.png"});
ui->disableButton->setIcon(QIcon{":/icons/mod-disabled.png"}); ui->disableButton->setIcon(QIcon{":/icons/mod-disabled.png"});
@ -788,6 +786,8 @@ void CModListView::installFiles(QStringList files)
if(!exe.empty()) if(!exe.empty())
{ {
ui->progressWidget->setVisible(true);
ui->pushButton->setEnabled(false);
ui->progressBar->setFormat(tr("Installing chronicles")); ui->progressBar->setFormat(tr("Installing chronicles"));
float prog = 0.0; float prog = 0.0;
@ -807,6 +807,9 @@ void CModListView::installFiles(QStringList files)
if(futureExtract.get()) if(futureExtract.get())
{ {
hideProgressBar();
ui->pushButton->setEnabled(true);
ui->progressWidget->setVisible(false);
//update //update
modStateModel->reloadLocalState(); modStateModel->reloadLocalState();
modModel->reloadRepositories(); modModel->reloadRepositories();

View File

@ -54,7 +54,6 @@ class CModListView : public QWidget
void installMods(QStringList archives); void installMods(QStringList archives);
void installMaps(QStringList maps); void installMaps(QStringList maps);
void installFiles(QStringList mods);
QString genChangelogText(const ModState & mod); QString genChangelogText(const ModState & mod);
QString genModInfoText(const ModState & mod); QString genModInfoText(const ModState & mod);
@ -113,6 +112,7 @@ public:
bool isModInstalled(const QString & modName); bool isModInstalled(const QString & modName);
void downloadFile(QString file, QUrl url, QString description, qint64 sizeBytes = 0); void downloadFile(QString file, QUrl url, QString description, qint64 sizeBytes = 0);
void installFiles(QStringList mods);
public slots: public slots:
void enableModByName(QString modName); void enableModByName(QString modName);

View File

@ -33,8 +33,6 @@ class StartGameTab : public QWidget
MainWindow * getMainWindow(); MainWindow * getMainWindow();
void refreshState();
void refreshUpdateStatus(EGameUpdateStatus status); void refreshUpdateStatus(EGameUpdateStatus status);
void refreshTranslation(ETranslationStatus status); void refreshTranslation(ETranslationStatus status);
void refreshMods(); void refreshMods();
@ -45,6 +43,8 @@ public:
explicit StartGameTab(QWidget * parent = nullptr); explicit StartGameTab(QWidget * parent = nullptr);
~StartGameTab(); ~StartGameTab();
void refreshState();
private slots: private slots:
void on_buttonGameStart_clicked(); void on_buttonGameStart_clicked();
void on_buttonOpenChangelog_clicked(); void on_buttonOpenChangelog_clicked();