patch 9.1.1608: No command-line completion for :unsilent {command}

Problem:  No command-line completion for :unsilent {command}.
Solution: Add missing command arg completion (Doug Kearns).
          (author)

Add completion tests for all command modifiers.

closes: #17524

Signed-off-by: Doug Kearns <dougkearns@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
Doug Kearns
2025-08-08 13:34:04 +02:00
committed by Christian Brabandt
parent efd83d441b
commit 126731c8fd
3 changed files with 27 additions and 12 deletions

View File

@ -2361,6 +2361,7 @@ set_context_by_cmdname(
case CMD_tab: case CMD_tab:
case CMD_tabdo: case CMD_tabdo:
case CMD_topleft: case CMD_topleft:
case CMD_unsilent:
case CMD_verbose: case CMD_verbose:
case CMD_vertical: case CMD_vertical:
case CMD_windo: case CMD_windo:

View File

@ -1,20 +1,29 @@
" Test for all command modifiers in " Test for all command modifiers in
def s:memoize_cmdmods(): func(): list<string>
var cmdmods: list<string> = []
return () => {
if empty(cmdmods)
edit ../ex_docmd.c
var top = search('^static cmdmod_info_T cmdmod_info_tab[') + 1
var bot = search('^};.*\/\/ cmdmod_info_tab') - 1
var lines = getline(top, bot)
cmdmods = lines->map((_, v) => substitute(v, '.*"\(\k*\)".*', '\1', ''))
bwipe!
endif
return cmdmods
}
enddef
let s:get_cmdmods = s:memoize_cmdmods()
def Test_cmdmods_array() def Test_cmdmods_array()
# Get all the command modifiers from ex_cmds.h. # Get all the command modifiers from ex_cmds.h.
var lines = readfile('../ex_cmds.h')->filter((_, l) => l =~ 'ex_wrongmodifier,') var lines = readfile('../ex_cmds.h')->filter((_, l) => l =~ 'ex_wrongmodifier,')
var cmds = lines->map((_, v) => substitute(v, '.*"\(\k*\)".*', '\1', '')) var cmds = lines->map((_, v) => substitute(v, '.*"\(\k*\)".*', '\1', ''))
# :hide is both a command and a modifier # :hide is both a command and a modifier
cmds->extend(['hide']) cmds->extend(['hide'])
# Get the entries of cmdmod_info_tab[] in ex_docmd.c var mods = s:get_cmdmods()
edit ../ex_docmd.c
var top = search('^static cmdmod_info_T cmdmod_info_tab[') + 1
var bot = search('^};.*\/\/ cmdmod_info_tab') - 1
lines = getline(top, bot)
var mods = lines->map((_, v) => substitute(v, '.*"\(\k*\)".*', '\1', ''))
# Add the other commands that use ex_wrongmodifier. # Add the other commands that use ex_wrongmodifier.
mods->extend([ mods->extend([
'endclass', 'endclass',
@ -73,10 +82,13 @@ def Test_keep_cmdmods_names()
enddef enddef
def Test_cmdmod_completion() def Test_cmdmod_completion()
assert_equal('edit', getcompletion('keepalt ed', 'cmdline')[0]) for mod in s:get_cmdmods()
assert_equal('edit', getcompletion('keepjumps ed', 'cmdline')[0]) var cmd = $'{mod} ed'
assert_equal('edit', getcompletion('keepmarks ed', 'cmdline')[0]) if mod == 'filter'
assert_equal('edit', getcompletion('keeppatterns ed', 'cmdline')[0]) cmd = $'{mod} /pattern/ ed'
endif
assert_equal('edit', getcompletion(cmd, 'cmdline')[0])
endfor
enddef enddef
" vim: shiftwidth=2 sts=2 expandtab " vim: shiftwidth=2 sts=2 expandtab

View File

@ -719,6 +719,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
1608,
/**/ /**/
1607, 1607,
/**/ /**/