#include "wx/app.h"
#include "wx/evtloop.h"
+#include "wx/thread.h"
#include "wx/dfb/private.h"
#include "wx/private/fontmgr.h"
IMPLEMENT_DYNAMIC_CLASS(wxApp, wxEvtHandler)
-BEGIN_EVENT_TABLE(wxApp, wxEvtHandler)
- EVT_IDLE(wxAppBase::OnIdle)
-END_EVENT_TABLE()
-
wxApp::wxApp()
{
}
void wxApp::WakeUpIdle()
{
-#if wxUSE_THREADS
- if (!wxThread::IsMain())
- wxMutexGuiEnter();
-#endif
-
+ // we don't need a mutex here, since we use the wxConsoleEventLoop
+ // and wxConsoleEventLoop::WakeUp() is thread-safe
wxEventLoopBase * const loop = wxEventLoop::GetActive();
if ( loop )
loop->WakeUp();
-
-#if wxUSE_THREADS
- if (!wxThread::IsMain())
- wxMutexGuiLeave();
-#endif
-}
-
-
-bool wxApp::Yield(bool onlyIfNeeded)
-{
-#if wxUSE_THREADS
- if ( !wxThread::IsMain() )
- return true; // can't process events from other threads
-#endif // wxUSE_THREADS
-
- static bool s_inYield = false;
-
- if ( s_inYield )
- {
- if ( !onlyIfNeeded )
- {
- wxFAIL_MSG( wxT("wxYield called recursively" ) );
- }
-
- return false;
- }
-
- s_inYield = true;
-
- wxLog::Suspend();
-
- wxEventLoop * const
- loop = wx_static_cast(wxEventLoop *, wxEventLoop::GetActive());
- if ( loop )
- loop->Yield();
-
- // it's necessary to call ProcessIdle() to update the frames sizes which
- // might have been changed (it also will update other things set from
- // OnUpdateUI() which is a nice (and desired) side effect)
- while ( ProcessIdle() ) {}
-
- wxLog::Resume();
-
- s_inYield = false;
-
- return true;
}