vim-patch:8.0.0220: highlight completion misses some values #8013

Problem:    Completion for :match does not show "none" and other missing
            highlight names.
Solution:   Skip over cleared entries before checking the index to be at the
            end.
15eedf1d62
This commit is contained in:
ckelsel 2018-02-15 22:50:41 +08:00 committed by Justin M. Keyes
parent 544cef0155
commit b615192a37
2 changed files with 47 additions and 23 deletions

View File

@ -7762,10 +7762,18 @@ static void highlight_list_two(int cnt, int attr)
* Function given to ExpandGeneric() to obtain the list of group names. * Function given to ExpandGeneric() to obtain the list of group names.
* Also used for synIDattr() function. * Also used for synIDattr() function.
*/ */
const char *get_highlight_name(expand_T *const xp, const int idx) const char *get_highlight_name(expand_T *const xp, int idx)
FUNC_ATTR_WARN_UNUSED_RESULT FUNC_ATTR_WARN_UNUSED_RESULT
{ {
// TODO(justinmk): 'xp' is unused if (idx < 0) {
return NULL;
}
// Items are never removed from the table, skip the ones that were cleared.
while (idx < highlight_ga.ga_len && HL_TABLE()[idx].sg_cleared) {
idx++;
}
if (idx == highlight_ga.ga_len && include_none != 0) { if (idx == highlight_ga.ga_len && include_none != 0) {
return "none"; return "none";
} else if (idx == highlight_ga.ga_len + include_none } else if (idx == highlight_ga.ga_len + include_none
@ -7777,20 +7785,10 @@ const char *get_highlight_name(expand_T *const xp, const int idx)
} else if (idx == highlight_ga.ga_len + include_none + include_default + 1 } else if (idx == highlight_ga.ga_len + include_none + include_default + 1
&& include_link != 0) { && include_link != 0) {
return "clear"; return "clear";
} else if (idx < 0) { } else if (idx >= highlight_ga.ga_len) {
return NULL; return NULL;
} }
return (const char *)HL_TABLE()[idx].sg_name;
// Items are never removed from the table, skip the ones that were cleared.
int current_idx = idx;
while (current_idx < highlight_ga.ga_len
&& HL_TABLE()[current_idx].sg_cleared) {
current_idx++;
}
if (current_idx >= highlight_ga.ga_len) {
return NULL;
}
return (const char *)HL_TABLE()[current_idx].sg_name;
} }
color_name_table_T color_name_table[] = { color_name_table_T color_name_table[] = {

View File

@ -46,8 +46,34 @@ func Test_map_completion()
call assert_equal('"map <silent> <special>', getreg(':')) call assert_equal('"map <silent> <special>', getreg(':'))
endfunc endfunc
func Test_match_completion()
if !has('cmdline_compl')
return
endif
hi Aardig ctermfg=green
call feedkeys(":match \<Tab>\<Home>\"\<CR>", 'xt')
call assert_equal('"match Aardig', getreg(':'))
call feedkeys(":match \<S-Tab>\<Home>\"\<CR>", 'xt')
call assert_equal('"match none', getreg(':'))
endfunc
func Test_highlight_completion()
if !has('cmdline_compl')
return
endif
hi Aardig ctermfg=green
call feedkeys(":hi \<Tab>\<Home>\"\<CR>", 'xt')
call assert_equal('"hi Aardig', getreg(':'))
call feedkeys(":hi li\<S-Tab>\<Home>\"\<CR>", 'xt')
call assert_equal('"hi link', getreg(':'))
call feedkeys(":hi d\<S-Tab>\<Home>\"\<CR>", 'xt')
call assert_equal('"hi default', getreg(':'))
call feedkeys(":hi c\<S-Tab>\<Home>\"\<CR>", 'xt')
call assert_equal('"hi clear', getreg(':'))
endfunc
func Test_expr_completion() func Test_expr_completion()
if !(has('cmdline_compl') && has('eval')) if !has('cmdline_compl')
return return
endif endif
for cmd in [ for cmd in [