X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/1e678b9b9392d7e2897c96af79ed76acc75c9fe4..0e08dd802b39ca3732a4797ab43a4461c8397889:/src/common/cmdline.cpp diff --git a/src/common/cmdline.cpp b/src/common/cmdline.cpp index f055522190..ce169ac95b 100644 --- a/src/common/cmdline.cpp +++ b/src/common/cmdline.cpp @@ -1280,15 +1280,15 @@ static wxString GetLongOptionName(wxString::const_iterator p, */ /* static */ -wxArrayString wxCmdLineParser::ConvertStringToArgs(const wxString& cmdline) +wxArrayString +wxCmdLineParser::ConvertStringToArgs(const wxString& cmdline, + wxCmdLineSplitType type) { wxArrayString args; wxString arg; arg.reserve(1024); - bool isInsideQuotes = false; - const wxString::const_iterator end = cmdline.end(); wxString::const_iterator p = cmdline.begin(); @@ -1303,31 +1303,76 @@ wxArrayString wxCmdLineParser::ConvertStringToArgs(const wxString& cmdline) break; // parse this parameter - bool lastBS = false; + bool lastBS = false, + isInsideQuotes = false; + wxChar chDelim = '\0'; for ( arg.clear(); p != end; ++p ) { const wxChar ch = *p; - if ( ch == '"' ) + + if ( type == wxCMD_LINE_SPLIT_DOS ) { - if ( !lastBS ) + if ( ch == '"' ) { - isInsideQuotes = !isInsideQuotes; + if ( !lastBS ) + { + isInsideQuotes = !isInsideQuotes; - // don't put quote in arg - continue; + // don't put quote in arg + continue; + } + //else: quote has no special meaning but the backslash + // still remains -- makes no sense but this is what + // Windows does + } + // note that backslash does *not* quote the space, only quotes do + else if ( !isInsideQuotes && (ch == ' ' || ch == '\t') ) + { + ++p; // skip this space anyhow + break; } - //else: quote has no special meaning but the backslash - // still remains -- makes no sense but this is what - // Windows does + + lastBS = !lastBS && ch == '\\'; } - // note that backslash does *not* quote the space, only quotes do - else if ( !isInsideQuotes && (ch == ' ' || ch == '\t') ) + else // type == wxCMD_LINE_SPLIT_UNIX { - ++p; // skip this space anyhow - break; - } + if ( !lastBS ) + { + if ( isInsideQuotes ) + { + if ( ch == chDelim ) + { + isInsideQuotes = false; + + continue; // don't use the quote itself + } + } + else // not in quotes and not escaped + { + if ( ch == '\'' || ch == '"' ) + { + isInsideQuotes = true; + chDelim = ch; - lastBS = ch == '\\'; + continue; // don't use the quote itself + } + + if ( ch == ' ' || ch == '\t' ) + { + ++p; // skip this space anyhow + break; + } + } + + lastBS = ch == '\\'; + if ( lastBS ) + continue; + } + else // escaped by backslash, just use as is + { + lastBS = false; + } + } arg += ch; }