diff options
author | Ryan C. Gordon <icculus@icculus.org> | 2005-09-28 11:36:20 +0000 |
---|---|---|
committer | Ryan C. Gordon <icculus@icculus.org> | 2005-09-28 11:36:20 +0000 |
commit | 91121c31044b1089bba5360409b47762effcb441 (patch) | |
tree | b10b3ae1bf7b106ac1ebc23ad7c39072471f0c5b /test/testtimer.c | |
parent | 004ec06058c91614d1aca65aa38573a6256d16a9 (diff) |
Removed atexit() from most of the test programs; atexit(SDL_Quit) isn't safe
if SDL is built with a non-cdecl calling convention, and it's just generally
bad practice anyhow.
Now programs explicitly call SDL_Quit() where appropriate, wrap SDL_Quit() in
a cdecl function where it can't be avoided, and rely on the parachute where
a crash might have hit the atexit() before (these ARE test programs, after
all!).
--HG--
extra : convert_revision : svn%3Ac70aab31-4412-0410-b14c-859654838e24/trunk%401154
Diffstat (limited to 'test/testtimer.c')
-rw-r--r-- | test/testtimer.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/test/testtimer.c b/test/testtimer.c index c89cfee9..02b533cb 100644 --- a/test/testtimer.c +++ b/test/testtimer.c @@ -12,6 +12,13 @@ static int ticks = 0; +/* Call this instead of exit(), so we can clean up SDL: atexit() is evil. */ +static void quit(int rc) +{ + SDL_Quit(); + exit(rc); +} + static Uint32 ticktock(Uint32 interval) { ++ticks; @@ -31,9 +38,8 @@ int main(int argc, char *argv[]) if ( SDL_Init(SDL_INIT_TIMER) < 0 ) { fprintf(stderr, "Couldn't load SDL: %s\n", SDL_GetError()); - exit(1); + return(1); } - atexit(SDL_Quit); /* Start the timer */ desired = 0; @@ -83,5 +89,6 @@ int main(int argc, char *argv[]) SDL_RemoveTimer(t2); SDL_RemoveTimer(t3); + SDL_Quit(); return(0); } |