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 | b77cfd625af1620704c3415c01684a95b430688c (patch) | |
tree | b10b3ae1bf7b106ac1ebc23ad7c39072471f0c5b /test/testtimer.c | |
parent | a452729cab30ba62f43da4ecbc7c947f89eafe2e (diff) | |
download | sdl-b77cfd625af1620704c3415c01684a95b430688c.tar.gz |
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!).
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 c89cfee90..02b533cbb 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); } |