diff --git a/src/nvim/insexpand.c b/src/nvim/insexpand.c index 9f26e44eea..8ec058a98f 100644 --- a/src/nvim/insexpand.c +++ b/src/nvim/insexpand.c @@ -4936,12 +4936,14 @@ static int ins_compl_get_exp(pos_T *ini) } may_trigger_modechanged(); - if (is_nearest_active() && !ins_compl_has_preinsert()) { - sort_compl_match_list(cp_compare_nearest); - } + if (match_count > 0) { + if (is_nearest_active() && !ins_compl_has_preinsert()) { + sort_compl_match_list(cp_compare_nearest); + } - if ((get_cot_flags() & kOptCotFlagFuzzy) && ins_compl_leader_len() > 0) { - ins_compl_fuzzy_sort(); + if ((get_cot_flags() & kOptCotFlagFuzzy) && ins_compl_leader_len() > 0) { + ins_compl_fuzzy_sort(); + } } return match_count; diff --git a/test/old/testdir/test_ins_complete.vim b/test/old/testdir/test_ins_complete.vim index 749c8cc851..59c876518a 100644 --- a/test/old/testdir/test_ins_complete.vim +++ b/test/old/testdir/test_ins_complete.vim @@ -3816,6 +3816,22 @@ func Test_complete_fuzzy_collect() set completeopt& cfc& cpt& endfunc +" Issue #18752 +func Test_complete_fuzzy_collect_multiwin() + new + set completefuzzycollect=keyword,files,whole_line + set completeopt=fuzzy + + vnew + call setline(1, ["completeness,", "compatibility", "Composite", "Omnipotent"]) + wincmd p + call feedkeys("Somp\\0", 'tx!') + call assert_equal('Omnipotent', getline('.')) + + bw! + set completeopt& cfc& +endfunc + func Test_cfc_with_longest() new set completefuzzycollect=keyword,files,whole_line