-gint wxapp_idle_callback( gpointer WXUNUSED(data) )
-{
- if (!wxTheApp) return TRUE;
-
- /* when getting called from GDK's idle handler we
- are no longer within GDK's grab on the GUI
- thread so we must lock it here ourselves */
- GDK_THREADS_ENTER ();
-
- /* sent idle event to all who request them */
- while (wxTheApp->ProcessIdle()) { }
-
- /* we don't want any more idle events until the next event is
- sent to wxGTK */
- gtk_idle_remove( wxTheApp->m_idleTag );
- wxTheApp->m_idleTag = 0;
-
- /* indicate that we are now in idle mode - even so deeply
- in idle mode that we don't get any idle events anymore.
- this is like wxMSW where an idle event is sent only
- once each time after the event queue has been completely
- emptied */
- g_isIdle = TRUE;
-
- /* release lock again */
- GDK_THREADS_LEAVE ();
-
- return TRUE;
-}
+#if wxUSE_LOG
+ // disable log flushing from here because a call to wxYield() shouldn't
+ // normally result in message boxes popping up &c
+ wxLog::Suspend();
+#endif