Don't send idle events while an assertion dialog is showing.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@22800 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
David Elliott 2003-08-13 15:25:34 +00:00
parent 5bb31e3561
commit b93d8cc460
2 changed files with 41 additions and 9 deletions

View File

@ -61,6 +61,16 @@ public:
virtual bool OnInit();
virtual bool OnInitGui();
#ifdef __WXDEBUG__
virtual void OnAssert(const wxChar *file, int line, const wxChar *cond, const wxChar *msg);
bool IsInAssert() const { return m_isInAssert; }
#endif // __WXDEBUG__
private:
#ifdef __WXDEBUG__
bool m_isInAssert;
#endif // __WXDEBUG__
};
#endif // _WX_COCOA_APP_H_

View File

@ -64,18 +64,27 @@ wxPoseAsInitializer *wxPoseAsInitializer::sm_first = NULL;
{
wxASSERT(wxTheApp);
wxLogDebug("doIdle called");
NSRunLoop *rl = [NSRunLoop currentRunLoop];
// runMode: beforeDate returns YES if something was done
while(wxTheApp->ProcessIdle()) // FIXME: AND NO EVENTS ARE PENDING
#ifdef __WXDEBUG__
if(wxTheApp->IsInAssert())
{
wxLogDebug("Looping for idle events");
#if 1
if( [rl runMode:[rl currentMode] beforeDate:[NSDate distantPast]])
wxLogDebug("Idle events ignored durring assertion dialog");
}
else
#endif
{
NSRunLoop *rl = [NSRunLoop currentRunLoop];
// runMode: beforeDate returns YES if something was done
while(wxTheApp->ProcessIdle()) // FIXME: AND NO EVENTS ARE PENDING
{
wxLogDebug("Found actual work to do");
break;
wxLogDebug("Looping for idle events");
#if 1
if( [rl runMode:[rl currentMode] beforeDate:[NSDate distantPast]])
{
wxLogDebug("Found actual work to do");
break;
}
#endif
}
#endif
}
wxLogDebug("Idle processing complete, requesting next idle event");
// Add ourself back into the run loop (on next event) if necessary
@ -175,6 +184,10 @@ wxApp::wxApp()
#if WXWIN_COMPATIBILITY_2_2
m_wantDebugOutput = TRUE;
#endif
#ifdef __WXDEBUG__
m_isInAssert = FALSE;
#endif // __WXDEBUG__
argc = 0;
argv = NULL;
@ -309,3 +322,12 @@ bool wxApp::Yield(bool onlyIfNeeded)
return true;
}
#ifdef __WXDEBUG__
void wxApp::OnAssert(const wxChar *file, int line, const wxChar* cond, const wxChar *msg)
{
m_isInAssert = TRUE;
wxAppBase::OnAssert(file, line, cond, msg);
m_isInAssert = FALSE;
}
#endif // __WXDEBUG__