From 5b2bd7fe87503f237d06aa4fd57ea1a53c67e1e7 Mon Sep 17 00:00:00 2001 From: Spoike Date: Mon, 8 Apr 2013 09:31:59 +0000 Subject: [PATCH] hopefully sdl target should work a little better on mac. git-svn-id: https://svn.code.sf.net/p/fteqw/code/trunk@4303 fc73d0e0-1445-4013-8a0c-d673dee63da5 --- engine/client/sys_sdl.c | 24 +++++++++++++++++++++++- 1 file changed, 23 insertions(+), 1 deletion(-) diff --git a/engine/client/sys_sdl.c b/engine/client/sys_sdl.c index 41a7c8aaa..47b583f4f 100644 --- a/engine/client/sys_sdl.c +++ b/engine/client/sys_sdl.c @@ -211,7 +211,7 @@ int Sys_EnumerateFiles (const char *gpath, const char *match, int (*func)(const return go; } -#elif defined(linux) || defined(__unix__) +#elif defined(linux) || defined(__unix__) || defined(__MACH__) #include int Sys_EnumerateFiles (const char *gpath, const char *match, int (*func)(const char *, int, void *, void *), void *parm, void *spath) { @@ -597,6 +597,28 @@ int QDECL main(int argc, char **argv) return 0; } +#ifdef _MSC_VER +//our version of sdl_main.lib, which doesn't fight c runtimes. +int WINAPI WinMain (HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) +{ + int argc; + int i, l, c; + LPWSTR *argvw; + char **argv; + char utf8arg[1024]; + argvw = CommandLineToArgvW(GetCommandLineW(), &argc); + argv = malloc(argc * sizeof(char*)); + for (i = 0; i < argc; i++) + { + for(l = 0, c = 0; argvw[l]; l++) + c += utf8_encode(utf8arg+c, argvw[i][l], sizeof(utf8arg) - c-1); + utf8arg[c] = 0; + argv[i] = strdup(utf8arg); + } + return main(argc, argv); +} +#endif + qboolean Sys_GetDesktopParameters(int *width, int *height, int *bpp, int *refreshrate) { return false;