]> granicus.if.org Git - vim/commitdiff
patch 8.0.1672: error during completion causes command to be cancelled v8.0.1672
authorBram Moolenaar <Bram@vim.org>
Sat, 7 Apr 2018 17:09:09 +0000 (19:09 +0200)
committerBram Moolenaar <Bram@vim.org>
Sat, 7 Apr 2018 17:09:09 +0000 (19:09 +0200)
Problem:    Error during completion causes command to be cancelled.
Solution:   Reset did_emsg before waiting for another character. (Tom M.)

src/ex_getln.c
src/testdir/test_cmdline.vim
src/version.c

index 48cccf18e04609a2b0606718efefac655889c050..9fdfac5a28bcdd4e0d80deba537f6649a700be3d 100644 (file)
@@ -426,6 +426,10 @@ getcmdline(
 #endif
        quit_more = FALSE;      /* reset after CTRL-D which had a more-prompt */
 
+       did_emsg = FALSE;       /* There can't really be a reason why an error
+                                  that occurs while typing a command should
+                                  cause the command not to be executed. */
+
        cursorcmd();            /* set the cursor on the right spot */
 
        /* Get a character.  Ignore K_IGNORE and K_NOP, they should not do
index 8755fbf1aaf9623a822a79f3e58934ec9fa1dbba..ff0756c392c3ee203dab83ad08851988a6d2a5e3 100644 (file)
@@ -316,6 +316,17 @@ func Test_paste_in_cmdline()
   call feedkeys(":\<C-\>etoupper(getline(1))\<CR>\<C-B>\"\<CR>", 'tx')
   call assert_equal('"ASDF.X /TMP/SOME VERYLONGWORD A;B-C*D ', @:)
   bwipe!
+
+  " Error while typing a command used to cause that it was not executed
+  " in the end.
+  new
+  try
+    call feedkeys(":file \<C-R>%Xtestfile\<CR>", 'tx')
+  catch /^Vim\%((\a\+)\)\=:E32/
+    " ignore error E32
+  endtry
+  call assert_equal("Xtestfile", bufname("%"))
+  bwipe!
 endfunc
 
 func Test_remove_char_in_cmdline()
index 8264bd9a8a46ac6df6c1e491421e11cd9cf95528..665c95391616c6eeaba245050305043bdfdd72a5 100644 (file)
@@ -762,6 +762,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1672,
 /**/
     1671,
 /**/