summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2016-07-09 21:49:03 +0200
committerBram Moolenaar <Bram@vim.org>2016-07-09 21:49:03 +0200
commit67081e50616ae9546621072c5eaaa59bd0a4bed7 (patch)
treeea59d44c53e118e3c4faf8a79576755d0bbdcd2c
parent063b9d15abea041a5bfff3ffc4e219e26fd1d4fa (diff)
downloadvim-git-7.4.2013.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.c1
-rw-r--r--src/testdir/test_popup.vim61
-rw-r--r--src/version.c2
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,