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:
committed by
Christian Brabandt
parent
efd83d441b
commit
126731c8fd
@ -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:
|
||||||
|
|||||||
@ -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
|
||||||
|
|||||||
@ -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,
|
||||||
/**/
|
/**/
|
||||||
|
|||||||
Reference in New Issue
Block a user