summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2017-09-03 19:52:17 +0200
committerBram Moolenaar <Bram@vim.org>2017-09-03 19:52:17 +0200
commit9d654a8d8cd3421307445f111785fb303a38c2a0 (patch)
tree19af52692c7206812731803fbcb2267a74d7abf7
parent595a40226ea1285689b622042534fd8442402db3 (diff)
downloadvim-9d654a8d8cd3421307445f111785fb303a38c2a0.zip
patch 8.0.1051: cannot run terminal with spaces in argument
Problem: Cannot run terminal with spaces in argument. Solution: Accept backslash to escape space and other characters. (closes #1999)
-rw-r--r--src/os_unix.c11
-rw-r--r--src/testdir/test_terminal.vim20
-rw-r--r--src/version.c2
3 files changed, 31 insertions, 2 deletions
diff --git a/src/os_unix.c b/src/os_unix.c
index b34c31645..57ea4d945 100644
--- a/src/os_unix.c
+++ b/src/os_unix.c
@@ -4094,8 +4094,17 @@ mch_parse_cmd(char_u *cmd, int use_shcf, char ***argv, int *argc)
++*argc;
while (*p != NUL && (inquote || (*p != ' ' && *p != TAB)))
{
- if (*p == '"')
+ if (p[0] == '"')
inquote = !inquote;
+ 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;
+ }
++p;
}
if (*p == NUL)
diff --git a/src/testdir/test_terminal.vim b/src/testdir/test_terminal.vim
index a16f3d906..ce3fab7e5 100644
--- a/src/testdir/test_terminal.vim
+++ b/src/testdir/test_terminal.vim
@@ -293,6 +293,8 @@ func Test_terminal_size()
let size = term_getsize('')
bwipe!
call assert_equal([7, 27], size)
+
+ call delete('Xtext')
endfunc
func Test_terminal_curwin()
@@ -325,7 +327,7 @@ func Test_terminal_curwin()
split dummy
bwipe!
-
+ call delete('Xtext')
endfunc
func Test_finish_open_close()
@@ -555,3 +557,19 @@ func Test_terminal_no_cmd()
call assert_equal('look here', term_getline(buf, 1))
bwipe!
endfunc
+
+func Test_terminal_special_chars()
+ " this file name only works on Unix
+ if !has('unix')
+ return
+ endif
+ call mkdir('Xdir with spaces')
+ call writefile(['x'], 'Xdir with spaces/quoted"file')
+ term ls Xdir\ with\ spaces/quoted\"file
+ call WaitFor('term_getline("", 1) =~ "quoted"')
+ call assert_match('quoted"file', term_getline('', 1))
+ call term_wait('')
+
+ call delete('Xdir with spaces', 'rf')
+ bwipe
+endfunc
diff --git a/src/version.c b/src/version.c
index 45537fe05..fe316be09 100644
--- a/src/version.c
+++ b/src/version.c
@@ -770,6 +770,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1051,
+/**/
1050,
/**/
1049,