X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdlib%2Fexit.c;h=8862f4120c899912a696cfda3b40a5b183a187c8;hb=d02f38605b53cdff5460cc6b9e1b2a80c3a2ba4c;hp=5cb2a508fe19838baa4e9e95f08707af90e671c4;hpb=492cae1767efcce269e5472dcf0a18e6abf546a1;p=pdclib diff --git a/functions/stdlib/exit.c b/functions/stdlib/exit.c index 5cb2a50..8862f41 100644 --- a/functions/stdlib/exit.c +++ b/functions/stdlib/exit.c @@ -12,19 +12,24 @@ #ifndef REGTEST -struct _PDCLIB_exitfunc_t * regstack = NULL; +/* TODO - "except that a function is called after any previously registered + functions that had already been called at the time it was registered. +*/ + +/* TODO: 32 is guaranteed. This should be dynamic but ATM gives problems + with my malloc. +*/ +#define NUMBER_OF_SLOTS 40 + +void (*_PDCLIB_regstack[ NUMBER_OF_SLOTS ])( void ); +size_t _PDCLIB_regptr = NUMBER_OF_SLOTS; void exit( int status ) { - struct _PDCLIB_exitfunc_t * next = regstack; - while ( next != NULL ) + while ( _PDCLIB_regptr < NUMBER_OF_SLOTS ) { - next->func(); - regstack = next->next; - free( next ); - next = regstack; + _PDCLIB_regstack[ _PDCLIB_regptr++ ](); } - /* TODO: Flush and close open streams. Remove tmpfile() files. */ _Exit( status ); } @@ -33,10 +38,9 @@ void exit( int status ) #ifdef TEST #include <_PDCLIB_test.h> -int main() +int main( void ) { - BEGIN_TESTS; - TESTCASE( NO_TESTDRIVER ); + /* Unwinding of regstack tested in atexit(). */ return TEST_RESULTS; }