mirror of
https://github.com/reactos/wine.git
synced 2025-01-19 10:13:01 +00:00
imm32: Detach hMsgBuf when sending messages in ImmGenerateMessage.
The issues is that if a message being sent in ImmGenerateMessage gets turned around and sent into an IME that in response to that message calls ImmGenerateMessage, the hMsgBuf still has the old message in it and it ends up getting processed in a loop again and again. Signed-off-by: Aric Stewart <aric@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
f253e6cf93
commit
e7f725ec5f
@ -2893,15 +2893,23 @@ BOOL WINAPI ImmGenerateMessage(HIMC hIMC)
|
||||
if (data->IMC.dwNumMsgBuf > 0)
|
||||
{
|
||||
LPTRANSMSG lpTransMsg;
|
||||
DWORD i;
|
||||
HIMCC hMsgBuf;
|
||||
DWORD i, dwNumMsgBuf;
|
||||
|
||||
lpTransMsg = ImmLockIMCC(data->IMC.hMsgBuf);
|
||||
for (i = 0; i < data->IMC.dwNumMsgBuf; i++)
|
||||
/* We are going to detach our hMsgBuff so that if processing messages
|
||||
generates new messages they go into a new buffer */
|
||||
hMsgBuf = data->IMC.hMsgBuf;
|
||||
dwNumMsgBuf = data->IMC.dwNumMsgBuf;
|
||||
|
||||
data->IMC.hMsgBuf = ImmCreateIMCC(0);
|
||||
data->IMC.dwNumMsgBuf = 0;
|
||||
|
||||
lpTransMsg = ImmLockIMCC(hMsgBuf);
|
||||
for (i = 0; i < dwNumMsgBuf; i++)
|
||||
ImmInternalSendIMEMessage(data, lpTransMsg[i].message, lpTransMsg[i].wParam, lpTransMsg[i].lParam);
|
||||
|
||||
ImmUnlockIMCC(data->IMC.hMsgBuf);
|
||||
|
||||
data->IMC.dwNumMsgBuf = 0;
|
||||
ImmUnlockIMCC(hMsgBuf);
|
||||
ImmDestroyIMCC(hMsgBuf);
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
|
Loading…
x
Reference in New Issue
Block a user