patch 9.1.1351: Return value of getcmdline() inconsistent in CmdlineLeavePre

Problem:  Return value of getcmdline() inconsistent in CmdlineLeavePre
          when leaving cmdline in different ways (after v9.1.1329).
Solution: Trigger CmdlineLeavePre before calling abandon_cmdline() so
          that getcmdline() can return the command line (zeertzjq).

closes: #17218

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Girish Palya <girishji@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
zeertzjq
2025-04-28 18:04:00 +02:00
committed by Christian Brabandt
parent 6220bbad4e
commit 9240369774
3 changed files with 27 additions and 9 deletions

View File

@ -2560,6 +2560,9 @@ cmdline_changed:
}
returncmd:
// Trigger CmdlineLeavePre autocommands if not already triggered.
if (!event_cmdlineleavepre_triggered)
trigger_cmd_autocmd(cmdline_type, EVENT_CMDLINELEAVEPRE);
#ifdef FEAT_RIGHTLEFT
cmdmsg_rl = FALSE;
@ -2616,10 +2619,6 @@ returncmd:
if (some_key_typed)
need_wait_return = FALSE;
// Trigger CmdlineLeavePre autocommands if not already triggered.
if (!event_cmdlineleavepre_triggered)
trigger_cmd_autocmd(cmdline_type, EVENT_CMDLINELEAVEPRE);
// Trigger CmdlineLeave autocommands.
trigger_cmd_autocmd(cmdline_type, EVENT_CMDLINELEAVE);

View File

@ -2066,11 +2066,28 @@ func Test_Cmdline_Trigger()
call assert_equal('CmdlineLeavePre', g:log)
call assert_equal('CmdlineLeave', g:log2)
let g:count = 0
autocmd CmdlineLeavePre * let g:count += 1
call feedkeys(":let c = input('? ')\<cr>B\<cr>", "tx")
call assert_equal(2, g:count)
unlet! g:count
autocmd CmdlineLeavePre * let g:cmdline += [getcmdline()]
for end_keys in ["\<CR>", "\<NL>", "\<kEnter>", "\<C-C>", "\<Esc>",
\ "\<C-\>\<C-N>", "\<C-\>\<C-G>"]
let g:cmdline = []
let g:log = ''
let g:log2 = ''
call assert_equal('', g:log)
let keys = $':echo "hello"{end_keys}'
let msg = keytrans(keys)
call feedkeys(keys, "tx")
call assert_equal(['echo "hello"'], g:cmdline, msg)
call assert_equal('CmdlineLeavePre', g:log, msg)
call assert_equal('CmdlineLeave', g:log2, msg)
endfor
let g:cmdline = []
call feedkeys(":let c = input('? ')\<cr>ABCDE\<cr>", "tx")
call assert_equal(["let c = input('? ')", 'ABCDE'], g:cmdline)
au! CmdlineLeavePre
unlet! g:cmdline
unlet! g:log
unlet! g:log2
bw!

View File

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