]> granicus.if.org Git - vim/commitdiff
patch 8.0.0041 v8.0.0041
authorBram Moolenaar <Bram@vim.org>
Sun, 16 Oct 2016 13:35:47 +0000 (15:35 +0200)
committerBram Moolenaar <Bram@vim.org>
Sun, 16 Oct 2016 13:35:47 +0000 (15:35 +0200)
Problem:    When using Insert mode completion but not actually inserting
            anything an undo item is still created. (Tommy Allen)
Solution:   Do not call stop_arrow() when not inserting anything.

src/edit.c
src/testdir/test_popup.vim
src/version.c

index d763b53183501758907e71a7ba462c440996e272..53b43c485adf9bca79557f0d7ad33c4001cfb93d 100644 (file)
@@ -2799,9 +2799,6 @@ set_completion(colnr_T startcol, list_T *list)
        ins_compl_prep(' ');
     ins_compl_clear();
 
-    if (stop_arrow() == FAIL)
-       return;
-
     compl_direction = FORWARD;
     if (startcol > curwin->w_cursor.col)
        startcol = curwin->w_cursor.col;
@@ -3876,7 +3873,8 @@ ins_compl_prep(int c)
                /* put the cursor on the last char, for 'tw' formatting */
                if (prev_col > 0)
                    dec_cursor();
-               if (stop_arrow() == OK)
+               /* only format when something was inserted */
+               if (!arrow_used && !ins_need_undo)
                    insertchar(NUL, 0, -1);
                if (prev_col > 0
                             && ml_get_curline()[curwin->w_cursor.col] != NUL)
index 7cb0e10aa1d669e5db12674006b32adc8bd4fc37..38459b323e54effacce1bd88dc70d3c48115f7be 100644 (file)
@@ -378,7 +378,7 @@ func DummyCompleteFour(findstart, base)
   endif
 endfunc
 
-:"Test that 'completefunc' works when it's OK.
+Test that 'completefunc' works when it's OK.
 func Test_omnifunc_with_check()
   new
   setlocal omnifunc=DummyCompleteFour
@@ -400,4 +400,30 @@ func Test_omnifunc_with_check()
   q!
 endfunc
 
+function UndoComplete()
+  call complete(1, ['January', 'February', 'March',
+        \ 'April', 'May', 'June', 'July', 'August', 'September',
+        \ 'October', 'November', 'December'])
+  return ''
+endfunc
+
+" Test that no undo item is created when no completion is inserted
+func Test_complete_no_undo()
+  set completeopt=menu,preview,noinsert,noselect
+  inoremap <Right> <C-R>=UndoComplete()<CR>
+  new
+  call feedkeys("ixxx\<CR>\<CR>yyy\<Esc>k", 'xt')
+  call feedkeys("iaaa\<Esc>0", 'xt')
+  call assert_equal('aaa', getline(2))
+  call feedkeys("i\<Right>\<Esc>", 'xt')
+  call assert_equal('aaa', getline(2))
+  call feedkeys("u", 'xt')
+  call assert_equal('', getline(2))
+
+  iunmap <Right>
+  set completeopt&
+  q!
+endfunc
+
+
 " vim: shiftwidth=2 sts=2 expandtab
index e6f8f47821354953fb580fa2d134260fd71b0c18..4902d69f09d0275f778970bbd5683d5843d68561 100644 (file)
@@ -764,6 +764,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    41,
 /**/
     40,
 /**/