0
0
mirror of https://github.com/vim/vim.git synced 2025-09-24 03:44:06 -04:00

patch 8.0.1176: job_start() does not handle quote and backslash correctly

Problem:    Job_start() does not handle quote and backslash correctly.
Solution:   Remove quotes, recognize and remove backslashes.
This commit is contained in:
Bram Moolenaar
2017-10-06 01:07:41 +02:00
parent c902609f69
commit d78f03f860
3 changed files with 35 additions and 9 deletions

View File

@@ -4074,7 +4074,7 @@ wait4pid(pid_t child, waitstatus *status)
mch_parse_cmd(char_u *cmd, int use_shcf, char ***argv, int *argc)
{
int i;
char_u *p;
char_u *p, *d;
int inquote;
/*
@@ -4092,26 +4092,34 @@ mch_parse_cmd(char_u *cmd, int use_shcf, char ***argv, int *argc)
if (i == 1)
(*argv)[*argc] = (char *)p;
++*argc;
d = p;
while (*p != NUL && (inquote || (*p != ' ' && *p != TAB)))
{
if (p[0] == '"')
/* quotes surrounding an argument and are dropped */
inquote = !inquote;
else if (p[0] == '\\' && p[1] != NUL)
else
{
if (p[0] == '\\' && p[1] != NUL)
{
/* First pass: skip over "\ " and "\"".
* Second pass: Remove the backslash. */
if (i == 1)
mch_memmove(p, p + 1, STRLEN(p));
else
++p;
}
if (i == 1)
*d++ = *p;
}
++p;
}
if (*p == NUL)
break;
{
if (i == 1)
*p++ = NUL;
p = skipwhite(p);
*d++ = NUL;
break;
}
if (i == 1)
*d++ = NUL;
p = skipwhite(p + 1);
}
if (*argv == NULL)
{

View File

@@ -1590,6 +1590,22 @@ func Test_collapse_buffers()
bwipe!
endfunc
func Test_cmd_parsing()
if !has('unix')
return
endif
call assert_false(filereadable("file with space"))
let job = job_start('touch "file with space"')
call WaitFor('filereadable("file with space")')
call assert_true(filereadable("file with space"))
call delete("file with space")
let job = job_start('touch file\ with\ space')
call WaitFor('filereadable("file with space")')
call assert_true(filereadable("file with space"))
call delete("file with space")
endfunc
func Test_raw_passes_nul()
if !executable('cat') || !has('job')
return

View File

@@ -761,6 +761,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
1176,
/**/
1175,
/**/