From 58d66e3e9710efda115b3bb0e592e6b357dfd91a Mon Sep 17 00:00:00 2001 From: WerWolv Date: Thu, 26 Dec 2024 14:01:35 +0100 Subject: [PATCH] fix: Added migration routine to fix shortcuts --- .../source/content/settings_entries.cpp | 25 ++++++++++++++++--- 1 file changed, 22 insertions(+), 3 deletions(-) diff --git a/plugins/builtin/source/content/settings_entries.cpp b/plugins/builtin/source/content/settings_entries.cpp index fd7567a53..b978f77c0 100644 --- a/plugins/builtin/source/content/settings_entries.cpp +++ b/plugins/builtin/source/content/settings_entries.cpp @@ -285,9 +285,7 @@ namespace hex::plugin::builtin { ImGui::BeginDisabled(m_drawShortcut.matches(m_defaultShortcut)); if (ImGuiExt::IconButton(ICON_VS_X, ImGui::GetStyleColorVec4(ImGuiCol_Text))) { - m_hasDuplicate = !ShortcutManager::updateShortcut(m_shortcut, m_defaultShortcut, m_view); - - m_drawShortcut = m_defaultShortcut; + this->reset(); if (!m_hasDuplicate) { m_shortcut = m_defaultShortcut; settingChanged = true; @@ -356,6 +354,12 @@ namespace hex::plugin::builtin { return keys; } + void reset() { + m_hasDuplicate = !ShortcutManager::updateShortcut(m_shortcut, m_defaultShortcut, m_view); + + m_drawShortcut = m_defaultShortcut; + } + private: bool detectShortcut() { if (const auto &shortcut = ShortcutManager::getPreviousShortcut(); shortcut.has_value()) { @@ -971,6 +975,21 @@ namespace hex::plugin::builtin { ContentRegistry::Settings::add("hex.builtin.setting.toolbar", "", "hex.builtin.setting.toolbar.icons"); } + ImHexApi::System::addMigrationRoutine("v1.36.1", [] { + log::warn("Resetting shortcut key settings for them to work with this version of ImHex"); + + for (const auto &category : ContentRegistry::Settings::impl::getSettings()) { + for (const auto &subcategory : category.subCategories) { + for (const auto &entry : subcategory.entries) { + if (auto keybindingWidget = dynamic_cast(entry.widget.get())) { + keybindingWidget->reset(); + } + } + } + } + + ContentRegistry::Settings::impl::store(); + }); } static void loadLayoutSettings() {