From ddb82a690ba030e5fa0528231b58947bbeac66f4 Mon Sep 17 00:00:00 2001 From: Vinicius Rangel Date: Thu, 26 Sep 2024 01:56:38 -0300 Subject: [PATCH] Save lib fixes III (#1069) * SaveDataMemory: increase memory if needed * SaveDataDialog: fix intention to hide save details --- .../save_data/dialog/savedatadialog_ui.cpp | 81 ++++++++++--------- src/core/libraries/save_data/save_memory.cpp | 8 +- 2 files changed, 43 insertions(+), 46 deletions(-) diff --git a/src/core/libraries/save_data/dialog/savedatadialog_ui.cpp b/src/core/libraries/save_data/dialog/savedatadialog_ui.cpp index 793b4dd38..c4bf84258 100644 --- a/src/core/libraries/save_data/dialog/savedatadialog_ui.cpp +++ b/src/core/libraries/save_data/dialog/savedatadialog_ui.cpp @@ -79,55 +79,58 @@ SaveDialogState::SaveDialogState(const OrbisSaveDataDialogParam& param) { this->title_id = item->titleId->data.to_string(); } - for (u32 i = 0; i < item->dirNameNum; i++) { - const auto dir_name = item->dirName[i].data.to_view(); + if (item->dirName != nullptr) { + for (u32 i = 0; i < item->dirNameNum; i++) { + const auto dir_name = item->dirName[i].data.to_view(); - if (dir_name.empty()) { - continue; - } + if (dir_name.empty()) { + continue; + } - auto dir_path = SaveInstance::MakeDirSavePath(user_id, title_id, dir_name); + auto dir_path = SaveInstance::MakeDirSavePath(user_id, title_id, dir_name); - auto param_sfo_path = dir_path / "sce_sys" / "param.sfo"; - if (!std::filesystem::exists(param_sfo_path)) { - continue; - } + auto param_sfo_path = dir_path / "sce_sys" / "param.sfo"; + if (!std::filesystem::exists(param_sfo_path)) { + continue; + } - PSF param_sfo; - param_sfo.Open(param_sfo_path); + PSF param_sfo; + param_sfo.Open(param_sfo_path); - auto last_write = param_sfo.GetLastWrite(); + auto last_write = param_sfo.GetLastWrite(); #ifdef _WIN32 - auto utc_time = std::chrono::file_clock::to_utc(last_write); + auto utc_time = std::chrono::file_clock::to_utc(last_write); #else - auto utc_time = std::chrono::file_clock::to_sys(last_write); + auto utc_time = std::chrono::file_clock::to_sys(last_write); #endif - std::string date_str = fmt::format("{:%d %b, %Y %R}", utc_time); + std::string date_str = fmt::format("{:%d %b, %Y %R}", utc_time); - size_t size = Common::FS::GetDirectorySize(dir_path); - std::string size_str = SpaceSizeToString(size); + size_t size = Common::FS::GetDirectorySize(dir_path); + std::string size_str = SpaceSizeToString(size); - auto icon_path = dir_path / "sce_sys" / "icon0.png"; - RefCountedTexture icon; - if (std::filesystem::exists(icon_path)) { - icon = RefCountedTexture::DecodePngFile(icon_path); + auto icon_path = dir_path / "sce_sys" / "icon0.png"; + RefCountedTexture icon; + if (std::filesystem::exists(icon_path)) { + icon = RefCountedTexture::DecodePngFile(icon_path); + } + + bool is_corrupted = std::filesystem::exists(dir_path / "sce_sys" / "corrupted"); + + this->save_list.emplace_back(Item{ + .dir_name = std::string{dir_name}, + .icon = icon, + + .title = + std::string{param_sfo.GetString(SaveParams::MAINTITLE).value_or("Unknown")}, + .subtitle = std::string{param_sfo.GetString(SaveParams::SUBTITLE).value_or("")}, + .details = std::string{param_sfo.GetString(SaveParams::DETAIL).value_or("")}, + .date = date_str, + .size = size_str, + .last_write = param_sfo.GetLastWrite(), + .pfo = param_sfo, + .is_corrupted = is_corrupted, + }); } - - bool is_corrupted = std::filesystem::exists(dir_path / "sce_sys" / "corrupted"); - - this->save_list.emplace_back(Item{ - .dir_name = std::string{dir_name}, - .icon = icon, - - .title = std::string{param_sfo.GetString(SaveParams::MAINTITLE).value_or("Unknown")}, - .subtitle = std::string{param_sfo.GetString(SaveParams::SUBTITLE).value_or("")}, - .details = std::string{param_sfo.GetString(SaveParams::DETAIL).value_or("")}, - .date = date_str, - .size = size_str, - .last_write = param_sfo.GetLastWrite(), - .pfo = param_sfo, - .is_corrupted = is_corrupted, - }); } if (type == DialogType::SAVE && item->newItem != nullptr) { @@ -299,7 +302,7 @@ SaveDialogState::ProgressBarState::ProgressBarState(const SaveDialogState& state } else { switch (bar.sysMsgType) { case ProgressSystemMessageType::INVALID: - this->msg = "INVALID"; + this->msg = ""; break; case ProgressSystemMessageType::PROGRESS: switch (state.type) { diff --git a/src/core/libraries/save_data/save_memory.cpp b/src/core/libraries/save_data/save_memory.cpp index 44f5311e1..d7ef58039 100644 --- a/src/core/libraries/save_data/save_memory.cpp +++ b/src/core/libraries/save_data/save_memory.cpp @@ -268,9 +268,6 @@ bool TriggerSave() { void ReadMemory(void* buf, size_t buf_size, int64_t offset) { std::scoped_lock lk{g_saving_memory_mutex}; - if (offset > g_save_memory.size()) { - UNREACHABLE_MSG("ReadMemory out of bounds"); - } if (offset + buf_size > g_save_memory.size()) { UNREACHABLE_MSG("ReadMemory out of bounds"); } @@ -279,11 +276,8 @@ void ReadMemory(void* buf, size_t buf_size, int64_t offset) { void WriteMemory(void* buf, size_t buf_size, int64_t offset) { std::scoped_lock lk{g_saving_memory_mutex}; - if (offset > g_save_memory.size()) { - UNREACHABLE_MSG("WriteMemory out of bounds"); - } if (offset + buf_size > g_save_memory.size()) { - UNREACHABLE_MSG("WriteMemory out of bounds"); + g_save_memory.resize(offset + buf_size); } std::memcpy(g_save_memory.data() + offset, buf, buf_size); g_memory_dirty = true;