From ca611eaa645af588ed9d95511209b04910d82095 Mon Sep 17 00:00:00 2001 From: tomcw Date: Tue, 19 Oct 2021 21:56:19 +0100 Subject: [PATCH] Mousecard: fix persisting card in slot-4 after a VM restart. (Fixes #993) --- source/CardManager.cpp | 4 ++-- source/CardManager.h | 2 +- source/Configuration/PageInput.cpp | 4 ++-- source/Windows/AppleWin.cpp | 2 +- 4 files changed, 6 insertions(+), 6 deletions(-) diff --git a/source/CardManager.cpp b/source/CardManager.cpp index 789f061c..bbc61447 100644 --- a/source/CardManager.cpp +++ b/source/CardManager.cpp @@ -137,9 +137,9 @@ void CardManager::RemoveInternal(UINT slot) m_slot[slot] = NULL; } -void CardManager::Remove(UINT slot) +void CardManager::Remove(UINT slot, bool updateRegistry/*=true*/) { - Insert(slot, CT_Empty); + Insert(slot, CT_Empty, updateRegistry); } void CardManager::InsertAuxInternal(SS_CARDTYPE type) diff --git a/source/CardManager.h b/source/CardManager.h index 3c808975..f1ad191c 100644 --- a/source/CardManager.h +++ b/source/CardManager.h @@ -29,7 +29,7 @@ public: } void Insert(UINT slot, SS_CARDTYPE type, bool updateRegistry = true); - void Remove(UINT slot); + void Remove(UINT slot, bool updateRegistry = true); SS_CARDTYPE QuerySlot(UINT slot) { _ASSERT(slotQueryType(); } Card& GetRef(UINT slot) { diff --git a/source/Configuration/PageInput.cpp b/source/Configuration/PageInput.cpp index ea286e05..8417b147 100644 --- a/source/Configuration/PageInput.cpp +++ b/source/Configuration/PageInput.cpp @@ -292,7 +292,7 @@ void CPageInput::DlgOK(HWND hWnd) UINT uNewJoyType1 = SendDlgItemMessage(hWnd, IDC_JOYSTICK1, CB_GETCURSEL, 0, 0); if (uNewJoyType1 >= J1C_MAX) uNewJoyType1 = 0; // GH#434 - const bool bIsSlot4Mouse = m_PropertySheetHelper.GetConfigNew().m_Slot[4] == CT_MouseInterface; + const bool bIsSlot4Mouse = m_PropertySheetHelper.GetConfigNew().m_Slot[SLOT4] == CT_MouseInterface; if (JoySetEmulationType(hWnd, m_nJoy0ChoiceTranlationTbl[uNewJoyType0], JN_JOYSTICK0, bIsSlot4Mouse)) { @@ -381,7 +381,7 @@ void CPageInput::InitJoystickChoices(HWND hWnd, int nJoyNum, int nIdcValue) pszMem += strlen(ppszJoyChoices[nJC_JOYSTICK])+1; pnJoyTranslationTbl[nIdx++] = nJC_JOYSTICK; - const bool bIsSlot4Mouse = m_PropertySheetHelper.GetConfigNew().m_Slot[4] == CT_MouseInterface; + const bool bIsSlot4Mouse = m_PropertySheetHelper.GetConfigNew().m_Slot[SLOT4] == CT_MouseInterface; // Now exclude: // . the other Joystick type (if it exists) from this new list diff --git a/source/Windows/AppleWin.cpp b/source/Windows/AppleWin.cpp index 43b57c73..cc068cd6 100644 --- a/source/Windows/AppleWin.cpp +++ b/source/Windows/AppleWin.cpp @@ -552,7 +552,7 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) if (pMouseCard) { // dtor removes event from g_SynchronousEventMgr - do before g_SynchronousEventMgr.Reset() - GetCardMgr().Remove( pMouseCard->GetSlot() ); + GetCardMgr().Remove( pMouseCard->GetSlot(), false ); LogFileOutput("Main: CMouseInterface::dtor\n"); }