]> granicus.if.org Git - vim/commitdiff
patch 8.0.1051: cannot run terminal with spaces in argument v8.0.1051
authorBram Moolenaar <Bram@vim.org>
Sun, 3 Sep 2017 17:52:17 +0000 (19:52 +0200)
committerBram Moolenaar <Bram@vim.org>
Sun, 3 Sep 2017 17:52:17 +0000 (19:52 +0200)
Problem:    Cannot run terminal with spaces in argument.
Solution:   Accept backslash to escape space and other characters. (closes
            #1999)

src/os_unix.c
src/testdir/test_terminal.vim
src/version.c

index b34c31645bb06718ea8327743fb22e0ab4085050..57ea4d94516d65c8c0bf594b0362f6ca48187826 100644 (file)
@@ -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)
index a16f3d906e3229f990f53dbb4cded9309815906b..ce3fab7e5d0076c4e9f0b35ee73a09c616b31715 100644 (file)
@@ -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
index 45537fe059a44bdd7fdc269528d95adf2da1f930..fe316be097f874c0f1cefd47a4ffa02ea7805f31 100644 (file)
@@ -769,6 +769,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1051,
 /**/
     1050,
 /**/