Ensure that the WM_ENTERIDLE message is not sent if the wake-up event
for the MSG_InternalGetMessage() call is a WM_TIMER.
diff --git a/windows/message.c b/windows/message.c
index facfc19..9ceb0b0 100644
--- a/windows/message.c
+++ b/windows/message.c
@@ -1182,7 +1182,7 @@
* 'code' is the message filter value (MSGF_??? codes).
*/
BOOL MSG_InternalGetMessage( MSG *msg, HWND hwnd, HWND hwndOwner,
- WPARAM code, WORD flags, BOOL sendIdle )
+ WPARAM code, WORD flags, BOOL sendIdle, BOOL* idleSent )
{
for (;;)
{
@@ -1192,8 +1192,13 @@
{
/* No message present -> send ENTERIDLE and wait */
if (IsWindow(hwndOwner))
+ {
SendMessageA( hwndOwner, WM_ENTERIDLE,
code, (LPARAM)hwnd );
+
+ if (idleSent!=NULL)
+ *idleSent=TRUE;
+ }
MSG_PeekMessage( msg, 0, 0, 0, flags, FALSE );
}
}