diff options
author | Jan Edmund Lazo <jan.lazo@mail.utoronto.ca> | 2019-06-06 19:59:17 -0400 |
---|---|---|
committer | Jan Edmund Lazo <jan.lazo@mail.utoronto.ca> | 2019-06-06 22:43:48 -0400 |
commit | bb4e0deaf924490f792433becbe0629fe0ce5b4e (patch) | |
tree | f9e8a7bdeed8289eeff0ab2aad5adc598751163c /src/nvim/quickfix.c | |
parent | 7d345a7294a24e8270bf608dd87d1ebd8c897432 (diff) | |
download | rneovim-bb4e0deaf924490f792433becbe0629fe0ce5b4e.tar.gz rneovim-bb4e0deaf924490f792433becbe0629fe0ce5b4e.tar.bz2 rneovim-bb4e0deaf924490f792433becbe0629fe0ce5b4e.zip |
vim-patch:8.1.0060: crash when autocommands delete the current buffer
Problem: Crash when autocommands delete the current buffer. (Dominique
Pelle)
Solution: Check that autocommands don't change the buffer.
https://github.com/vim/vim/commit/600323b4ef51a58a8e800d8ca469383a3c911db7
Diffstat (limited to 'src/nvim/quickfix.c')
-rw-r--r-- | src/nvim/quickfix.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/src/nvim/quickfix.c b/src/nvim/quickfix.c index b70e881d33..03f909f634 100644 --- a/src/nvim/quickfix.c +++ b/src/nvim/quickfix.c @@ -5255,8 +5255,14 @@ void ex_cbuffer(exarg_T *eap) qf_list_changed(qi, qi->qf_curlist); } if (au_name != NULL) { + const buf_T *const curbuf_old = curbuf; apply_autocmds(EVENT_QUICKFIXCMDPOST, (char_u *)au_name, curbuf->b_fname, true, curbuf); + if (curbuf != curbuf_old) { + // Autocommands changed buffer, don't jump now, "qi" may + // be invalid. + res = 0; + } } if (res > 0 && (eap->cmdidx == CMD_cbuffer || eap->cmdidx == CMD_lbuffer)) { |