summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMorph <39850852+Morph1984@users.noreply.github.com>2020-07-17 12:06:56 +0200
committerMorph <39850852+Morph1984@users.noreply.github.com>2020-07-29 12:50:30 +0200
commitef02370816924156b6c3c3fd70e7e2595be19216 (patch)
tree591b4bea9fc7c79946f187cb3f047e06f8d7f8c9
parentmain: Connect game list remove signals to removal functions (diff)
downloadyuzu-ef02370816924156b6c3c3fd70e7e2595be19216.tar
yuzu-ef02370816924156b6c3c3fd70e7e2595be19216.tar.gz
yuzu-ef02370816924156b6c3c3fd70e7e2595be19216.tar.bz2
yuzu-ef02370816924156b6c3c3fd70e7e2595be19216.tar.lz
yuzu-ef02370816924156b6c3c3fd70e7e2595be19216.tar.xz
yuzu-ef02370816924156b6c3c3fd70e7e2595be19216.tar.zst
yuzu-ef02370816924156b6c3c3fd70e7e2595be19216.zip
-rw-r--r--src/yuzu/main.cpp239
-rw-r--r--src/yuzu/main.h5
2 files changed, 131 insertions, 113 deletions
diff --git a/src/yuzu/main.cpp b/src/yuzu/main.cpp
index e94785101..49c10459b 100644
--- a/src/yuzu/main.cpp
+++ b/src/yuzu/main.cpp
@@ -1396,19 +1396,18 @@ static bool RomFSRawCopy(QProgressDialog& dialog, const FileSys::VirtualDir& src
}
void GMainWindow::OnGameListRemoveInstalledEntry(u64 program_id, InstalledEntryType type) {
- QString entry_type;
-
- switch (type) {
- case InstalledEntryType::Game:
- entry_type = tr("Contents");
- break;
- case InstalledEntryType::Update:
- entry_type = tr("Update");
- break;
- case InstalledEntryType::AddOnContent:
- entry_type = tr("DLC");
- break;
- }
+ const QString entry_type = [this, type] {
+ switch (type) {
+ case InstalledEntryType::Game:
+ return tr("Contents");
+ case InstalledEntryType::Update:
+ return tr("Update");
+ case InstalledEntryType::AddOnContent:
+ return tr("DLC");
+ default:
+ return QString{};
+ }
+ }();
if (QMessageBox::question(
this, tr("Remove Entry"), tr("Remove Installed Game %1?").arg(entry_type),
@@ -1416,68 +1415,19 @@ void GMainWindow::OnGameListRemoveInstalledEntry(u64 program_id, InstalledEntryT
return;
}
- bool res;
-
switch (type) {
case InstalledEntryType::Game:
- res = Core::System::GetInstance()
- .GetFileSystemController()
- .GetUserNANDContents()
- ->RemoveExistingEntry(program_id);
-
- if (res) {
- QMessageBox::information(this, tr("Successfully Removed"),
- tr("Successfully removed the installed base game."));
- } else {
- QMessageBox::warning(
- this, tr("Error Removing %1").arg(entry_type),
- tr("The base game is not installed in the NAND and cannot be removed."));
- }
+ RemoveBaseContent(program_id, entry_type);
[[fallthrough]];
case InstalledEntryType::Update:
- res = Core::System::GetInstance()
- .GetFileSystemController()
- .GetUserNANDContents()
- ->RemoveExistingEntry(program_id | 0x800);
-
- if (res) {
- QMessageBox::information(this, tr("Successfully Removed"),
- tr("Successfully removed the installed update."));
- } else {
- QMessageBox::warning(this, tr("Error Removing %1").arg(entry_type),
- tr("There is no update installed for this title."));
- }
-
+ RemoveUpdateContent(program_id, entry_type);
if (type == InstalledEntryType::Game) {
[[fallthrough]];
} else {
break;
}
case InstalledEntryType::AddOnContent:
- u32 count{};
- const auto dlc_entries = Core::System::GetInstance().GetContentProvider().ListEntriesFilter(
- FileSys::TitleType::AOC, FileSys::ContentRecordType::Data);
-
- for (const auto& entry : dlc_entries) {
- if ((entry.title_id & DLC_BASE_TITLE_ID_MASK) == program_id) {
- res = Core::System::GetInstance()
- .GetFileSystemController()
- .GetUserNANDContents()
- ->RemoveExistingEntry(entry.title_id);
- if (res) {
- ++count;
- }
- }
- }
-
- if (count == 0) {
- QMessageBox::warning(this, tr("Error Removing %1").arg(entry_type),
- tr("There are no DLC installed for this title."));
- break;
- }
-
- QMessageBox::information(this, tr("Successfully Removed"),
- tr("Successfully removed %1 installed DLC.").arg(count));
+ RemoveAddOnContent(program_id, entry_type);
break;
}
game_list->PopulateAsync(UISettings::values.game_dirs);
@@ -1485,70 +1435,133 @@ void GMainWindow::OnGameListRemoveInstalledEntry(u64 program_id, InstalledEntryT
"game_list");
}
+void GMainWindow::RemoveBaseContent(u64 program_id, const QString& entry_type) {
+ const auto res = Core::System::GetInstance()
+ .GetFileSystemController()
+ .GetUserNANDContents()
+ ->RemoveExistingEntry(program_id);
+
+ if (res) {
+ QMessageBox::information(this, tr("Successfully Removed"),
+ tr("Successfully removed the installed base game."));
+ } else {
+ QMessageBox::warning(
+ this, tr("Error Removing %1").arg(entry_type),
+ tr("The base game is not installed in the NAND and cannot be removed."));
+ }
+}
+
+void GMainWindow::RemoveUpdateContent(u64 program_id, const QString& entry_type) {
+ const auto res = Core::System::GetInstance()
+ .GetFileSystemController()
+ .GetUserNANDContents()
+ ->RemoveExistingEntry(program_id | 0x800);
+
+ if (res) {
+ QMessageBox::information(this, tr("Successfully Removed"),
+ tr("Successfully removed the installed update."));
+ } else {
+ QMessageBox::warning(this, tr("Error Removing %1").arg(entry_type),
+ tr("There is no update installed for this title."));
+ }
+}
+
+void GMainWindow::RemoveAddOnContent(u64 program_id, const QString& entry_type) {
+ u32 count{};
+ const auto dlc_entries = Core::System::GetInstance().GetContentProvider().ListEntriesFilter(
+ FileSys::TitleType::AOC, FileSys::ContentRecordType::Data);
+
+ for (const auto& entry : dlc_entries) {
+ if ((entry.title_id & DLC_BASE_TITLE_ID_MASK) == program_id) {
+ const auto res = Core::System::GetInstance()
+ .GetFileSystemController()
+ .GetUserNANDContents()
+ ->RemoveExistingEntry(entry.title_id);
+ if (res) {
+ ++count;
+ }
+ }
+ }
+
+ if (count == 0) {
+ QMessageBox::warning(this, tr("Error Removing %1").arg(entry_type),
+ tr("There are no DLC installed for this title."));
+ return;
+ }
+
+ QMessageBox::information(this, tr("Successfully Removed"),
+ tr("Successfully removed %1 installed DLC.").arg(count));
+}
+
void GMainWindow::OnGameListRemoveFile(u64 program_id, GameListRemoveTarget target) {
- QString question;
+ const QString question = [this, target] {
+ switch (target) {
+ case GameListRemoveTarget::ShaderCache:
+ return tr("Delete Transferable Shader Cache?");
+ case GameListRemoveTarget::CustomConfiguration:
+ return tr("Remove Custom Game Configuration?");
+ default:
+ return QString{};
+ }
+ }();
+
+ if (QMessageBox::question(this, tr("Remove File"), question, QMessageBox::Yes | QMessageBox::No,
+ QMessageBox::No) != QMessageBox::Yes) {
+ return;
+ }
switch (target) {
case GameListRemoveTarget::ShaderCache:
- question = tr("Delete Transferable Shader Cache?");
+ RemoveTransferableShaderCache(program_id);
break;
case GameListRemoveTarget::CustomConfiguration:
- question = tr("Remove Custom Game Configuration?");
+ RemoveCustomConfiguration(program_id);
break;
}
+}
- if (QMessageBox::question(this, tr("Remove File"), question, QMessageBox::Yes | QMessageBox::No,
- QMessageBox::No) != QMessageBox::Yes) {
+void GMainWindow::RemoveTransferableShaderCache(u64 program_id) {
+ const QString shader_dir =
+ QString::fromStdString(FileUtil::GetUserPath(FileUtil::UserPath::ShaderDir));
+ const QString transferable_shader_cache_folder_path =
+ shader_dir + QStringLiteral("opengl") + QDir::separator() + QStringLiteral("transferable");
+ const QString transferable_shader_cache_file_path =
+ transferable_shader_cache_folder_path + QDir::separator() +
+ QString::fromStdString(fmt::format("{:016X}.bin", program_id));
+
+ if (!QFile::exists(transferable_shader_cache_file_path)) {
+ QMessageBox::warning(this, tr("Error Removing Transferable Shader Cache"),
+ tr("A shader cache for this title does not exist."));
return;
}
- switch (target) {
- case GameListRemoveTarget::ShaderCache: {
- const QString shader_dir =
- QString::fromStdString(FileUtil::GetUserPath(FileUtil::UserPath::ShaderDir));
- const QString transferable_shader_cache_folder_path =
- shader_dir + QStringLiteral("opengl") + QDir::separator() +
- QStringLiteral("transferable");
- const QString transferable_shader_cache_file_path =
- transferable_shader_cache_folder_path + QDir::separator() +
- QString::fromStdString(fmt::format("{:016X}.bin", program_id));
-
- if (!QFile::exists(transferable_shader_cache_file_path)) {
- QMessageBox::warning(this, tr("Error Removing Transferable Shader Cache"),
- tr("A shader cache for this title does not exist."));
- break;
- }
-
- if (QFile::remove(transferable_shader_cache_file_path)) {
- QMessageBox::information(this, tr("Successfully Removed"),
- tr("Successfully removed the transferable shader cache."));
- } else {
- QMessageBox::warning(this, tr("Error Removing Transferable Shader Cache"),
- tr("Failed to remove the transferable shader cache."));
- }
- break;
+ if (QFile::remove(transferable_shader_cache_file_path)) {
+ QMessageBox::information(this, tr("Successfully Removed"),
+ tr("Successfully removed the transferable shader cache."));
+ } else {
+ QMessageBox::warning(this, tr("Error Removing Transferable Shader Cache"),
+ tr("Failed to remove the transferable shader cache."));
}
- case GameListRemoveTarget::CustomConfiguration: {
- const QString config_dir =
- QString::fromStdString(FileUtil::GetUserPath(FileUtil::UserPath::ConfigDir));
- const QString custom_config_file_path =
- config_dir + QString::fromStdString(fmt::format("{:016X}.ini", program_id));
+}
- if (!QFile::exists(custom_config_file_path)) {
- QMessageBox::warning(this, tr("Error Removing Custom Configuration"),
- tr("A custom configuration for this title does not exist."));
- break;
- }
+void GMainWindow::RemoveCustomConfiguration(u64 program_id) {
+ const QString config_dir =
+ QString::fromStdString(FileUtil::GetUserPath(FileUtil::UserPath::ConfigDir));
+ const QString custom_config_file_path =
+ config_dir + QString::fromStdString(fmt::format("{:016X}.ini", program_id));
- if (QFile::remove(custom_config_file_path)) {
- QMessageBox::information(this, tr("Successfully Removed"),
- tr("Successfully removed the custom game configuration."));
- } else {
- QMessageBox::warning(this, tr("Error Removing Custom Configuration"),
- tr("Failed to remove the custom game configuration."));
- }
- break;
+ if (!QFile::exists(custom_config_file_path)) {
+ QMessageBox::warning(this, tr("Error Removing Custom Configuration"),
+ tr("A custom configuration for this title does not exist."));
+ return;
}
+
+ if (QFile::remove(custom_config_file_path)) {
+ QMessageBox::information(this, tr("Successfully Removed"),
+ tr("Successfully removed the custom game configuration."));
+ } else {
+ QMessageBox::warning(this, tr("Error Removing Custom Configuration"),
+ tr("Failed to remove the custom game configuration."));
}
}
diff --git a/src/yuzu/main.h b/src/yuzu/main.h
index bbdf7ae51..73a44a3bf 100644
--- a/src/yuzu/main.h
+++ b/src/yuzu/main.h
@@ -233,6 +233,11 @@ private slots:
void OnLanguageChanged(const QString& locale);
private:
+ void RemoveBaseContent(u64 program_id, const QString& entry_type);
+ void RemoveUpdateContent(u64 program_id, const QString& entry_type);
+ void RemoveAddOnContent(u64 program_id, const QString& entry_type);
+ void RemoveTransferableShaderCache(u64 program_id);
+ void RemoveCustomConfiguration(u64 program_id);
std::optional<u64> SelectRomFSDumpTarget(const FileSys::ContentProvider&, u64 program_id);
InstallResult InstallNSPXCI(const QString& filename);
InstallResult InstallNCA(const QString& filename);