wcmd: Ignore start and end quotes.

This commit is contained in:
André Hentschel 2009-08-28 18:34:32 +02:00 committed by Alexandre Julliard
parent 2f3ac0640b
commit 765d9a1411
3 changed files with 7 additions and 1 deletions

View File

@ -2072,6 +2072,8 @@ void WCMD_setshow_env (WCHAR *s) {
s += 2; s += 2;
while (*s && *s==' ') s++; while (*s && *s==' ') s++;
if (*s=='\"')
WCMD_opt_s_strip_quotes(s);
/* If no parameter, or no '=' sign, return an error */ /* If no parameter, or no '=' sign, return an error */
if (!(*s) || ((p = strchrW (s, '=')) == NULL )) { if (!(*s) || ((p = strchrW (s, '=')) == NULL )) {
@ -2096,6 +2098,9 @@ void WCMD_setshow_env (WCHAR *s) {
} else { } else {
DWORD gle; DWORD gle;
if (*s=='\"')
WCMD_opt_s_strip_quotes(s);
p = strchrW (s, '='); p = strchrW (s, '=');
if (p == NULL) { if (p == NULL) {
env = GetEnvironmentStrings (); env = GetEnvironmentStrings ();

View File

@ -100,6 +100,7 @@ WCHAR *WCMD_strtrim_leading_spaces (WCHAR *string);
void WCMD_HandleTildaModifiers(WCHAR **start, WCHAR *forVariable, WCHAR *forValue, BOOL justFors); void WCMD_HandleTildaModifiers(WCHAR **start, WCHAR *forVariable, WCHAR *forValue, BOOL justFors);
void WCMD_splitpath(const WCHAR* path, WCHAR* drv, WCHAR* dir, WCHAR* name, WCHAR* ext); void WCMD_splitpath(const WCHAR* path, WCHAR* drv, WCHAR* dir, WCHAR* name, WCHAR* ext);
void WCMD_opt_s_strip_quotes(WCHAR *cmd);
WCHAR *WCMD_LoadMessage(UINT id); WCHAR *WCMD_LoadMessage(UINT id);
WCHAR *WCMD_strdupW(WCHAR *input); WCHAR *WCMD_strdupW(WCHAR *input);
void WCMD_strsubstW(WCHAR *start, WCHAR* next, WCHAR* insert, int len); void WCMD_strsubstW(WCHAR *start, WCHAR* next, WCHAR* insert, int len);

View File

@ -457,7 +457,7 @@ WCHAR *WCMD_strtrim_leading_spaces (WCHAR *string) {
* *
* Remove first and last quote WCHARacters, preserving all other text * Remove first and last quote WCHARacters, preserving all other text
*/ */
static void WCMD_opt_s_strip_quotes(WCHAR *cmd) { void WCMD_opt_s_strip_quotes(WCHAR *cmd) {
WCHAR *src = cmd + 1, *dest = cmd, *lastq = NULL; WCHAR *src = cmd + 1, *dest = cmd, *lastq = NULL;
while((*dest=*src) != '\0') { while((*dest=*src) != '\0') {
if (*src=='\"') if (*src=='\"')