summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorglepnir <glephunter@gmail.com>2024-02-11 17:52:40 +0100
committerChristian Brabandt <cb@256bit.org>2024-02-11 17:52:40 +0100
commit0d3c0a66a39570cbc52b9536604c39e324b989b3 (patch)
tree786f5f41c0f365793c89dbf60c1457cabab492cb /src
parentefabd7c8d4f733350364356b8950a11f013aec49 (diff)
patch 9.1.0098: CompletionChanged not triggered when new leader added without matchesv9.1.0098
Problem: CompletionChanged not triggered when new leader added causing no matching item in the completion menu Solution: When completion is active but no items matched still trigger CompletChanged event (glepnir) closes: #13982 Signed-off-by: glepnir <glephunter@gmail.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
Diffstat (limited to 'src')
-rw-r--r--src/insexpand.c6
-rw-r--r--src/testdir/test_popup.vim6
-rw-r--r--src/version.c2
3 files changed, 14 insertions, 0 deletions
diff --git a/src/insexpand.c b/src/insexpand.c
index d712181bcd..68e970a71a 100644
--- a/src/insexpand.c
+++ b/src/insexpand.c
@@ -1350,7 +1350,13 @@ ins_compl_show_pum(void)
}
if (compl_match_array == NULL)
+ {
+#ifdef FEAT_EVAL
+ if (compl_started && has_completechanged())
+ trigger_complete_changed_event(cur);
+#endif
return;
+ }
// In Replace mode when a $ is displayed at the end of the line only
// part of the screen would be updated. We do need to redraw here.
diff --git a/src/testdir/test_popup.vim b/src/testdir/test_popup.vim
index 879d1fa3e5..f5cb8b2a19 100644
--- a/src/testdir/test_popup.vim
+++ b/src/testdir/test_popup.vim
@@ -1139,6 +1139,10 @@ func Test_CompleteChanged()
let g:event = copy(v:event)
let g:item = get(v:event, 'completed_item', {})
let g:word = get(g:item, 'word', v:null)
+ let l:line = getline('.')
+ if g:word == v:null && l:line == "bc"
+ let g:word = l:line
+ endif
endfunction
augroup AAAAA_Group
au!
@@ -1158,6 +1162,8 @@ func Test_CompleteChanged()
call assert_equal(v:null, g:word)
call feedkeys("a\<C-N>\<C-N>\<C-N>\<C-N>\<C-P>", 'tx')
call assert_equal('foobar', g:word)
+ call feedkeys("S\<C-N>bc", 'tx')
+ call assert_equal("bc", g:word)
func Omni_test(findstart, base)
if a:findstart
diff --git a/src/version.c b/src/version.c
index 98cb8bc9bb..7fd6982f3f 100644
--- a/src/version.c
+++ b/src/version.c
@@ -705,6 +705,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 98,
+/**/
97,
/**/
96,