X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdlib%2Fexit.c;h=0d816a3bba1a6ecd9b9b867bfc0fbe4ab0d22479;hb=0788e1f853cae7be12203116b0d277ab1d653afb;hp=5cb2a508fe19838baa4e9e95f08707af90e671c4;hpb=492cae1767efcce269e5472dcf0a18e6abf546a1;p=pdclib diff --git a/functions/stdlib/exit.c b/functions/stdlib/exit.c index 5cb2a50..0d816a3 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 ); } @@ -36,7 +41,7 @@ void exit( int status ) int main() { BEGIN_TESTS; - TESTCASE( NO_TESTDRIVER ); + /* Unwinding of regstack tested in atexit(). */ return TEST_RESULTS; }