X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=rts%2FMain.c;h=434f79156b668079f7e07abe30e68f115816fa21;hb=2777940384ce4740954062bedd0f6813698fc72a;hp=745d7759def2b99d14fd4d8dca79703c9027189c;hpb=48aefd90f74b4c9522eacdf9a730e50a1dfa29f9;p=ghc-hetmet.git diff --git a/rts/Main.c b/rts/Main.c index 745d775..434f791 100644 --- a/rts/Main.c +++ b/rts/Main.c @@ -16,6 +16,9 @@ #include "RtsUtils.h" #include "Prelude.h" #include "Task.h" +#if defined(mingw32_HOST_OS) +#include "win32/seh_excn.h" +#endif #include #ifdef DEBUG @@ -38,17 +41,20 @@ extern void __stginit_ZCMain(void); +static int progargc; +static char **progargv; + /* Hack: we assume that we're building a batch-mode system unless * INTERPRETER is set */ #ifndef INTERPRETER /* Hack */ -int main(int argc, char *argv[]) +static void real_main(void) { int exit_status; SchedulerStatus status; /* all GranSim/GUM init is done in startupHaskell; sets IAmMainThread! */ - startupHaskell(argc,argv,__stginit_ZCMain); + startupHaskell(progargc,progargv,__stginit_ZCMain); /* kick off the computation by creating the main thread with a pointer to mainIO_closure representing the computation of the overall program; @@ -133,6 +139,21 @@ int main(int argc, char *argv[]) barf("main thread completed with invalid status"); } shutdownHaskellAndExit(exit_status); - return 0; /* never reached, keep gcc -Wall happy */ +} +int main(int argc, char *argv[]) +{ + /* We do this dance with argc and argv as otherwise the SEH exception + stuff (the BEGIN/END CATCH below) on Windows gets confused */ + progargc = argc; + progargv = argv; + +#if defined(mingw32_HOST_OS) + BEGIN_CATCH +#endif + real_main(); +#if defined(mingw32_HOST_OS) + END_CATCH +#endif + return 0; /* not reached, but keeps gcc -Wall happy */ } # endif /* BATCH_MODE */