Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
Tony White fixed bug #503
Support escaped quotes on Win32 command lines.
  • Loading branch information
slouken committed Dec 29, 2007
1 parent 50765f3 commit c51344b
Showing 1 changed file with 32 additions and 3 deletions.
35 changes: 32 additions & 3 deletions src/main/win32/SDL_win32_main.c
Expand Up @@ -53,13 +53,35 @@
#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) ) {
Expand All @@ -75,7 +97,8 @@ static int ParseCommandLine(char *cmdline, char **argv)
++argc;
}
/* Skip over word */
while ( *bufp && (*bufp != '"') ) {
while ( *bufp && ( *bufp != '"' || *lastp == '\\' ) ) {
lastp = bufp;
++bufp;
}
} else {
Expand All @@ -96,6 +119,12 @@ static int 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;
Expand Down

0 comments on commit c51344b

Please sign in to comment.