From 87621e9337b5aebe59757fae2e1e0ab9f04cc947 Mon Sep 17 00:00:00 2001 From: WerWolv Date: Sat, 20 May 2023 21:23:15 +0200 Subject: [PATCH] impr: Disable some `Import...` options when the provider isn't writable --- plugins/builtin/source/content/main_menu_items.cpp | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/plugins/builtin/source/content/main_menu_items.cpp b/plugins/builtin/source/content/main_menu_items.cpp index 86e5491d7..22690f33a 100644 --- a/plugins/builtin/source/content/main_menu_items.cpp +++ b/plugins/builtin/source/content/main_menu_items.cpp @@ -35,6 +35,10 @@ namespace hex::plugin::builtin { return noRunningTasks() && ImHexApi::Provider::isValid(); } + bool noRunningTaskAndWritableProvider() { + return noRunningTasks() && ImHexApi::Provider::isValid() && ImHexApi::Provider::get()->isWritable(); + } + } namespace { @@ -340,7 +344,7 @@ namespace hex::plugin::builtin { ContentRegistry::Interface::addMenuItem({ "hex.builtin.menu.file", "hex.builtin.menu.file.import", "hex.builtin.menu.file.import.base64" }, 2050, Shortcut::None, importBase64, - noRunningTasks); + noRunningTaskAndWritableProvider); ContentRegistry::Interface::addMenuItemSeparator({ "hex.builtin.menu.file", "hex.builtin.menu.file.import" }, 2100); @@ -348,19 +352,19 @@ namespace hex::plugin::builtin { ContentRegistry::Interface::addMenuItem({ "hex.builtin.menu.file", "hex.builtin.menu.file.import", "hex.builtin.menu.file.import.ips"}, 2150, Shortcut::None, importIPSPatch, - ImHexApi::Provider::isValid); + noRunningTaskAndWritableProvider); /* IPS32 */ ContentRegistry::Interface::addMenuItem({ "hex.builtin.menu.file", "hex.builtin.menu.file.import", "hex.builtin.menu.file.import.ips32"}, 2200, Shortcut::None, importIPS32Patch, - ImHexApi::Provider::isValid); + noRunningTaskAndWritableProvider); /* Modified File */ ContentRegistry::Interface::addMenuItem({ "hex.builtin.menu.file", "hex.builtin.menu.file.import", "hex.builtin.menu.file.import.modified_file" }, 2300, Shortcut::None, importModifiedFile, - [&] { return noRunningTaskAndValidProvider() && ImHexApi::Provider::get()->isWritable(); }); + noRunningTaskAndWritableProvider); } /* Export */