diff options
author | Björn Linse <bjorn.linse@gmail.com> | 2018-12-12 11:01:46 +0100 |
---|---|---|
committer | Björn Linse <bjorn.linse@gmail.com> | 2018-12-12 15:31:52 +0100 |
commit | 5f82889be78856ee189c254110bf087dba918b23 (patch) | |
tree | 936600d127e522fef943cdf44090dd76581a8ab2 /src | |
parent | 6c602be33a5176fd1101e8cff45dd2a85b0e512e (diff) | |
download | rneovim-5f82889be78856ee189c254110bf087dba918b23.tar.gz rneovim-5f82889be78856ee189c254110bf087dba918b23.tar.bz2 rneovim-5f82889be78856ee189c254110bf087dba918b23.zip |
cmdline: support v:event in CmdlineChanged
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/ex_getln.c | 34 |
1 files changed, 29 insertions, 5 deletions
diff --git a/src/nvim/ex_getln.c b/src/nvim/ex_getln.c index 447123e45d..bfc32887ca 100644 --- a/src/nvim/ex_getln.c +++ b/src/nvim/ex_getln.c @@ -1805,11 +1805,35 @@ static int empty_pattern(char_u *p) static int command_line_changed(CommandLineState *s) { // Trigger CmdlineChanged autocommands. - char firstcbuf[2]; - firstcbuf[0] = s->firstc > 0 ? s->firstc : '-'; - firstcbuf[1] = 0; - apply_autocmds(EVENT_CMDLINECHANGED, (char_u *)firstcbuf, (char_u *)firstcbuf, - false, curbuf); + if (has_event(EVENT_CMDLINECHANGED)) { + TryState tstate; + Error err = ERROR_INIT; + bool tl_ret = true; + dict_T *dict = get_vim_var_dict(VV_EVENT); + + char firstcbuf[2]; + firstcbuf[0] = s->firstc > 0 ? s->firstc : '-'; + firstcbuf[1] = 0; + + // set v:event to a dictionary with information about the commandline + tv_dict_add_str(dict, S_LEN("cmdtype"), firstcbuf); + tv_dict_add_nr(dict, S_LEN("cmdlevel"), ccline.level); + tv_dict_set_keys_readonly(dict); + try_enter(&tstate); + + apply_autocmds(EVENT_CMDLINECHANGED, (char_u *)firstcbuf, + (char_u *)firstcbuf, false, curbuf); + tv_dict_clear(dict); + + tl_ret = try_leave(&tstate, &err); + if (!tl_ret && ERROR_SET(&err)) { + msg_putchar('\n'); + msg_printf_attr(HL_ATTR(HLF_E)|MSG_HIST, (char *)e_autocmd_err, err.msg); + api_clear_error(&err); + redrawcmd(); + } + tl_ret = true; + } // 'incsearch' highlighting. if (p_is && !cmd_silent && (s->firstc == '/' || s->firstc == '?')) { |