From 4b93b8b57460c83421d0d859e243dd05a864bdc1 Mon Sep 17 00:00:00 2001
From: Martin <67326368+Martini-141@users.noreply.github.com>
Date: Tue, 28 Jan 2025 17:47:00 +0100
Subject: [PATCH 1/8] add missing translations and other corrections nb (#2253)
---
src/qt_gui/translations/nb.ts | 42 +++++++++++++++++------------------
1 file changed, 21 insertions(+), 21 deletions(-)
diff --git a/src/qt_gui/translations/nb.ts b/src/qt_gui/translations/nb.ts
index d6d4090df..0b7d2699a 100644
--- a/src/qt_gui/translations/nb.ts
+++ b/src/qt_gui/translations/nb.ts
@@ -98,7 +98,7 @@
Open Folder...
- Åpne mappen...
+ Åpne mappe...
Open Game Folder
@@ -126,7 +126,7 @@
Copy All
- Kopier alle
+ Kopier alt
Delete...
@@ -146,19 +146,19 @@
Compatibility...
- Compatibility...
+ Kompatibilitet...
Update database
- Update database
+ Oppdater database
View report
- View report
+ Vis rapport
Submit a report
- Submit a report
+ Send inn en rapport
Shortcut creation
@@ -574,11 +574,11 @@
Trophy Key
- Trophy Key
+ Trofénøkkel
Trophy
- Trophy
+ Trofé
Logger
@@ -658,7 +658,7 @@
Enable Shaders Dumping
- Aktiver dumping av skyggelegger
+ Aktiver skyggeleggerdumping
Enable NULL GPU
@@ -666,7 +666,7 @@
Paths
- Stier
+ Mapper
Game Folders
@@ -686,7 +686,7 @@
Enable Debug Dumping
- Aktiver dumping av feilretting
+ Aktiver feilrettingsdumping
Enable Vulkan Validation Layers
@@ -718,7 +718,7 @@
GUI Settings
- GUI-innstillinger
+ Grensesnitt-innstillinger
Disable Trophy Pop-ups
@@ -730,7 +730,7 @@
Update Compatibility Database On Startup
- Oppdater kompatibilitets-database ved oppstart
+ Oppdater database ved oppstart
Game Compatibility
@@ -750,7 +750,7 @@
Audio Backend
- Audio Backend
+ Lydsystem
Save
@@ -806,7 +806,7 @@
TrophyKey
- Trophy Key:\nKey used to decrypt trophies. Must be obtained from your jailbroken console.\nMust contain only hex characters.
+ Trofénøkkel:\nNøkkel brukes til å dekryptere trofeer. Må hentes fra din konsoll (jailbroken).\nMå bare inneholde sekskantede tegn.
logTypeGroupBox
@@ -846,7 +846,7 @@
checkCompatibilityOnStartupCheckBox
- Oppdater kompatibilitets-data ved oppstart:\nOppdaterer kompatibilitets-databasen automatisk når shadPS4 starter.
+ Oppdater database ved oppstart:\nOppdaterer kompatibilitets-databasen automatisk når shadPS4 starter.
updateCompatibilityButton
@@ -894,7 +894,7 @@
dumpShadersCheckBox
- Aktiver dumping av skyggelegger:\nFor teknisk feilsøking lagrer skyggeleggerne fra spillet i en mappe mens de gjengis.
+ Aktiver skyggeleggerdumping:\nFor teknisk feilsøking lagrer skyggeleggerne fra spillet i en mappe mens de gjengis.
nullGpuCheckBox
@@ -914,7 +914,7 @@
debugDump
- Aktiver dumping av feilsøking:\nLagrer import- og eksport-symbolene og filoverskriftsinformasjonen til det nåværende kjørende PS4-programmet i en katalog.
+ Aktiver feilrettingsdumping:\nLagrer import- og eksport-symbolene og filoverskriftsinformasjonen til det nåværende kjørende PS4-programmet i en katalog.
vkValidationCheckBox
@@ -1188,7 +1188,7 @@
Path
- Sti
+ Adresse
Play Time
@@ -1232,7 +1232,7 @@
Game can be completed with playable performance and no major glitches
- Spillet kan fullføres med spillbar ytelse og ingen store feil
+ Spillet kan fullføres med spillbar ytelse og uten store feil
@@ -1361,4 +1361,4 @@
TB
-
\ No newline at end of file
+
From 2cdd873681dd3b03d0752bda5c84412f06f4f0b8 Mon Sep 17 00:00:00 2001
From: slick-daddy <129640104+slick-daddy@users.noreply.github.com>
Date: Tue, 28 Jan 2025 19:47:12 +0300
Subject: [PATCH 2/8] Update tr_TR.ts (#2255)
---
src/qt_gui/translations/tr_TR.ts | 54 ++++++++++++++++----------------
1 file changed, 27 insertions(+), 27 deletions(-)
diff --git a/src/qt_gui/translations/tr_TR.ts b/src/qt_gui/translations/tr_TR.ts
index 6436278de..a2368bfee 100644
--- a/src/qt_gui/translations/tr_TR.ts
+++ b/src/qt_gui/translations/tr_TR.ts
@@ -546,7 +546,7 @@
Enable Separate Update Folder
- Enable Separate Update Folder
+ Ayrı Güncelleme Klasörünü Etkinleştir
Default tab when opening settings
@@ -554,7 +554,7 @@
Show Game Size In List
- Göster oyun boyutunu listede
+ Oyun Boyutunu Listede Göster
Show Splash
@@ -574,11 +574,11 @@
Trophy Key
- Trophy Key
+ Kupa Anahtarı
Trophy
- Trophy
+ Kupa
Logger
@@ -722,7 +722,7 @@
Disable Trophy Pop-ups
- Disable Trophy Pop-ups
+ Kupa Açılır Pencerelerini Devre Dışı Bırak
Play title music
@@ -730,23 +730,23 @@
Update Compatibility Database On Startup
- Update Compatibility Database On Startup
+ Başlangıçta Uyumluluk Veritabanını Güncelle
Game Compatibility
- Game Compatibility
+ Oyun Uyumluluğu
Display Compatibility Data
- Display Compatibility Data
+ Uyumluluk Verilerini Göster
Update Compatibility Database
- Update Compatibility Database
+ Uyumluluk Veritabanını Güncelle
Volume
- Ses seviyesi
+ Ses Seviyesi
Audio Backend
@@ -1105,11 +1105,11 @@
The game is in version: %1
- Oyun sürümde: %1
+ Oyun sürümü: %1
The downloaded patch only works on version: %1
- İndirilen yamanın sadece sürümde çalışıyor: %1
+ İndirilen yama sadece şu sürümde çalışıyor: %1
You may need to update your game.
@@ -1168,7 +1168,7 @@
Compatibility
- Compatibility
+ Uyumluluk
Region
@@ -1196,35 +1196,35 @@
Never Played
- Never Played
+ Hiç Oynanmadı
h
- h
+ sa
m
- m
+ dk
s
- s
+ sn
Compatibility is untested
- Compatibility is untested
+ Uyumluluk test edilmemiş
Game does not initialize properly / crashes the emulator
- Game does not initialize properly / crashes the emulator
+ Oyun düzgün bir şekilde başlatılamıyor / emülatörü çökertiyor
Game boots, but only displays a blank screen
- Game boots, but only displays a blank screen
+ Oyun başlatılabiliyor ancak yalnızca boş bir ekran gösteriyor
Game displays an image but does not go past the menu
- Game displays an image but does not go past the menu
+ Oyun bir resim gösteriyor ancak menüleri geçemiyor
Game has game-breaking glitches or unplayable performance
@@ -1232,7 +1232,7 @@
Game can be completed with playable performance and no major glitches
- Game can be completed with playable performance and no major glitches
+ Oyun, oynanabilir performansla tamamlanabilir ve büyük aksaklık yok
@@ -1267,7 +1267,7 @@
Your version is already up to date!
- Versiyonunuz zaten güncel!
+ Sürümünüz zaten güncel!
Update Available
@@ -1279,11 +1279,11 @@
Current Version
- Mevcut Versiyon
+ Mevcut Sürüm
Latest Version
- Son Versiyon
+ Son Sürüm
Do you want to update?
@@ -1335,7 +1335,7 @@
Failed to create the update script file
- Güncelleme betiği dosyası oluşturulamadı
+ Güncelleme komut dosyası oluşturulamadı
@@ -1361,4 +1361,4 @@
TB
-
\ No newline at end of file
+
From a78f8afe58a995cecdb4eb1f1e6d6e58320444f6 Mon Sep 17 00:00:00 2001
From: squidbus <175574877+squidbus@users.noreply.github.com>
Date: Tue, 28 Jan 2025 08:48:19 -0800
Subject: [PATCH 3/8] libraries: Implement libSceZlib. (#2256)
* libraries: add zlib hle skeleton/stub
* libraries: Implement libSceZlib.
* zlib: Make variables static.
---------
Co-authored-by: Nenkai
---
CMakeLists.txt | 6 +
src/common/logging/filter.cpp | 1 +
src/common/logging/types.h | 1 +
src/core/libraries/libs.cpp | 2 +
src/core/libraries/zlib/zlib.cpp | 183 +++++++++++++++++++++++++++
src/core/libraries/zlib/zlib_error.h | 18 +++
src/core/libraries/zlib/zlib_sce.h | 21 +++
7 files changed, 232 insertions(+)
create mode 100644 src/core/libraries/zlib/zlib.cpp
create mode 100644 src/core/libraries/zlib/zlib_error.h
create mode 100644 src/core/libraries/zlib/zlib_sce.h
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 4c9dad307..78e3c7997 100755
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -440,6 +440,11 @@ set(NP_LIBS src/core/libraries/np_common/np_common.cpp
src/core/libraries/np_party/np_party.h
)
+set(ZLIB_LIB src/core/libraries/zlib/zlib.cpp
+ src/core/libraries/zlib/zlib_sce.h
+ src/core/libraries/zlib/zlib_error.h
+)
+
set(MISC_LIBS src/core/libraries/screenshot/screenshot.cpp
src/core/libraries/screenshot/screenshot.h
src/core/libraries/move/move.cpp
@@ -612,6 +617,7 @@ set(CORE src/core/aerolib/stubs.cpp
${PLAYGO_LIB}
${RANDOM_LIB}
${USBD_LIB}
+ ${ZLIB_LIB}
${MISC_LIBS}
${IME_LIB}
${FIBER_LIB}
diff --git a/src/common/logging/filter.cpp b/src/common/logging/filter.cpp
index f1d3a9499..dd708c528 100644
--- a/src/common/logging/filter.cpp
+++ b/src/common/logging/filter.cpp
@@ -133,6 +133,7 @@ bool ParseFilterRule(Filter& instance, Iterator begin, Iterator end) {
SUB(Lib, Mouse) \
SUB(Lib, WebBrowserDialog) \
SUB(Lib, NpParty) \
+ SUB(Lib, Zlib) \
CLS(Frontend) \
CLS(Render) \
SUB(Render, Vulkan) \
diff --git a/src/common/logging/types.h b/src/common/logging/types.h
index d5530312c..54f8cdd0b 100644
--- a/src/common/logging/types.h
+++ b/src/common/logging/types.h
@@ -100,6 +100,7 @@ enum class Class : u8 {
Lib_Mouse, ///< The LibSceMouse implementation
Lib_WebBrowserDialog, ///< The LibSceWebBrowserDialog implementation
Lib_NpParty, ///< The LibSceNpParty implementation
+ Lib_Zlib, ///< The LibSceZlib implementation.
Frontend, ///< Emulator UI
Render, ///< Video Core
Render_Vulkan, ///< Vulkan backend
diff --git a/src/core/libraries/libs.cpp b/src/core/libraries/libs.cpp
index e09de1cee..8cf286d13 100644
--- a/src/core/libraries/libs.cpp
+++ b/src/core/libraries/libs.cpp
@@ -54,6 +54,7 @@
#include "core/libraries/videodec/videodec2.h"
#include "core/libraries/videoout/video_out.h"
#include "core/libraries/web_browser_dialog/webbrowserdialog.h"
+#include "core/libraries/zlib/zlib_sce.h"
#include "fiber/fiber.h"
#include "jpeg/jpegenc.h"
@@ -111,6 +112,7 @@ void InitHLELibs(Core::Loader::SymbolsResolver* sym) {
Libraries::Mouse::RegisterlibSceMouse(sym);
Libraries::WebBrowserDialog::RegisterlibSceWebBrowserDialog(sym);
Libraries::NpParty::RegisterlibSceNpParty(sym);
+ Libraries::Zlib::RegisterlibSceZlib(sym);
}
} // namespace Libraries
diff --git a/src/core/libraries/zlib/zlib.cpp b/src/core/libraries/zlib/zlib.cpp
new file mode 100644
index 000000000..899cb5bf6
--- /dev/null
+++ b/src/core/libraries/zlib/zlib.cpp
@@ -0,0 +1,183 @@
+// SPDX-FileCopyrightText: Copyright 2024 shadPS4 Emulator Project
+// SPDX-License-Identifier: GPL-2.0-or-later
+
+#include
+#include
+#include
+#include
+#include
+#include
+
+#include "common/logging/log.h"
+#include "common/thread.h"
+#include "core/libraries/kernel/threads.h"
+#include "core/libraries/libs.h"
+#include "core/libraries/zlib/zlib_error.h"
+#include "core/libraries/zlib/zlib_sce.h"
+
+namespace Libraries::Zlib {
+
+struct InflateTask {
+ u64 request_id;
+ const void* src;
+ u32 src_length;
+ void* dst;
+ u32 dst_length;
+};
+
+struct InflateResult {
+ u32 length;
+ s32 status;
+};
+
+static Kernel::Thread task_thread;
+
+static std::mutex mutex;
+static std::queue task_queue;
+static std::condition_variable_any task_queue_cv;
+static std::queue done_queue;
+static std::condition_variable_any done_queue_cv;
+static std::unordered_map results;
+static u64 next_request_id;
+
+void ZlibTaskThread(const std::stop_token& stop) {
+ Common::SetCurrentThreadName("shadPS4:ZlibTaskThread");
+
+ while (!stop.stop_requested()) {
+ InflateTask task;
+ {
+ // Lock and pop from the task queue, unless stop has been requested.
+ std::unique_lock lock(mutex);
+ if (!task_queue_cv.wait(lock, stop, [&] { return !task_queue.empty(); })) {
+ break;
+ }
+ task = task_queue.back();
+ task_queue.pop();
+ }
+
+ uLongf decompressed_length = task.dst_length;
+ const auto ret = uncompress(static_cast(task.dst), &decompressed_length,
+ static_cast(task.src), task.src_length);
+
+ {
+ // Lock, insert the new result, and push the finished request ID to the done queue.
+ std::unique_lock lock(mutex);
+ results[task.request_id] = InflateResult{
+ .length = static_cast(decompressed_length),
+ .status = ret == Z_BUF_ERROR ? ORBIS_ZLIB_ERROR_NOSPACE
+ : ret == Z_OK ? ORBIS_OK
+ : ORBIS_ZLIB_ERROR_FATAL,
+ };
+ done_queue.push(task.request_id);
+ }
+ done_queue_cv.notify_one();
+ }
+}
+
+s32 PS4_SYSV_ABI sceZlibInitialize(const void* buffer, u32 length) {
+ LOG_INFO(Lib_Zlib, "called");
+ if (task_thread.Joinable()) {
+ return ORBIS_ZLIB_ERROR_ALREADY_INITIALIZED;
+ }
+
+ // Initialize with empty task data
+ task_queue = std::queue();
+ done_queue = std::queue();
+ results.clear();
+ next_request_id = 1;
+
+ task_thread.Run([](const std::stop_token& stop) { ZlibTaskThread(stop); });
+ return ORBIS_OK;
+}
+
+s32 PS4_SYSV_ABI sceZlibInflate(const void* src, u32 src_len, void* dst, u32 dst_len,
+ u64* request_id) {
+ LOG_DEBUG(Lib_Zlib, "(STUBBED) called");
+ if (!task_thread.Joinable()) {
+ return ORBIS_ZLIB_ERROR_NOT_INITIALIZED;
+ }
+ if (!src || !src_len || !dst || !dst_len || !request_id || dst_len > 64_KB ||
+ dst_len % 2_KB != 0) {
+ return ORBIS_ZLIB_ERROR_INVALID;
+ }
+
+ {
+ std::unique_lock lock(mutex);
+ *request_id = next_request_id++;
+ task_queue.emplace(InflateTask{
+ .request_id = *request_id,
+ .src = src,
+ .src_length = src_len,
+ .dst = dst,
+ .dst_length = dst_len,
+ });
+ task_queue_cv.notify_one();
+ }
+ return ORBIS_OK;
+}
+
+s32 PS4_SYSV_ABI sceZlibWaitForDone(u64* request_id, const u32* timeout) {
+ LOG_DEBUG(Lib_Zlib, "(STUBBED) called");
+ if (!task_thread.Joinable()) {
+ return ORBIS_ZLIB_ERROR_NOT_INITIALIZED;
+ }
+ if (!request_id) {
+ return ORBIS_ZLIB_ERROR_INVALID;
+ }
+
+ {
+ // Pop from the done queue, unless the timeout is reached.
+ std::unique_lock lock(mutex);
+ const auto pred = [] { return !done_queue.empty(); };
+ if (timeout) {
+ if (!done_queue_cv.wait_for(lock, std::chrono::milliseconds(*timeout), pred)) {
+ return ORBIS_ZLIB_ERROR_TIMEDOUT;
+ }
+ } else {
+ done_queue_cv.wait(lock, pred);
+ }
+ *request_id = done_queue.back();
+ done_queue.pop();
+ }
+ return ORBIS_OK;
+}
+
+s32 PS4_SYSV_ABI sceZlibGetResult(const u64 request_id, u32* dst_length, s32* status) {
+ LOG_DEBUG(Lib_Zlib, "(STUBBED) called");
+ if (!task_thread.Joinable()) {
+ return ORBIS_ZLIB_ERROR_NOT_INITIALIZED;
+ }
+ if (!dst_length || !status) {
+ return ORBIS_ZLIB_ERROR_INVALID;
+ }
+
+ {
+ std::unique_lock lock(mutex);
+ if (!results.contains(request_id)) {
+ return ORBIS_ZLIB_ERROR_NOT_FOUND;
+ }
+ const auto result = results[request_id];
+ *dst_length = result.length;
+ *status = result.status;
+ }
+ return ORBIS_OK;
+}
+
+s32 PS4_SYSV_ABI sceZlibFinalize() {
+ LOG_INFO(Lib_Zlib, "called");
+ if (!task_thread.Joinable()) {
+ return ORBIS_ZLIB_ERROR_NOT_INITIALIZED;
+ }
+ task_thread.Stop();
+ return ORBIS_OK;
+}
+
+void RegisterlibSceZlib(Core::Loader::SymbolsResolver* sym) {
+ LIB_FUNCTION("m1YErdIXCp4", "libSceZlib", 1, "libSceZlib", 1, 1, sceZlibInitialize);
+ LIB_FUNCTION("6na+Sa-B83w", "libSceZlib", 1, "libSceZlib", 1, 1, sceZlibFinalize);
+ LIB_FUNCTION("TLar1HULv1Q", "libSceZlib", 1, "libSceZlib", 1, 1, sceZlibInflate);
+ LIB_FUNCTION("uB8VlDD4e0s", "libSceZlib", 1, "libSceZlib", 1, 1, sceZlibWaitForDone);
+ LIB_FUNCTION("2eDcGHC0YaM", "libSceZlib", 1, "libSceZlib", 1, 1, sceZlibGetResult);
+};
+
+} // namespace Libraries::Zlib
diff --git a/src/core/libraries/zlib/zlib_error.h b/src/core/libraries/zlib/zlib_error.h
new file mode 100644
index 000000000..59574f0b2
--- /dev/null
+++ b/src/core/libraries/zlib/zlib_error.h
@@ -0,0 +1,18 @@
+// SPDX-FileCopyrightText: Copyright 2024 shadPS4 Emulator Project
+// SPDX-License-Identifier: GPL-2.0-or-later
+
+#pragma once
+
+#include "core/libraries/error_codes.h"
+
+// Zlib library
+constexpr int ORBIS_ZLIB_ERROR_NOT_FOUND = 0x81120002;
+constexpr int ORBIS_ZLIB_ERROR_BUSY = 0x8112000B;
+constexpr int ORBIS_ZLIB_ERROR_FAULT = 0x8112000E;
+constexpr int ORBIS_ZLIB_ERROR_INVALID = 0x81120016;
+constexpr int ORBIS_ZLIB_ERROR_NOSPACE = 0x8112001C;
+constexpr int ORBIS_ZLIB_ERROR_NOT_SUPPORTED = 0x81120025;
+constexpr int ORBIS_ZLIB_ERROR_TIMEDOUT = 0x81120027;
+constexpr int ORBIS_ZLIB_ERROR_NOT_INITIALIZED = 0x81120032;
+constexpr int ORBIS_ZLIB_ERROR_ALREADY_INITIALIZED = 0x81120033;
+constexpr int ORBIS_ZLIB_ERROR_FATAL = 0x811200FF;
diff --git a/src/core/libraries/zlib/zlib_sce.h b/src/core/libraries/zlib/zlib_sce.h
new file mode 100644
index 000000000..6f8cf9468
--- /dev/null
+++ b/src/core/libraries/zlib/zlib_sce.h
@@ -0,0 +1,21 @@
+// SPDX-FileCopyrightText: Copyright 2024 shadPS4 Emulator Project
+// SPDX-License-Identifier: GPL-2.0-or-later
+
+#pragma once
+
+#include "common/types.h"
+
+namespace Core::Loader {
+class SymbolsResolver;
+}
+namespace Libraries::Zlib {
+
+s32 PS4_SYSV_ABI sceZlibInitialize(const void* buffer, u32 length);
+s32 PS4_SYSV_ABI sceZlibInflate(const void* src, u32 src_len, void* dst, u32 dst_len,
+ u64* request_id);
+s32 PS4_SYSV_ABI sceZlibWaitForDone(u64* request_id, const u32* timeout);
+s32 PS4_SYSV_ABI sceZlibGetResult(u64 request_id, u32* dst_length, s32* status);
+s32 PS4_SYSV_ABI sceZlibFinalize();
+
+void RegisterlibSceZlib(Core::Loader::SymbolsResolver* sym);
+} // namespace Libraries::Zlib
\ No newline at end of file
From 0575853be18d8f0504482b4a5a407fb14a23d492 Mon Sep 17 00:00:00 2001
From: squidbus <175574877+squidbus@users.noreply.github.com>
Date: Tue, 28 Jan 2025 17:56:05 -0800
Subject: [PATCH 4/8] externals: Update MoltenVK. (#2264)
Adds support for VK_EXT_depth_clip_control
---
externals/MoltenVK/MoltenVK | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/externals/MoltenVK/MoltenVK b/externals/MoltenVK/MoltenVK
index 6fa077fb8..aba997657 160000
--- a/externals/MoltenVK/MoltenVK
+++ b/externals/MoltenVK/MoltenVK
@@ -1 +1 @@
-Subproject commit 6fa077fb8ed8dac4e4cd66b6b1ebd7b4d955a754
+Subproject commit aba997657b94d6de1794ebad36ce5634341252c7
From 78a0a755c5f2ff06c340ec0dc3431fc247aaa3e4 Mon Sep 17 00:00:00 2001
From: ElBread3 <92335081+ElBread3@users.noreply.github.com>
Date: Tue, 28 Jan 2025 21:14:47 -0600
Subject: [PATCH 5/8] qt_gui: Some game install features and fixes (#2261)
* open update folder + delete save folder + bulk install checkbox
* delete pkg on install checkbox + use game icon for finish window
---
src/qt_gui/gui_context_menus.h | 45 ++++++++++++++++++++++++++++---
src/qt_gui/install_dir_select.cpp | 24 ++++++++++++++---
src/qt_gui/install_dir_select.h | 12 +++++++++
src/qt_gui/main_window.cpp | 26 +++++++++++++++---
src/qt_gui/main_window.h | 4 +++
5 files changed, 101 insertions(+), 10 deletions(-)
diff --git a/src/qt_gui/gui_context_menus.h b/src/qt_gui/gui_context_menus.h
index 72affeca7..bdc2aec0c 100644
--- a/src/qt_gui/gui_context_menus.h
+++ b/src/qt_gui/gui_context_menus.h
@@ -52,10 +52,12 @@ public:
// "Open Folder..." submenu
QMenu* openFolderMenu = new QMenu(tr("Open Folder..."), widget);
QAction* openGameFolder = new QAction(tr("Open Game Folder"), widget);
+ QAction* openUpdateFolder = new QAction(tr("Open Update Folder"), widget);
QAction* openSaveDataFolder = new QAction(tr("Open Save Data Folder"), widget);
QAction* openLogFolder = new QAction(tr("Open Log Folder"), widget);
openFolderMenu->addAction(openGameFolder);
+ openFolderMenu->addAction(openUpdateFolder);
openFolderMenu->addAction(openSaveDataFolder);
openFolderMenu->addAction(openLogFolder);
@@ -87,10 +89,12 @@ public:
QMenu* deleteMenu = new QMenu(tr("Delete..."), widget);
QAction* deleteGame = new QAction(tr("Delete Game"), widget);
QAction* deleteUpdate = new QAction(tr("Delete Update"), widget);
+ QAction* deleteSaveData = new QAction(tr("Delete Save Data"), widget);
QAction* deleteDLC = new QAction(tr("Delete DLC"), widget);
deleteMenu->addAction(deleteGame);
deleteMenu->addAction(deleteUpdate);
+ deleteMenu->addAction(deleteSaveData);
deleteMenu->addAction(deleteDLC);
menu.addMenu(deleteMenu);
@@ -122,6 +126,18 @@ public:
QDesktopServices::openUrl(QUrl::fromLocalFile(folderPath));
}
+ if (selected == openUpdateFolder) {
+ QString open_update_path;
+ Common::FS::PathToQString(open_update_path, m_games[itemID].path);
+ open_update_path += "-UPDATE";
+ if (!std::filesystem::exists(Common::FS::PathFromQString(open_update_path))) {
+ QMessageBox::critical(nullptr, tr("Error"),
+ QString(tr("This game has no update folder to open!")));
+ } else {
+ QDesktopServices::openUrl(QUrl::fromLocalFile(open_update_path));
+ }
+ }
+
if (selected == openSaveDataFolder) {
QString userPath;
Common::FS::PathToQString(userPath,
@@ -143,7 +159,7 @@ public:
PSF psf;
std::filesystem::path game_folder_path = m_games[itemID].path;
std::filesystem::path game_update_path = game_folder_path;
- game_update_path += "UPDATE";
+ game_update_path += "-UPDATE";
if (std::filesystem::exists(game_update_path)) {
game_folder_path = game_update_path;
}
@@ -238,6 +254,11 @@ public:
QString trophyPath, gameTrpPath;
Common::FS::PathToQString(trophyPath, m_games[itemID].serial);
Common::FS::PathToQString(gameTrpPath, m_games[itemID].path);
+ auto game_update_path = Common::FS::PathFromQString(gameTrpPath);
+ game_update_path += "-UPDATE";
+ if (std::filesystem::exists(game_update_path)) {
+ Common::FS::PathToQString(gameTrpPath, game_update_path);
+ }
TrophyViewer* trophyViewer = new TrophyViewer(trophyPath, gameTrpPath);
trophyViewer->show();
connect(widget->parent(), &QWidget::destroyed, trophyViewer,
@@ -335,14 +356,18 @@ public:
clipboard->setText(combinedText);
}
- if (selected == deleteGame || selected == deleteUpdate || selected == deleteDLC) {
+ if (selected == deleteGame || selected == deleteUpdate || selected == deleteDLC ||
+ selected == deleteSaveData) {
bool error = false;
- QString folder_path, game_update_path, dlc_path;
+ QString folder_path, game_update_path, dlc_path, save_data_path;
Common::FS::PathToQString(folder_path, m_games[itemID].path);
game_update_path = folder_path + "-UPDATE";
Common::FS::PathToQString(
dlc_path, Config::getAddonInstallDir() /
Common::FS::PathFromQString(folder_path).parent_path().filename());
+ Common::FS::PathToQString(save_data_path,
+ Common::FS::GetUserPath(Common::FS::PathType::UserDir) /
+ "savedata/1" / m_games[itemID].serial);
QString message_type = tr("Game");
if (selected == deleteUpdate) {
@@ -363,6 +388,15 @@ public:
folder_path = dlc_path;
message_type = tr("DLC");
}
+ } else if (selected == deleteSaveData) {
+ if (!std::filesystem::exists(Common::FS::PathFromQString(save_data_path))) {
+ QMessageBox::critical(nullptr, tr("Error"),
+ QString(tr("This game has no save data to delete!")));
+ error = true;
+ } else {
+ folder_path = save_data_path;
+ message_type = tr("Save Data");
+ }
}
if (!error) {
QString gameName = QString::fromStdString(m_games[itemID].name);
@@ -374,7 +408,10 @@ public:
QMessageBox::Yes | QMessageBox::No);
if (reply == QMessageBox::Yes) {
dir.removeRecursively();
- widget->removeRow(itemID);
+ if (selected == deleteGame) {
+ widget->removeRow(itemID);
+ m_games.removeAt(itemID);
+ }
}
}
}
diff --git a/src/qt_gui/install_dir_select.cpp b/src/qt_gui/install_dir_select.cpp
index e0951b123..e90a10ee6 100644
--- a/src/qt_gui/install_dir_select.cpp
+++ b/src/qt_gui/install_dir_select.cpp
@@ -1,6 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2024 shadPS4 Emulator Project
// SPDX-License-Identifier: GPL-2.0-or-later
+#include
#include
#include
#include
@@ -15,10 +16,11 @@
#include "install_dir_select.h"
InstallDirSelect::InstallDirSelect() : selected_dir() {
- selected_dir = Config::getGameInstallDirs().empty() ? "" : Config::getGameInstallDirs().front();
+ auto install_dirs = Config::getGameInstallDirs();
+ selected_dir = install_dirs.empty() ? "" : install_dirs.front();
- if (!Config::getGameInstallDirs().empty() && Config::getGameInstallDirs().size() == 1) {
- reject();
+ if (!install_dirs.empty() && install_dirs.size() == 1) {
+ accept();
}
auto layout = new QVBoxLayout(this);
@@ -53,6 +55,14 @@ QWidget* InstallDirSelect::SetupInstallDirList() {
vlayout->addWidget(m_path_list);
+ auto checkbox = new QCheckBox(tr("Install All Queued to Selected Folder"));
+ connect(checkbox, &QCheckBox::toggled, this, &InstallDirSelect::setUseForAllQueued);
+ vlayout->addWidget(checkbox);
+
+ auto checkbox2 = new QCheckBox(tr("Delete PKG File on Install"));
+ connect(checkbox2, &QCheckBox::toggled, this, &InstallDirSelect::setDeleteFileOnInstall);
+ vlayout->addWidget(checkbox2);
+
group->setLayout(vlayout);
return group;
}
@@ -66,6 +76,14 @@ void InstallDirSelect::setSelectedDirectory(QListWidgetItem* item) {
}
}
+void InstallDirSelect::setUseForAllQueued(bool enabled) {
+ use_for_all_queued = enabled;
+}
+
+void InstallDirSelect::setDeleteFileOnInstall(bool enabled) {
+ delete_file_on_install = enabled;
+}
+
QWidget* InstallDirSelect::SetupDialogActions() {
auto actions = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel);
diff --git a/src/qt_gui/install_dir_select.h b/src/qt_gui/install_dir_select.h
index e3e81575a..e11cbf381 100644
--- a/src/qt_gui/install_dir_select.h
+++ b/src/qt_gui/install_dir_select.h
@@ -22,9 +22,21 @@ public:
return selected_dir;
}
+ bool useForAllQueued() {
+ return use_for_all_queued;
+ }
+
+ bool deleteFileOnInstall() {
+ return delete_file_on_install;
+ }
+
private:
QWidget* SetupInstallDirList();
QWidget* SetupDialogActions();
void setSelectedDirectory(QListWidgetItem* item);
+ void setDeleteFileOnInstall(bool enabled);
+ void setUseForAllQueued(bool enabled);
std::filesystem::path selected_dir;
+ bool delete_file_on_install = false;
+ bool use_for_all_queued = false;
};
diff --git a/src/qt_gui/main_window.cpp b/src/qt_gui/main_window.cpp
index 3ee392613..3678b3a82 100644
--- a/src/qt_gui/main_window.cpp
+++ b/src/qt_gui/main_window.cpp
@@ -725,9 +725,20 @@ void MainWindow::InstallDragDropPkg(std::filesystem::path file, int pkgNum, int
return;
}
auto category = psf.GetString("CATEGORY");
- InstallDirSelect ids;
- ids.exec();
- auto game_install_dir = ids.getSelectedDirectory();
+
+ if (!use_for_all_queued || pkgNum == 1) {
+ InstallDirSelect ids;
+ const auto selected = ids.exec();
+ if (selected == QDialog::Rejected) {
+ return;
+ }
+
+ last_install_dir = ids.getSelectedDirectory();
+ delete_file_on_install = ids.deleteFileOnInstall();
+ use_for_all_queued = ids.useForAllQueued();
+ }
+ std::filesystem::path game_install_dir = last_install_dir;
+
auto game_folder_path = game_install_dir / pkg.GetTitleID();
QString pkgType = QString::fromStdString(pkg.GetPkgFlags());
bool use_game_update = pkgType.contains("PATCH") && Config::getSeparateUpdateEnabled();
@@ -879,8 +890,14 @@ void MainWindow::InstallDragDropPkg(std::filesystem::path file, int pkgNum, int
if (pkgNum == nPkg) {
QString path;
Common::FS::PathToQString(path, game_install_dir);
+ QIcon windowIcon(
+ Common::FS::PathToUTF8String(game_folder_path / "sce_sys/icon0.png")
+ .c_str());
QMessageBox extractMsgBox(this);
extractMsgBox.setWindowTitle(tr("Extraction Finished"));
+ if (!windowIcon.isNull()) {
+ extractMsgBox.setWindowIcon(windowIcon);
+ }
extractMsgBox.setText(
QString(tr("Game successfully installed at %1")).arg(path));
extractMsgBox.addButton(QMessageBox::Ok);
@@ -894,6 +911,9 @@ void MainWindow::InstallDragDropPkg(std::filesystem::path file, int pkgNum, int
});
extractMsgBox.exec();
}
+ if (delete_file_on_install) {
+ std::filesystem::remove(file);
+ }
});
connect(&dialog, &QProgressDialog::canceled, [&]() { futureWatcher.cancel(); });
connect(&futureWatcher, &QFutureWatcher::progressValueChanged, &dialog,
diff --git a/src/qt_gui/main_window.h b/src/qt_gui/main_window.h
index f4163defa..5ac56e44c 100644
--- a/src/qt_gui/main_window.h
+++ b/src/qt_gui/main_window.h
@@ -123,4 +123,8 @@ protected:
}
void resizeEvent(QResizeEvent* event) override;
+
+ std::filesystem::path last_install_dir = "";
+ bool delete_file_on_install = false;
+ bool use_for_all_queued = false;
};
From 9bad66b24d4082240d00849a3d342d4d4a7c52d3 Mon Sep 17 00:00:00 2001
From: squidbus <175574877+squidbus@users.noreply.github.com>
Date: Wed, 29 Jan 2025 01:29:52 -0800
Subject: [PATCH 6/8] hotfix: Raise videodec memory back up to 16MB.
Found a game that needs more, still should be low enough compared to before to fix some games.
---
src/core/libraries/videodec/videodec.cpp | 2 +-
src/core/libraries/videodec/videodec2.cpp | 2 +-
2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/src/core/libraries/videodec/videodec.cpp b/src/core/libraries/videodec/videodec.cpp
index 79001e76f..02ea61509 100644
--- a/src/core/libraries/videodec/videodec.cpp
+++ b/src/core/libraries/videodec/videodec.cpp
@@ -9,7 +9,7 @@
namespace Libraries::Videodec {
-static constexpr u64 kMinimumMemorySize = 8_MB; ///> Fake minimum memory size for querying
+static constexpr u64 kMinimumMemorySize = 16_MB; ///> Fake minimum memory size for querying
int PS4_SYSV_ABI sceVideodecCreateDecoder(const OrbisVideodecConfigInfo* pCfgInfoIn,
const OrbisVideodecResourceInfo* pRsrcInfoIn,
diff --git a/src/core/libraries/videodec/videodec2.cpp b/src/core/libraries/videodec/videodec2.cpp
index be0db4ea3..a7e520b41 100644
--- a/src/core/libraries/videodec/videodec2.cpp
+++ b/src/core/libraries/videodec/videodec2.cpp
@@ -10,7 +10,7 @@
namespace Libraries::Vdec2 {
-static constexpr u64 kMinimumMemorySize = 8_MB; ///> Fake minimum memory size for querying
+static constexpr u64 kMinimumMemorySize = 16_MB; ///> Fake minimum memory size for querying
s32 PS4_SYSV_ABI
sceVideodec2QueryComputeMemoryInfo(OrbisVideodec2ComputeMemoryInfo* computeMemInfo) {
From aa847de043e2e04512d5d01b4d9e40adc4706b0a Mon Sep 17 00:00:00 2001
From: isshininu
Date: Wed, 29 Jan 2025 13:54:08 +0400
Subject: [PATCH 7/8] Update ru_RU translation (#2267)
Several changes in ru_RU translation file.
---
src/qt_gui/translations/ru_RU.ts | 24 ++++++++++++------------
1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/src/qt_gui/translations/ru_RU.ts b/src/qt_gui/translations/ru_RU.ts
index 6423f5ba4..0fddb1e7f 100644
--- a/src/qt_gui/translations/ru_RU.ts
+++ b/src/qt_gui/translations/ru_RU.ts
@@ -126,11 +126,11 @@
Copy All
- Копировать все
+ Копировать всё
Delete...
- Удаление...
+ Удалить...
Delete Game
@@ -158,7 +158,7 @@
Submit a report
- Отправить отчет
+ Отправить отчёт
Shortcut creation
@@ -297,7 +297,7 @@
Elf Viewer
- Elf
+ Исполняемый файл
Game Install Directory
@@ -542,7 +542,7 @@
Fullscreen Mode
- Режим Полного Экран
+ Тип полноэкранного режима
Enable Separate Update Folder
@@ -574,11 +574,11 @@
Trophy Key
- Trophy Key
+ Ключ трофеев
Trophy
- Trophy
+ Трофеи
Logger
@@ -750,7 +750,7 @@
Audio Backend
- Звуковая Подсистема
+ Звуковая подсистема
Save
@@ -826,7 +826,7 @@
disableTrophycheckBox
- Отключить уведомления о трофеях:\nОтключает внутриигровые уведомления о трофеях. Прогресс трофеев по прежнему можно отслеживать в меню Просмотр трофеев (правая кнопка мыши по игре в главном окне).
+ Отключить уведомления о трофеях:\nОтключает внутриигровые уведомления о трофеях. Прогресс трофеев по прежнему можно отслеживать в меню просмотра трофеев (правая кнопка мыши по игре в главном окне).
hideCursorGroupBox
@@ -1192,11 +1192,11 @@
Play Time
- Времени в игре
+ Время в игре
Never Played
- Вы не играли
+ Нет
h
@@ -1361,4 +1361,4 @@
ТБ
-
\ No newline at end of file
+
From 4bb578f9fb73ce77680e26621717db460a93b0e8 Mon Sep 17 00:00:00 2001
From: Missake212
Date: Wed, 29 Jan 2025 11:45:44 +0100
Subject: [PATCH 8/8] updates french translation (#2262)
* updates the french translation
* fix space at the end
* forgot to translate a line
* final changes
* final changes 2
---
src/qt_gui/translations/fr.ts | 66 +++++++++++++++++------------------
1 file changed, 33 insertions(+), 33 deletions(-)
diff --git a/src/qt_gui/translations/fr.ts b/src/qt_gui/translations/fr.ts
index 601ece8b4..0f87b087b 100644
--- a/src/qt_gui/translations/fr.ts
+++ b/src/qt_gui/translations/fr.ts
@@ -146,19 +146,19 @@
Compatibility...
- Compatibility...
+ Compatibilité...
Update database
- Update database
+ Mettre à jour la base de données
View report
- View report
+ Voir rapport
Submit a report
- Submit a report
+ Soumettre un rapport
Shortcut creation
@@ -186,7 +186,7 @@
requiresEnableSeparateUpdateFolder_MSG
- This feature requires the 'Enable Separate Update Folder' config option to work. If you want to use this feature, please enable it.
+ Cette fonctionnalité nécessite l'option 'Dossier séparé pour les mises à jour' pour fonctionner. Si vous voulez utiliser cette fonctionnalité, veuillez l'activer.
This game has no update to delete!
@@ -546,7 +546,7 @@
Enable Separate Update Folder
- Dossier séparé pour les mises à jours
+ Dossier séparé pour les mises à jour
Default tab when opening settings
@@ -574,11 +574,11 @@
Trophy Key
- Trophy Key
+ Clé de trophée
Trophy
- Trophy
+ Trophée
Logger
@@ -586,11 +586,11 @@
Log Type
- Type
+ Type de journal
Log Filter
- Filtre
+ Filtre du journal
Open Log Location
@@ -722,7 +722,7 @@
Disable Trophy Pop-ups
- Disable Trophy Pop-ups
+ Désactiver les notifications de trophées
Play title music
@@ -730,19 +730,19 @@
Update Compatibility Database On Startup
- Update Compatibility Database On Startup
+ Mettre à jour la base de données de compatibilité au lancement
Game Compatibility
- Game Compatibility
+ Compatibilité du jeu
Display Compatibility Data
- Display Compatibility Data
+ Afficher les données de compatibilité
Update Compatibility Database
- Update Compatibility Database
+ Mettre à jour la base de données de compatibilité
Volume
@@ -750,7 +750,7 @@
Audio Backend
- Audio Backend
+ Back-end audio
Save
@@ -786,7 +786,7 @@
separateUpdatesCheckBox
- Dossier séparé pour les mises à jours:\nInstalle les mises à jours des jeux dans un dossier séparé pour une gestion plus facile.
+ Dossier séparé pour les mises à jour:\nInstalle les mises à jours des jeux dans un dossier séparé pour une gestion plus facile.
showSplashCheckBox
@@ -806,7 +806,7 @@
TrophyKey
- Trophy Key:\nKey used to decrypt trophies. Must be obtained from your jailbroken console.\nMust contain only hex characters.
+ Clé de trophées:\nClé utilisée pour décrypter les trophées. Doit être obtenu à partir de votre console jailbreakée.\nDoit contenir des caractères hexadécimaux uniquement.
logTypeGroupBox
@@ -826,7 +826,7 @@
disableTrophycheckBox
- Disable Trophy Pop-ups:\nDisable in-game trophy notifications. Trophy progress can still be tracked using the Trophy Viewer (right-click the game in the main window).
+ Désactiver les notifications de trophées:\nDésactive les notifications de trophées en jeu. La progression des trophées peut toujours être suivie à l'aide de la Visionneuse de trophées (clique droit sur le jeu sur la fenêtre principale).
hideCursorGroupBox
@@ -842,15 +842,15 @@
enableCompatibilityCheckBox
- Display Compatibility Data:\nDisplays game compatibility information in table view. Enable "Update Compatibility On Startup" to get up-to-date information.
+ Afficher les données de compatibilité:\nAffiche les informations de compatibilité des jeux dans une colonne dédiée. Activez "Mettre à jour la compatibilité au démarrage" pour avoir des informations à jour.
checkCompatibilityOnStartupCheckBox
- Update Compatibility On Startup:\nAutomatically update the compatibility database when shadPS4 starts.
+ Mettre à jour la compatibilité au démarrage:\nMettre à jour automatiquement la base de données de compatibilité au démarrage de shadPS4.
updateCompatibilityButton
- Update Compatibility Database:\nImmediately update the compatibility database.
+ Mettre à jour la compatibilité au démarrage:\nMet à jour immédiatement la base de données de compatibilité.
Never
@@ -1093,7 +1093,7 @@
DownloadComplete_MSG
- Patchs téléchargés avec succès ! Tous les patches disponibles pour tous les jeux ont été téléchargés, il n'est pas nécessaire de les télécharger individuellement pour chaque jeu comme c'est le cas pour les Cheats. Si le correctif n'apparaît pas, il se peut qu'il n'existe pas pour le numéro de série et la version spécifiques du jeu.
+ Patchs téléchargés avec succès ! Tous les patches disponibles pour tous les jeux ont été téléchargés, il n'est pas nécessaire de les télécharger individuellement pour chaque jeu comme c'est le cas pour les Cheats. Si le correctif n'apparaît pas, il se peut qu'il n'existe pas pour la série et la version spécifiques du jeu.
Failed to parse JSON data from HTML.
@@ -1113,7 +1113,7 @@
You may need to update your game.
- Vous devrez peut-être mettre à jour votre jeu.
+ Vous devriez peut-être mettre à jour votre jeu.
Incompatibility Notice
@@ -1137,7 +1137,7 @@
Directory does not exist:
- Répertoire n'existe pas:
+ Le répertoire n'existe pas:
Failed to open files.json for reading.
@@ -1149,7 +1149,7 @@
Can't apply cheats before the game is started
- Impossible d'appliquer les Cheats avant que le jeu ne commence.
+ Impossible d'appliquer les cheats avant que le jeu ne soit lancé
@@ -1168,7 +1168,7 @@
Compatibility
- Compatibility
+ Compatibilité
Region
@@ -1212,27 +1212,27 @@
Compatibility is untested
- Compatibility is untested
+ La compatibilité n'a pas été testé
Game does not initialize properly / crashes the emulator
- Game does not initialize properly / crashes the emulator
+ Le jeu ne se lance pas correctement / crash l'émulateur
Game boots, but only displays a blank screen
- Game boots, but only displays a blank screen
+ Le jeu démarre, mais n'affiche qu'un écran noir
Game displays an image but does not go past the menu
- Game displays an image but does not go past the menu
+ Le jeu affiche une image mais ne dépasse pas le menu
Game has game-breaking glitches or unplayable performance
- Game has game-breaking glitches or unplayable performance
+ Le jeu a des problèmes majeurs ou des performances qui le rendent injouable
Game can be completed with playable performance and no major glitches
- Game can be completed with playable performance and no major glitches
+ Le jeu peut être terminé avec des performances acceptables et sans problèmes majeurs