summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2018-04-23 21:29:48 +0200
committerBram Moolenaar <Bram@vim.org>2018-04-23 21:29:48 +0200
commit3b9474b4ad4d85b5396f7f641b436f193dc9d486 (patch)
tree32e8c88604f6da2d38708363437f760732444462
parent6537c421bb626ee92a2487a543e6287d33461bd0 (diff)
downloadvim-git-3b9474b4ad4d85b5396f7f641b436f193dc9d486.tar.gz
patch 8.0.1750: crash when clearing loccation list in autocommandv8.0.1750
Problem: Crash when clearing loccation list in autocommand. Solution: Check if "qi" equals "ql_info". (Yegappan Lakshmanan)
-rw-r--r--src/quickfix.c6
-rw-r--r--src/testdir/test_quickfix.vim14
-rw-r--r--src/version.c2
3 files changed, 17 insertions, 5 deletions
diff --git a/src/quickfix.c b/src/quickfix.c
index 39e3913c0..6142825e3 100644
--- a/src/quickfix.c
+++ b/src/quickfix.c
@@ -5897,7 +5897,6 @@ ex_helpgrep(exarg_T *eap)
char_u *lang;
#endif
qf_info_T *qi = &ql_info;
- qf_info_T *save_qi;
int new_qi = FALSE;
win_T *wp;
char_u *au_name = NULL;
@@ -5951,9 +5950,6 @@ ex_helpgrep(exarg_T *eap)
}
}
- /* Autocommands may change the list. Save it for later comparison */
- save_qi = qi;
-
regmatch.regprog = vim_regcomp(eap->arg, RE_MAGIC + RE_STRING);
regmatch.rm_ic = FALSE;
if (regmatch.regprog != NULL)
@@ -6086,7 +6082,7 @@ ex_helpgrep(exarg_T *eap)
{
apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
curbuf->b_fname, TRUE, curbuf);
- if (!new_qi && qi != save_qi && qf_find_buf(qi) == NULL)
+ if (!new_qi && qi != &ql_info && qf_find_buf(qi) == NULL)
/* autocommands made "qi" invalid */
return;
}
diff --git a/src/testdir/test_quickfix.vim b/src/testdir/test_quickfix.vim
index b0e14e6ad..12bfe3227 100644
--- a/src/testdir/test_quickfix.vim
+++ b/src/testdir/test_quickfix.vim
@@ -3175,3 +3175,17 @@ func Test_vimgrep_autocmd()
call delete('Xtest2.txt')
call setqflist([], 'f')
endfunc
+
+" The following test used to crash Vim
+func Test_lhelpgrep_autocmd()
+ lhelpgrep quickfix
+ autocmd QuickFixCmdPost * call setloclist(0, [], 'f')
+ lhelpgrep buffer
+ call assert_equal('help', &filetype)
+ call assert_equal(0, getloclist(0, {'nr' : '$'}).nr)
+ lhelpgrep tabpage
+ call assert_equal('help', &filetype)
+ call assert_equal(1, getloclist(0, {'nr' : '$'}).nr)
+ au! QuickFixCmdPost
+ new | only
+endfunc
diff --git a/src/version.c b/src/version.c
index 55892048d..123db5b67 100644
--- a/src/version.c
+++ b/src/version.c
@@ -762,6 +762,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1750,
+/**/
1749,
/**/
1748,