Minor Fixes for Separate Update Folder (#1387)

* description + string fixes

* fix use condition

* clang format

* updates now fully extract to game update folder

* don't guarantee the overwrite game condition
This commit is contained in:
ElBread3 2024-10-15 14:29:27 -05:00 committed by GitHub
parent 79c9ff9fdf
commit bb0164c9b2
5 changed files with 20 additions and 16 deletions

View file

@ -3,6 +3,7 @@
#include <zlib-ng.h> #include <zlib-ng.h>
#include "common/io_file.h" #include "common/io_file.h"
#include "common/logging/formatter.h"
#include "core/file_format/pkg.h" #include "core/file_format/pkg.h"
#include "core/file_format/pkg_type.h" #include "core/file_format/pkg_type.h"
@ -349,7 +350,8 @@ bool PKG::Extract(const std::filesystem::path& filepath, const std::filesystem::
auto parent_path = extract_path.parent_path(); auto parent_path = extract_path.parent_path();
auto title_id = GetTitleID(); auto title_id = GetTitleID();
if (parent_path.filename() != title_id) { if (parent_path.filename() != title_id &&
!fmt::UTF(extract_path.u8string()).data.ends_with("-UPDATE")) {
extractPaths[ndinode_counter] = parent_path / title_id; extractPaths[ndinode_counter] = parent_path / title_id;
} else { } else {
// DLCs path has different structure // DLCs path has different structure

View file

@ -26,8 +26,8 @@ public:
GameInfo game; GameInfo game;
game.path = filePath; game.path = filePath;
std::filesystem::path sce_folder_path = filePath / "sce_sys" / "param.sfo"; std::filesystem::path sce_folder_path = filePath / "sce_sys" / "param.sfo";
std::filesystem::path game_update_path = std::filesystem::path game_update_path = filePath;
std::filesystem::path(filePath.string() + "-UPDATE"); game_update_path += "-UPDATE";
if (std::filesystem::exists(game_update_path / "sce_sys" / "param.sfo")) { if (std::filesystem::exists(game_update_path / "sce_sys" / "param.sfo")) {
sce_folder_path = game_update_path / "sce_sys" / "param.sfo"; sce_folder_path = game_update_path / "sce_sys" / "param.sfo";
} }

View file

@ -290,10 +290,14 @@ public:
if (selected == deleteGame || selected == deleteUpdate || selected == deleteDLC) { if (selected == deleteGame || selected == deleteUpdate || selected == deleteDLC) {
bool error = false; bool error = false;
QString folder_path, game_update_path; QString folder_path, game_update_path, dlc_path;
Common::FS::PathToQString(folder_path, m_games[itemID].path); Common::FS::PathToQString(folder_path, m_games[itemID].path);
Common::FS::PathToQString(game_update_path, m_games[itemID].path.concat("-UPDATE")); Common::FS::PathToQString(game_update_path, m_games[itemID].path.concat("-UPDATE"));
Common::FS::PathToQString(
dlc_path, Config::getAddonInstallDir() /
Common::FS::PathFromQString(folder_path).parent_path().filename());
QString message_type = tr("Game"); QString message_type = tr("Game");
if (selected == deleteUpdate) { if (selected == deleteUpdate) {
if (!Config::getSeparateUpdateEnabled()) { if (!Config::getSeparateUpdateEnabled()) {
QMessageBox::critical( QMessageBox::critical(
@ -302,7 +306,8 @@ public:
"config option " "config option "
"to work. If you want to use this feature, please enable it."))); "to work. If you want to use this feature, please enable it.")));
error = true; error = true;
} else if (!std::filesystem::exists(m_games[itemID].path.concat("-UPDATE"))) { } else if (!std::filesystem::exists(
Common::FS::PathFromQString(game_update_path))) {
QMessageBox::critical(nullptr, tr("Error"), QMessageBox::critical(nullptr, tr("Error"),
QString(tr("This game has no update to delete!"))); QString(tr("This game has no update to delete!")));
error = true; error = true;
@ -311,15 +316,12 @@ public:
message_type = tr("Update"); message_type = tr("Update");
} }
} else if (selected == deleteDLC) { } else if (selected == deleteDLC) {
std::filesystem::path addon_path = if (!std::filesystem::exists(Common::FS::PathFromQString(dlc_path))) {
Config::getAddonInstallDir() /
Common::FS::PathFromQString(folder_path).parent_path().filename();
if (!std::filesystem::exists(addon_path)) {
QMessageBox::critical(nullptr, tr("Error"), QMessageBox::critical(nullptr, tr("Error"),
QString(tr("This game has no DLC to delete!"))); QString(tr("This game has no DLC to delete!")));
error = true; error = true;
} else { } else {
folder_path = QString::fromStdString(addon_path.string()); folder_path = dlc_path;
message_type = tr("DLC"); message_type = tr("DLC");
} }
} }

View file

@ -678,13 +678,10 @@ void MainWindow::InstallDragDropPkg(std::filesystem::path file, int pkgNum, int
auto game_install_dir = ids.getSelectedDirectory(); auto game_install_dir = ids.getSelectedDirectory();
auto game_folder_path = game_install_dir / pkg.GetTitleID(); auto game_folder_path = game_install_dir / pkg.GetTitleID();
QString pkgType = QString::fromStdString(pkg.GetPkgFlags()); QString pkgType = QString::fromStdString(pkg.GetPkgFlags());
bool use_game_update = pkgType.contains("Patch") && Config::getSeparateUpdateEnabled(); bool use_game_update = pkgType.contains("PATCH") && Config::getSeparateUpdateEnabled();
auto game_update_path = use_game_update auto game_update_path = use_game_update
? game_install_dir / (std::string(pkg.GetTitleID()) + "-UPDATE") ? game_install_dir / (std::string(pkg.GetTitleID()) + "-UPDATE")
: game_folder_path; : game_folder_path;
if (!std::filesystem::exists(game_update_path)) {
std::filesystem::create_directory(game_update_path);
}
QString gameDirPath; QString gameDirPath;
Common::FS::PathToQString(gameDirPath, game_folder_path); Common::FS::PathToQString(gameDirPath, game_folder_path);
QDir game_dir(gameDirPath); QDir game_dir(gameDirPath);
@ -792,8 +789,6 @@ void MainWindow::InstallDragDropPkg(std::filesystem::path file, int pkgNum, int
} }
} }
} else { } else {
QString gameDirPath;
Common::FS::PathToQString(gameDirPath, game_folder_path);
msgBox.setText(QString(tr("Game already installed") + "\n" + gameDirPath + "\n" + msgBox.setText(QString(tr("Game already installed") + "\n" + gameDirPath + "\n" +
tr("Would you like to overwrite?"))); tr("Would you like to overwrite?")));
msgBox.setStandardButtons(QMessageBox::Yes | QMessageBox::No); msgBox.setStandardButtons(QMessageBox::Yes | QMessageBox::No);

View file

@ -1056,6 +1056,11 @@
<source>fullscreenCheckBox</source> <source>fullscreenCheckBox</source>
<translation>Enable Full Screen:\nAutomatically puts the game window into full-screen mode.\nThis can be toggled by pressing the F11 key.</translation> <translation>Enable Full Screen:\nAutomatically puts the game window into full-screen mode.\nThis can be toggled by pressing the F11 key.</translation>
</message> </message>
<message>
<location filename="../settings_dialog.cpp" line="293"/>
<source>separateUpdatesCheckBox</source>
<translation>Enable Separate Update Folder:\nEnables installing game updates into a separate folder for easy management.</translation>
</message>
<message> <message>
<location filename="../settings_dialog.cpp" line="295"/> <location filename="../settings_dialog.cpp" line="295"/>
<source>showSplashCheckBox</source> <source>showSplashCheckBox</source>