// headers
// ----------------------------------------------------------------------------
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
#pragma implementation "evtloop.h"
#endif
#ifndef WX_PRECOMP
#endif //WX_PRECOMP
+#include "wx/app.h"
#include "wx/evtloop.h"
#include <gtk/gtk.h>
// wxEventLoop running and exiting
// ----------------------------------------------------------------------------
-wxEventLoop *wxEventLoop::ms_activeLoop = NULL;
+wxEventLoop *wxEventLoopBase::ms_activeLoop = NULL;
wxEventLoop::~wxEventLoop()
{
wxASSERT_MSG( !m_impl, _T("should have been deleted in Run()") );
}
-bool wxEventLoop::IsRunning() const
-{
- return m_impl != NULL;
-}
-
int wxEventLoop::Run()
{
// event loops are not recursive, you need to create another loop!
// wxEventLoop message processing dispatching
// ----------------------------------------------------------------------------
+extern bool g_isIdle;
+
bool wxEventLoop::Pending() const
{
- return gtk_events_pending() > 0;
+ if (wxTheApp && !g_isIdle)
+ {
+ // We need to remove idle callbacks or gtk_events_pending will
+ // never return false.
+ gtk_idle_remove( wxTheApp->m_idleTag );
+ wxTheApp->m_idleTag = 0;
+ g_isIdle = TRUE;
+ }
+
+ return gtk_events_pending();
}
bool wxEventLoop::Dispatch()