int _tmain(int argc, TCHAR **argv) #endif // __GNUC__ { int i, rc; char **utf8_argv; #ifdef __GNUC__ TCHAR **argv; #ifdef UNICODE // MinGW doesn't support wmain() directly, so we have to jump through some hoops extern void __wgetmainargs(int *argc, wchar_t ***wargv, wchar_t ***wenviron, int expand_wildcards, int *startupinfo); WCHAR **wenviron; int startupinfo; __wgetmainargs(&argc, &argv, &wenviron, 0, &startupinfo); #else // !UNICODE argv = a_argv; #endif // UNICODE #endif // __GNUC__ #ifdef MALLOC_DEBUG { extern int winalloc_in_main_code; winalloc_in_main_code = TRUE; #endif /* convert arguments to UTF-8 */ utf8_argv = (char **) malloc(argc * sizeof(*argv)); if (utf8_argv == NULL) return 999; for (i = 0; i < argc; i++) { utf8_argv[i] = utf8_from_tstring(argv[i]); if (utf8_argv[i] == NULL) return 999; } /* run utf8_main */ rc = utf8_main(argc, utf8_argv); /* free arguments */ for (i = 0; i < argc; i++) free(utf8_argv[i]); free(utf8_argv); #ifdef MALLOC_DEBUG { void check_unfreed_mem(void); check_unfreed_mem(); } winalloc_in_main_code = FALSE; } #endif return rc; }
extern "C" int _tmain(int argc, TCHAR **argv) { int i, rc; char **utf8_argv; #ifdef MALLOC_DEBUG { extern int winalloc_in_main_code; winalloc_in_main_code = TRUE; #endif /* convert arguments to UTF-8 */ utf8_argv = (char **) malloc(argc * sizeof(*argv)); if (utf8_argv == NULL) return 999; for (i = 0; i < argc; i++) { utf8_argv[i] = utf8_from_tstring(argv[i]); if (utf8_argv[i] == NULL) return 999; } /* run utf8_main */ rc = utf8_main(argc, utf8_argv); /* free arguments */ for (i = 0; i < argc; i++) free(utf8_argv[i]); free(utf8_argv); #ifdef MALLOC_DEBUG { void check_unfreed_mem(void); check_unfreed_mem(); } winalloc_in_main_code = FALSE; } #endif return rc; }
int main(int argc, char **argv) { int res = 0; #else /* gee */ extern "C" DECLSPEC void SDLCALL SDL_SetModuleHandle(void *hInst); // translated to utf8_main int main(int argc, char *argv[]) { int res = 0; #if !(SDLMAME_SDL2) /* Load SDL dynamic link library */ if ( SDL_Init(SDL_INIT_NOPARACHUTE) < 0 ) { fprintf(stderr, "WinMain() error: %s", SDL_GetError()); return(FALSE); } SDL_SetModuleHandle(GetModuleHandle(NULL)); #endif #endif // disable I/O buffering setvbuf(stdout, (char *) NULL, _IONBF, 0); setvbuf(stderr, (char *) NULL, _IONBF, 0); #ifdef SDLMAME_UNIX #if (!defined(SDLMAME_MACOSX)) && (!defined(SDLMAME_HAIKU)) if (TTF_Init() == -1) { printf("SDL_ttf failed: %s\n", TTF_GetError()); } FcInit(); #endif #endif #ifdef SDLMAME_OS2 MorphToPM(); #endif #if defined(SDLMAME_X11) && (SDL_MAJOR_VERSION == 1) && (SDL_MINOR_VERSION == 2) if (SDL_Linked_Version()->patch < 10) /* workaround for SDL choosing a 32-bit ARGB visual */ { Display *display; if ((display = XOpenDisplay(NULL)) && (DefaultDepth(display, DefaultScreen(display)) >= 24)) { XVisualInfo vi; char buf[130]; if (XMatchVisualInfo(display, DefaultScreen(display), 24, TrueColor, &vi)) { snprintf(buf, sizeof(buf), "0x%lx", vi.visualid); osd_setenv(SDLENV_VISUALID, buf, 0); } } if (display) XCloseDisplay(display); } #endif { sdl_osd_interface osd; sdl_options options; cli_frontend frontend(options, osd); res = frontend.execute(argc, argv); } #ifdef MALLOC_DEBUG { void check_unfreed_mem(void); check_unfreed_mem(); } #endif // already called... //SDL_Quit(); #ifdef SDLMAME_UNIX #if (!defined(SDLMAME_MACOSX)) && (!defined(SDLMAME_HAIKU)) TTF_Quit(); FcFini(); #endif #endif exit(res); return res; }