mirror of
https://github.com/neovim/neovim.git
synced 2025-09-30 23:18:33 +00:00
vim-patch:7.4.2013, vim-patch:7.4.2014
vim-patch:7.4.2013 Problem: Using "noinsert" in 'completeopt' breaks redo. Solution: Set compl_curr_match. (Shougo, closes vim/vim#874)67081e5061
vim-patch:7.4.2014 Problem: Using "noinsert" in 'completeopt' does not insert match. Solution: Set compl_enter_selects. (Shougo, closes #875)32b808a4bd
This commit is contained in:

committed by
Justin M. Keyes

parent
2cd3a2d1d8
commit
172cf079c7
@@ -2385,6 +2385,7 @@ void set_completion(colnr_T startcol, list_T *list)
|
|||||||
} else {
|
} else {
|
||||||
ins_complete(Ctrl_N, false);
|
ins_complete(Ctrl_N, false);
|
||||||
}
|
}
|
||||||
|
compl_enter_selects = compl_no_insert;
|
||||||
|
|
||||||
// Lazily show the popup menu, unless we got interrupted.
|
// Lazily show the popup menu, unless we got interrupted.
|
||||||
if (!compl_interrupted) {
|
if (!compl_interrupted) {
|
||||||
@@ -3989,6 +3990,7 @@ static void ins_compl_insert(void)
|
|||||||
dict_add_nr_str(dict, "info", 0L,
|
dict_add_nr_str(dict, "info", 0L,
|
||||||
EMPTY_IF_NULL(compl_shown_match->cp_text[CPT_INFO]));
|
EMPTY_IF_NULL(compl_shown_match->cp_text[CPT_INFO]));
|
||||||
set_vim_var_dict(VV_COMPLETED_ITEM, dict);
|
set_vim_var_dict(VV_COMPLETED_ITEM, dict);
|
||||||
|
compl_curr_match = compl_shown_match;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@@ -4,4 +4,5 @@
|
|||||||
source test_assign.vim
|
source test_assign.vim
|
||||||
source test_cursor_func.vim
|
source test_cursor_func.vim
|
||||||
source test_menu.vim
|
source test_menu.vim
|
||||||
|
source test_popup.vim
|
||||||
source test_unlet.vim
|
source test_unlet.vim
|
||||||
|
30
src/nvim/testdir/test_popup.vim
Normal file
30
src/nvim/testdir/test_popup.vim
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
" Test for completion menu
|
||||||
|
|
||||||
|
function! ComplTest() abort
|
||||||
|
call complete(1, ['source', 'soundfold'])
|
||||||
|
return ''
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! Test() 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!
|
||||||
|
|
||||||
|
new
|
||||||
|
inoremap <F5> <C-R>=Test()<CR>
|
||||||
|
call feedkeys("i\<F5>\<CR>\<ESC>", 'tx')
|
||||||
|
call assert_equal('source', getline(1))
|
||||||
|
bwipe!
|
||||||
|
|
||||||
|
set completeopt-=noinsert
|
||||||
|
iunmap <F5>
|
||||||
|
endfunc
|
@@ -261,8 +261,8 @@ static int included_patches[] = {
|
|||||||
// 2017,
|
// 2017,
|
||||||
// 2016 NA
|
// 2016 NA
|
||||||
// 2015,
|
// 2015,
|
||||||
// 2014,
|
2014,
|
||||||
// 2013,
|
2013,
|
||||||
// 2012,
|
// 2012,
|
||||||
// 2011,
|
// 2011,
|
||||||
// 2010,
|
// 2010,
|
||||||
|
Reference in New Issue
Block a user