SubWindow border thickness fix. Overlay changes in glutGet.
authorDon Heyse <dheyse@hotmail.com>
Fri, 7 Feb 2003 21:27:20 +0000 (21:27 +0000)
committerDon Heyse <dheyse@hotmail.com>
Fri, 7 Feb 2003 21:27:20 +0000 (21:27 +0000)
git-svn-id: svn+ssh://svn.code.sf.net/p/freeglut/code/trunk/freeglut/freeglut@49 7f0cb862-5218-0410-a997-914c9d46530a

freeglut-1.3/freeglut_structure.c

index d3696ba..2da3e1f 100644 (file)
@@ -32,7 +32,7 @@
 #define  G_LOG_DOMAIN  "freeglut-structure"
 
 #include "../include/GL/freeglut.h"
-#include "../include/GL/freeglut_internal.h"
+#include "freeglut_internal.h"
 
 
 /* -- GLOBAL EXPORTS ------------------------------------------------------- */
@@ -179,6 +179,17 @@ void fgAddToWindowDestroyList ( SFG_Window* window, GLboolean needToClose )
   WindowsToDestroy = new_list_entry ;
 
   /*
+   * Check if the window is the current one...
+   */
+  if ( fgStructure.Window == window )
+    fgStructure.Window = NULL;
+
+  /*
+   * If the destroyed window has the highest window ID number, decrement the window ID number
+   */
+  if ( window->ID == fgStructure.WindowID ) fgStructure.WindowID-- ;
+
+  /*
    * Check the execution state.  If this has been called from "glutDestroyWindow",
    * a statement in that function will reset the "ExecState" after this function returns.
    */
@@ -197,8 +208,6 @@ void fgAddToWindowDestroyList ( SFG_Window* window, GLboolean needToClose )
  */
 void fgCloseWindows ()
 {
-  fgExecutionState ExecState = fgState.ExecState ;
-
   SFG_WindowList *window_ptr = WindowsToDestroy ;
   WindowsToDestroy = (SFG_WindowList*)NULL ;  // In case the destroy callbacks cause more windows to be closed
 
@@ -209,14 +218,12 @@ void fgCloseWindows ()
     free ( window_ptr ) ;
     window_ptr = next ;
 
-    if ( !window_ptr ) window_ptr = WindowsToDestroy ;
+    if ( !window_ptr )
+    {
+      window_ptr = WindowsToDestroy ;
+      WindowsToDestroy = (SFG_WindowList*)NULL ;
+    }
   }
-
-  /*
-   * Since the "fgDestroyWindow" function could easily have set the "ExecState" to stop,
-   * let's set it back to what it was.
-   */
-  fgState.ExecState = ExecState ;
 }
 
 /*
@@ -265,12 +272,6 @@ void fgDestroyWindow( SFG_Window* window, GLboolean needToClose )
         fgCloseWindow( window );
 
     /*
-     * Check if the window is the current one...
-     */
-    if( fgStructure.Window == window )
-        fgStructure.Window = NULL;
-
-    /*
      * Finally, we can delete the window's object. It hopefully does
      * have everything inside it freed and we do not have to care...
      */