extern "C" {
static gint wxapp_poll_func( GPollFD *ufds, guint nfds, gint timeout )
{
- gdk_threads_enter();
-
- wxMutexGuiLeave();
g_mainThreadLocked = true;
gint res = (*wxgs_poll_func)(ufds, nfds, timeout);
- wxMutexGuiEnter();
g_mainThreadLocked = false;
- gdk_threads_leave();
-
return res;
}
}
#if wxUSE_THREADS
if (!g_thread_supported())
g_thread_init(NULL);
+ gdk_threads_init();
wxgs_poll_func = g_main_context_get_poll_func(NULL);
g_main_context_set_poll_func(NULL, wxapp_poll_func);
wxAddEmissionHook();
}
}
+
+#if wxUSE_THREADS
+void wxMutexGuiEnter()
+{
+ gdk_threads_enter();
+}
+
+void wxMutexGuiLeave()
+{
+ gdk_threads_leave();
+}
+#endif
// gs_nThreadsBeingDeleted will have been deleted
static wxCondition *gs_condAllDeleted = (wxCondition *)NULL;
+#ifndef __WXGTK20__
// this mutex must be acquired before any call to a GUI function
// (it's not inside #if wxUSE_GUI because this file is compiled as part
// of wxBase)
static wxMutex *gs_mutexGui = NULL;
+#endif
// when we wait for a thread to exit, we're blocking on a condition which the
// thread signals in its SignalExit() method -- but this condition can't be a
gs_mutexAllThreads = new wxMutex();
+#ifndef __WXGTK20__
gs_mutexGui = new wxMutex();
gs_mutexGui->Lock();
+#endif
gs_mutexDeleteThread = new wxMutex();
gs_condAllDeleted = new wxCondition(*gs_mutexDeleteThread);
delete gs_mutexAllThreads;
+#ifndef __WXGTK20__
// destroy GUI mutex
gs_mutexGui->Unlock();
delete gs_mutexGui;
+#endif
// and free TLD slot
(void)pthread_key_delete(gs_keySelf);
}
}
+#ifndef __WXGTK20__
void wxMutexGuiEnter()
{
gs_mutexGui->Lock();
{
gs_mutexGui->Unlock();
}
+#endif
// ----------------------------------------------------------------------------
// include common implementation code