cmd: for /f fails to launch quoted program plus args.

for /f can run a program and parse its output. The program name can
supply args and be quoted or not.  If quoted, wine fails to run the
program because internally we were adding an extra pair of
quotes. These are not needed and can be removed.

Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=39906
Signed-off-by: Jason Edmeades <us@edmeades.me.uk>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Jason Edmeades 2018-08-27 20:41:51 +01:00 committed by Alexandre Julliard
parent 58d21b3319
commit 8b6ba774c0
3 changed files with 6 additions and 2 deletions

View File

@ -2073,7 +2073,7 @@ static HANDLE WCMD_forf_getinputhandle(BOOL usebackq, WCHAR *itemstr, BOOL iscmd
static const WCHAR redirOutW[] = {'>','%','s','\0'}; static const WCHAR redirOutW[] = {'>','%','s','\0'};
static const WCHAR cmdW[] = {'C','M','D','\0'}; static const WCHAR cmdW[] = {'C','M','D','\0'};
static const WCHAR cmdslashcW[] = {'C','M','D','.','E','X','E',' ', static const WCHAR cmdslashcW[] = {'C','M','D','.','E','X','E',' ',
'/','C',' ','"','%','s','"','\0'}; '/','C',' ','%','s','\0'};
/* Remove leading and trailing character */ /* Remove leading and trailing character */
if ((iscmd && (itemstr[0] == '`' && usebackq)) || if ((iscmd && (itemstr[0] == '`' && usebackq)) ||

View File

@ -1724,9 +1724,11 @@ if "%CD%"=="" goto :SkipFORFcmdNT4
for /f %%i in ('echo.Passed1') do echo %%i for /f %%i in ('echo.Passed1') do echo %%i
for /f "usebackq" %%i in (`echo.Passed2`) do echo %%i for /f "usebackq" %%i in (`echo.Passed2`) do echo %%i
for /f usebackq %%i in (`echo.Passed3`) do echo %%i for /f usebackq %%i in (`echo.Passed3`) do echo %%i
for /f "usebackq" %%i in (`"c:\windows\system32\cmd.exe" /C echo Passed4`) do echo %%i
for /f "usebackq" %%i in (`""c:\windows\system32\cmd.exe" /C echo Passed5"`) do echo %%i
goto :ContinueFORF goto :ContinueFORF
:SkipFORFcmdNT4 :SkipFORFcmdNT4
for /l %%i in (1,1,3) do echo Missing functionality - Broken%%i for /l %%i in (1,1,5) do echo Missing functionality - Broken%%i
:ContinueFORF :ContinueFORF
rem FIXME: Rest not testable right now in wine: not implemented and would need rem FIXME: Rest not testable right now in wine: not implemented and would need
rem preliminary grep-like program implementation (e.g. like findstr or fc) even rem preliminary grep-like program implementation (e.g. like findstr or fc) even

View File

@ -1209,6 +1209,8 @@ c
Passed1@or_broken@Missing functionality - Broken1 Passed1@or_broken@Missing functionality - Broken1
Passed2@or_broken@Missing functionality - Broken2 Passed2@or_broken@Missing functionality - Broken2
Passed3@or_broken@Missing functionality - Broken3 Passed3@or_broken@Missing functionality - Broken3
Passed4@or_broken@Missing functionality - Broken4
Passed5@or_broken@Missing functionality - Broken5
------ eol option ------ eol option
and@or_broken@Broken NT4 functionality1 and@or_broken@Broken NT4 functionality1
Line@or_broken@Broken NT4 functionality2 Line@or_broken@Broken NT4 functionality2