]> git.saurik.com Git - wxWidgets.git/blobdiff - src/gtk/threadgui.inc
OnExit() is called for modules which were initialized even if the init of
[wxWidgets.git] / src / gtk / threadgui.inc
index 165fef3c01b707352ffb92e9a2a2a694c00c3bf9..7f29dc9cf165957c4b20dd382e602b54ff9fbddd 100644 (file)
@@ -21,7 +21,6 @@
 
 #include <gdk/gdk.h>
 
-
 /////////////////////////////////////////////////////////////////////////////
 // Static variables
 /////////////////////////////////////////////////////////////////////////////
@@ -36,16 +35,22 @@ static void
 ThreadExitProc(gpointer WXUNUSED(client), gint fid,
                GdkInputCondition WXUNUSED(cond))
 {
-  wxThread* ptr;
+    wxThread* ptr;
+  
+    // printf( "thread exit proc.\n" );
 
-  if (fid != p_thrd_pipe[0])
-    return;
-  if (read(fid, &ptr, sizeof(ptr)) == sizeof(ptr)) {
-    //fprintf(stderr, "calling OnExit %p\n", ptr);
-    ptr->OnExit();
-  } else {
-    //fprintf(stderr, "this should never happen\n");
-  }
+    if (fid != p_thrd_pipe[0])
+        return;
+       
+    if (read(fid, &ptr, sizeof(ptr)) == sizeof(ptr)) 
+    {
+        // printf( "calling OnExit %p\n", ptr);
+        ptr->OnExit();
+    } 
+    else 
+    {
+        // printf( "this should never happen\n" );
+    }
 }
 
 // Global initialization
@@ -63,3 +68,14 @@ static void wxThreadGuiExit()
   close(p_thrd_pipe[0]);
   close(p_thrd_pipe[1]);
 }
+
+void wxMutexGuiEnter()
+{
+  wxMainMutex->Lock();
+}
+
+void wxMutexGuiLeave()
+{
+  wxMainMutex->Unlock();
+}
+