From 73cfb17c5bea40f1c5df841cf39799b8b1b71d39 Mon Sep 17 00:00:00 2001 From: Sam Lantinga Date: Sat, 29 Dec 2007 19:29:20 +0000 Subject: [PATCH] Merged fix for bug #503 from SDL 1.2 revision 3487 --- src/main/win32/SDL_win32_main.c | 36 ++++++++++++++++++++++++++++++--- 1 file changed, 33 insertions(+), 3 deletions(-) diff --git a/src/main/win32/SDL_win32_main.c b/src/main/win32/SDL_win32_main.c index 16858a633..524e0db77 100644 --- a/src/main/win32/SDL_win32_main.c +++ b/src/main/win32/SDL_win32_main.c @@ -25,14 +25,37 @@ #define isspace(a) (((CHAR)a == ' ') || ((CHAR)a == '\t')) #endif /* _WIN32_WCE < 300 */ +static void +UnEscapeQuotes(char *arg) +{ + char *last = NULL; + + while (*arg) { + if (*arg == '"' && *last == '\\') { + char *c_curr = arg; + char *c_last = last; + + while (*c_curr) { + *c_last = *c_curr; + c_last = c_curr; + c_curr++; + } + *c_last = '\0'; + } + last = arg; + arg++; + } +} + /* Parse a command line buffer into arguments */ static int ParseCommandLine(char *cmdline, char **argv) { char *bufp; - int argc; + char *lastp = NULL; + int argc, last_argc; - argc = 0; + argc = last_argc = 0; for (bufp = cmdline; *bufp;) { /* Skip leading whitespace */ while (isspace(*bufp)) { @@ -48,7 +71,8 @@ ParseCommandLine(char *cmdline, char **argv) ++argc; } /* Skip over word */ - while (*bufp && (*bufp != '"')) { + while (*bufp && (*bufp != '"' || *lastp == '\\')) { + lastp = bufp; ++bufp; } } else { @@ -69,6 +93,12 @@ ParseCommandLine(char *cmdline, char **argv) } ++bufp; } + + /* Strip out \ from \" sequences */ + if (argv && last_argc != argc) { + UnEscapeQuotes(argv[last_argc]); + } + last_argc = argc; } if (argv) { argv[argc] = NULL;