Skip to content

Commit

Permalink
assert: mark SDL_ExitProcess as SDL_NORETURN again.
Browse files Browse the repository at this point in the history
Put in a hack to (hopefully) make MingW happy.

Fixes Bugzilla #4100.
  • Loading branch information
icculus committed Jun 12, 2019
1 parent 04b50f6 commit f5a3478
Showing 1 changed file with 4 additions and 2 deletions.
6 changes: 4 additions & 2 deletions src/SDL_assert.c
Expand Up @@ -123,14 +123,16 @@ static void SDL_GenerateAssertionReport(void)
#if defined(__WATCOMC__)
#pragma aux SDL_ExitProcess aborts;
#endif
static void SDL_ExitProcess(int exitcode)
static SDL_NORETURN void SDL_ExitProcess(int exitcode)
{
#ifdef __WIN32__
/* "if you do not know the state of all threads in your process, it is
better to call TerminateProcess than ExitProcess"
https://msdn.microsoft.com/en-us/library/windows/desktop/ms682658(v=vs.85).aspx */
TerminateProcess(GetCurrentProcess(), exitcode);

/* MingW doesn't have TerminateProcess marked as noreturn, so add an
ExitProcess here that will never be reached but make MingW happy. */
ExitProcess(exitcode);
#elif defined(__EMSCRIPTEN__)
emscripten_cancel_main_loop(); /* this should "kill" the app. */
emscripten_force_exit(exitcode); /* this should "kill" the app. */
Expand Down

0 comments on commit f5a3478

Please sign in to comment.