From: Bram Moolenaar Date: Wed, 31 Jan 2018 14:48:32 +0000 (+0100) Subject: patch 8.0.1445: cannot act on edits in the command line X-Git-Tag: v8.0.1445 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=153b704e20f9c269450a7d3ea8cafcf942579ab7;p=vim patch 8.0.1445: cannot act on edits in the command line Problem: Cannot act on edits in the command line. Solution: Add the CmdlineChanged autocommand event. (xtal8, closes #2603, closes #2524) --- diff --git a/runtime/doc/autocmd.txt b/runtime/doc/autocmd.txt index 173892cd4..4adf007e7 100644 --- a/runtime/doc/autocmd.txt +++ b/runtime/doc/autocmd.txt @@ -1,4 +1,4 @@ -*autocmd.txt* For Vim version 8.0. Last change: 2017 Dec 17 +*autocmd.txt* For Vim version 8.0. Last change: 2018 Jan 31 VIM REFERENCE MANUAL by Bram Moolenaar @@ -500,6 +500,13 @@ CmdUndefined When a user command is used but it isn't command is defined. An alternative is to always define the user command and have it invoke an autoloaded function. See |autoload|. + *CmdlineChanged* +CmdlineChanged After a change was made to the text inside + command line. Be careful not to mess up the + command line, it may cause Vim to lock up. + is set to a single character, + indicating the type of command-line. + |cmdwin-char| *CmdlineEnter* CmdlineEnter After moving the cursor to the command line, where the user can type a command or search diff --git a/src/ex_getln.c b/src/ex_getln.c index 421c6b7d5..837d29998 100644 --- a/src/ex_getln.c +++ b/src/ex_getln.c @@ -1951,6 +1951,11 @@ cmdline_not_changed: #endif cmdline_changed: +#ifdef FEAT_AUTOCMD + /* Trigger CmdlineChanged autocommands. */ + trigger_cmd_autocmd(cmdline_type, EVENT_CMDLINECHANGED); +#endif + #ifdef FEAT_SEARCH_EXTRA /* * 'incsearch' highlighting. diff --git a/src/fileio.c b/src/fileio.c index ba9ec9ec0..fb5af6446 100644 --- a/src/fileio.c +++ b/src/fileio.c @@ -7786,6 +7786,7 @@ static struct event_name {"BufWritePost", EVENT_BUFWRITEPOST}, {"BufWritePre", EVENT_BUFWRITEPRE}, {"BufWriteCmd", EVENT_BUFWRITECMD}, + {"CmdlineChanged", EVENT_CMDLINECHANGED}, {"CmdlineEnter", EVENT_CMDLINEENTER}, {"CmdlineLeave", EVENT_CMDLINELEAVE}, {"CmdwinEnter", EVENT_CMDWINENTER}, diff --git a/src/testdir/test_autocmd.vim b/src/testdir/test_autocmd.vim index d8fddffeb..b7d43b59a 100644 --- a/src/testdir/test_autocmd.vim +++ b/src/testdir/test_autocmd.vim @@ -812,6 +812,18 @@ func Test_QuitPre() endfunc func Test_Cmdline() + au! CmdlineChanged : let g:text = getcmdline() + let g:text = 0 + call feedkeys(":echom 'hello'\", 'xt') + call assert_equal("echom 'hello'", g:text) + au! CmdlineChanged + + au! CmdlineChanged : let g:entered = expand('') + let g:entered = 0 + call feedkeys(":echom 'hello'\", 'xt') + call assert_equal(':', g:entered) + au! CmdlineChanged + au! CmdlineEnter : let g:entered = expand('') au! CmdlineLeave : let g:left = expand('') let g:entered = 0 diff --git a/src/version.c b/src/version.c index bab773660..dad271555 100644 --- a/src/version.c +++ b/src/version.c @@ -771,6 +771,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 1445, /**/ 1444, /**/ diff --git a/src/vim.h b/src/vim.h index 4765b783b..1f9671a18 100644 --- a/src/vim.h +++ b/src/vim.h @@ -1269,6 +1269,7 @@ enum auto_event EVENT_BUFWRITEPOST, /* after writing a buffer */ EVENT_BUFWRITEPRE, /* before writing a buffer */ EVENT_BUFWRITECMD, /* write buffer using command */ + EVENT_CMDLINECHANGED, /* command line was modified*/ EVENT_CMDLINEENTER, /* after entering the command line */ EVENT_CMDLINELEAVE, /* before leaving the command line */ EVENT_CMDWINENTER, /* after entering the cmdline window */