diff options
author | Bram Moolenaar <Bram@vim.org> | 2016-07-09 21:49:03 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2016-07-09 21:49:03 +0200 |
commit | 67081e50616ae9546621072c5eaaa59bd0a4bed7 (patch) | |
tree | ea59d44c53e118e3c4faf8a79576755d0bbdcd2c | |
parent | 063b9d15abea041a5bfff3ffc4e219e26fd1d4fa (diff) | |
download | vim-git-67081e50616ae9546621072c5eaaa59bd0a4bed7.tar.gz |
patch 7.4.2013v7.4.2013
Problem: Using "noinsert" in 'completeopt' breaks redo.
Solution: Set compl_curr_match. (Shougo, closes #874)
-rw-r--r-- | src/edit.c | 1 | ||||
-rw-r--r-- | src/testdir/test_popup.vim | 61 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 44 insertions, 20 deletions
diff --git a/src/edit.c b/src/edit.c index 234e03dff..47c24f9d2 100644 --- a/src/edit.c +++ b/src/edit.c @@ -4680,6 +4680,7 @@ ins_compl_insert(void) EMPTY_IF_NULL(compl_shown_match->cp_text[CPT_INFO])); } set_vim_var_dict(VV_COMPLETED_ITEM, dict); + compl_curr_match = compl_shown_match; } /* diff --git a/src/testdir/test_popup.vim b/src/testdir/test_popup.vim index a5673c930..cefaee26a 100644 --- a/src/testdir/test_popup.vim +++ b/src/testdir/test_popup.vim @@ -1,6 +1,5 @@ " Test for completion menu -inoremap <F5> <C-R>=ListMonths()<CR> let g:months = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] let g:setting = '' @@ -13,23 +12,45 @@ func ListMonths() endfunc func! Test_popup_completion_insertmode() - new - call feedkeys("a\<f5>\<down>\<enter>\<esc>", 'tx') - call assert_equal('February', getline(1)) - %d - let g:setting = 'noinsertmode' - call feedkeys("a\<f5>\<down>\<enter>\<esc>", 'tx') - call assert_equal('February', getline(1)) - call assert_false(pumvisible()) - %d - let g:setting = '' - call feedkeys("a\<f5>". repeat("\<c-n>",12)."\<enter>\<esc>", 'tx') - call assert_equal('', getline(1)) - %d - call feedkeys("a\<f5>\<c-p>\<enter>\<esc>", 'tx') - call assert_equal('', getline(1)) - %d - call feedkeys("a\<f5>\<c-p>\<c-p>\<enter>\<esc>", 'tx') - call assert_equal('December', getline(1)) - bwipe! + new + inoremap <F5> <C-R>=ListMonths()<CR> + + call feedkeys("a\<f5>\<down>\<enter>\<esc>", 'tx') + call assert_equal('February', getline(1)) + %d + let g:setting = 'noinsertmode' + call feedkeys("a\<f5>\<down>\<enter>\<esc>", 'tx') + call assert_equal('February', getline(1)) + call assert_false(pumvisible()) + %d + let g:setting = '' + call feedkeys("a\<f5>". repeat("\<c-n>",12)."\<enter>\<esc>", 'tx') + call assert_equal('', getline(1)) + %d + call feedkeys("a\<f5>\<c-p>\<enter>\<esc>", 'tx') + call assert_equal('', getline(1)) + %d + call feedkeys("a\<f5>\<c-p>\<c-p>\<enter>\<esc>", 'tx') + call assert_equal('December', getline(1)) + + bwipe! + iunmap <F5> +endfunc + +function! ComplTest() abort + call complete(1, ['source', 'soundfold']) + return '' +endfunction + +func Test_noinsert_complete() + new + set completeopt+=noinsert + inoremap <F5> <C-R>=ComplTest()<CR> + call feedkeys("i\<F5>soun\<CR>\<CR>\<ESC>.", 'tx') + call assert_equal('soundfold', getline(1)) + call assert_equal('soundfold', getline(2)) + + bwipe! + set completeopt-=noinsert + iunmap <F5> endfunc diff --git a/src/version.c b/src/version.c index 39331b6c1..f1da7b31f 100644 --- a/src/version.c +++ b/src/version.c @@ -759,6 +759,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 2013, +/**/ 2012, /**/ 2011, |