diff --git a/src/edit.c b/src/edit.c index 47c24f9d2f..4bce8a30c7 100644 --- a/src/edit.c +++ b/src/edit.c @@ -2831,6 +2831,7 @@ set_completion(colnr_T startcol, list_T *list) } else ins_complete(Ctrl_N, FALSE); + compl_enter_selects = compl_no_insert; /* Lazily show the popup menu, unless we got interrupted. */ if (!compl_interrupted) diff --git a/src/testdir/test_popup.vim b/src/testdir/test_popup.vim index cefaee26af..ea489f9c93 100644 --- a/src/testdir/test_popup.vim +++ b/src/testdir/test_popup.vim @@ -49,8 +49,20 @@ func Test_noinsert_complete() call feedkeys("i\soun\\\.", 'tx') call assert_equal('soundfold', getline(1)) call assert_equal('soundfold', getline(2)) - bwipe! + + new + inoremap =Test() + call feedkeys("i\\\", 'tx') + call assert_equal('source', getline(1)) + bwipe! + set completeopt-=noinsert iunmap endfunc + + +function! Test() abort + call complete(1, ['source', 'soundfold']) + return '' +endfunction diff --git a/src/version.c b/src/version.c index f1da7b31f4..86c8c066e3 100644 --- a/src/version.c +++ b/src/version.c @@ -758,6 +758,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 2014, /**/ 2013, /**/