Call the registered exit functions if the dll is unloaded.
authorHartmut Birr <osexpert@googlemail.com>
Thu, 11 Aug 2005 19:32:02 +0000 (19:32 +0000)
committerHartmut Birr <osexpert@googlemail.com>
Thu, 11 Aug 2005 19:32:02 +0000 (19:32 +0000)
svn path=/trunk/; revision=17294

reactos/lib/crt/stdlib/_exit.c
reactos/lib/crt/stdlib/atexit.c
reactos/lib/crtdll/dllmain.c
reactos/lib/msvcrt/dllmain.c

index 0d6a163..d2e3f46 100644 (file)
@@ -12,13 +12,7 @@ struct __atexit *__atexit_ptr = 0;
 void exit(int status)
 {
   //int i;
-  struct __atexit *a = __atexit_ptr;
-  __atexit_ptr = 0; /* to prevent infinite loops */
-  while (a)
-  {
-    (a->__function)();
-    a = a->__next;
-  }
+
 /*
   if (__stdio_cleanup_hook)
     __stdio_cleanup_hook();
index c58e534..d6c105c 100644 (file)
@@ -2,6 +2,19 @@
 #include <stdlib.h>
 #include <internal/atexit.h>
 
+void _atexit_cleanup(void)
+{
+  struct __atexit *next, *a = __atexit_ptr;
+  __atexit_ptr = 0; /* to prevent infinite loops */
+  while (a)
+  {
+    (a->__function)();
+    next = a->__next;
+    free(a);
+    a = next;
+  }
+}
+
 /*
  * @implemented
  *
index 98118f7..f1aa0a7 100644 (file)
@@ -38,6 +38,7 @@ extern BOOL __fileno_init(void);
 extern int BlockEnvToEnvironA(void);
 extern int BlockEnvToEnvironW(void);
 extern void FreeEnvironment(char **environment);
+extern void _atexit_cleanup(void);
 
 extern unsigned int _osver;
 extern unsigned int _winminor;
@@ -174,6 +175,7 @@ DllMain(PVOID hinstDll, ULONG dwReason, PVOID reserved)
         DPRINT("Detach %d\n", nAttachCount);
         /* FIXME: more cleanup... */
         _fcloseall();
+        _atexit_cleanup();
 
         /* destroy tls stuff */
         DestroyThreadData();
index 58b41c7..4a837a1 100644 (file)
@@ -37,6 +37,7 @@ extern BOOL __fileno_init(void);
 extern int BlockEnvToEnvironA(void);
 extern int BlockEnvToEnvironW(void);
 extern void FreeEnvironment(char **environment);
+extern void _atexit_cleanup(void);
 
 extern unsigned int _osver;
 extern unsigned int _winminor;
@@ -116,6 +117,7 @@ DllMain(PVOID hinstDll, ULONG dwReason, PVOID reserved)
         //DPRINT("Detach\n");
         /* FIXME: more cleanup... */
         _fcloseall();
+        _atexit_cleanup();
 
         /* destroy tls stuff */
         DestroyThreadData();