X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/9af42efda6c78093872a67180d43d5eeba261fee..6bc176b4ab7ed858d558546bcdd0a05229b64a3b:/src/msw/evtloop.cpp?ds=sidebyside diff --git a/src/msw/evtloop.cpp b/src/msw/evtloop.cpp index 7c1ab86c19..d09faae69f 100644 --- a/src/msw/evtloop.cpp +++ b/src/msw/evtloop.cpp @@ -111,22 +111,33 @@ int wxMSWEventLoopBase::GetNextMessageTimeout(WXMSG *msg, unsigned long timeout) { // we use this function just in order to not block longer than the // given timeout, so we don't pass any handles to it at all - if ( ::MsgWaitForMultipleObjects - ( - 0, NULL, - FALSE, - timeout, - QS_ALLINPUT - ) == WAIT_TIMEOUT ) + DWORD rc = ::MsgWaitForMultipleObjects + ( + 0, NULL, + FALSE, + timeout, + QS_ALLINPUT + ); + + switch ( rc ) { - return -1; - } - - if ( !::PeekMessage(msg, 0, 0, 0, PM_REMOVE) ) - { - wxFAIL_MSG( _T("PeekMessage() should have succeeded") ); - - return -1; + default: + wxLogDebug("unexpected MsgWaitForMultipleObjects() return " + "value %lu", rc); + // fall through + + case WAIT_TIMEOUT: + return -1; + + case WAIT_OBJECT_0: + if ( !::PeekMessage(msg, 0, 0, 0, PM_REMOVE) ) + { + // somehow it may happen that MsgWaitForMultipleObjects() + // returns true but there are no messages -- just treat it + // the same as timeout then + return -1; + } + break; } } @@ -352,12 +363,6 @@ void wxGUIEventLoop::WakeUp() #if wxUSE_CONSOLE_EVENTLOOP -void wxConsoleEventLoop::OnNextIteration() -{ - if ( wxTheApp ) - wxTheApp->ProcessPendingEvents(); -} - void wxConsoleEventLoop::WakeUp() { #if wxUSE_THREADS