summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMorph <39850852+Morph1984@users.noreply.github.com>2020-07-20 05:52:06 +0200
committerMorph <39850852+Morph1984@users.noreply.github.com>2020-08-05 03:14:20 +0200
commitcf946312ca5aad399e39492bbb130bb1ff322cd1 (patch)
tree60527e682845ac86c746fb86a79a2e7e90ff6427 /src
parentmain: Fix Open Save/Mod Locations for installed titles (diff)
downloadyuzu-cf946312ca5aad399e39492bbb130bb1ff322cd1.tar
yuzu-cf946312ca5aad399e39492bbb130bb1ff322cd1.tar.gz
yuzu-cf946312ca5aad399e39492bbb130bb1ff322cd1.tar.bz2
yuzu-cf946312ca5aad399e39492bbb130bb1ff322cd1.tar.lz
yuzu-cf946312ca5aad399e39492bbb130bb1ff322cd1.tar.xz
yuzu-cf946312ca5aad399e39492bbb130bb1ff322cd1.tar.zst
yuzu-cf946312ca5aad399e39492bbb130bb1ff322cd1.zip
Diffstat (limited to '')
-rw-r--r--src/yuzu/main.cpp23
1 files changed, 17 insertions, 6 deletions
diff --git a/src/yuzu/main.cpp b/src/yuzu/main.cpp
index f711a337f..e2b6462bb 100644
--- a/src/yuzu/main.cpp
+++ b/src/yuzu/main.cpp
@@ -1244,13 +1244,24 @@ void GMainWindow::OnGameListOpenFolder(u64 program_id, GameListOpenTarget target
std::string path;
QString open_target;
- FileSys::PatchManager pm{program_id};
- const auto control = pm.GetControlMetadata();
- const auto v_file = Core::GetGameFileFromPath(vfs, game_path);
- const auto loader = Loader::GetLoader(v_file);
+ const auto [user_save_size, device_save_size] = [this, &program_id, &game_path] {
+ FileSys::PatchManager pm{program_id};
+ const auto control = pm.GetControlMetadata().first;
+ if (control != nullptr) {
+ return std::make_pair(control->GetDefaultNormalSaveSize(),
+ control->GetDeviceSaveDataSize());
+ } else {
+ const auto file = Core::GetGameFileFromPath(vfs, game_path);
+ const auto loader = Loader::GetLoader(file);
+
+ FileSys::NACP nacp{};
+ loader->ReadControlData(nacp);
+ return std::make_pair(nacp.GetDefaultNormalSaveSize(), nacp.GetDeviceSaveDataSize());
+ }
+ }();
- const bool has_user_save{control.first->GetDefaultNormalSaveSize() > 0};
- const bool has_device_save{control.first->GetDeviceSaveDataSize() > 0};
+ const bool has_user_save{user_save_size > 0};
+ const bool has_device_save{device_save_size > 0};
ASSERT_MSG(has_user_save != has_device_save, "Game uses both user and device savedata?");