diff options
author | Björn Linse <bjorn.linse@gmail.com> | 2018-12-12 21:40:10 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-12-12 21:40:10 +0100 |
commit | 2f3a18695e41ec6afa98194b22d064ec81154dbf (patch) | |
tree | 936600d127e522fef943cdf44090dd76581a8ab2 /src/nvim/ex_getln.c | |
parent | b9a441eb78349088d54eaa6e12c35aa06f0b1c6b (diff) | |
parent | 5f82889be78856ee189c254110bf087dba918b23 (diff) | |
download | rneovim-2f3a18695e41ec6afa98194b22d064ec81154dbf.tar.gz rneovim-2f3a18695e41ec6afa98194b22d064ec81154dbf.tar.bz2 rneovim-2f3a18695e41ec6afa98194b22d064ec81154dbf.zip |
Merge pull request #7946 from bfredl/vim-8.0.1445
implement CmdlineChanged: vim-patch:8.0.1445 + nvim specific v:event stuff
Diffstat (limited to 'src/nvim/ex_getln.c')
-rw-r--r-- | src/nvim/ex_getln.c | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/src/nvim/ex_getln.c b/src/nvim/ex_getln.c index 19a52c913a..bfc32887ca 100644 --- a/src/nvim/ex_getln.c +++ b/src/nvim/ex_getln.c @@ -1804,6 +1804,37 @@ static int empty_pattern(char_u *p) static int command_line_changed(CommandLineState *s) { + // Trigger CmdlineChanged autocommands. + 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 == '?')) { pos_T end_pos; |