summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2020-02-22 22:45:55 +0100
committerBram Moolenaar <Bram@vim.org>2020-02-22 22:45:55 +0100
commit0c81d1b11278b2d962aa6fbb4aa974dab97be59d (patch)
tree25ab018d04c0f46216f2321ad47faa1fc9aaed32
parentb654103ad1e379348616f354272db86804ab4bdb (diff)
patch 8.2.0302: setting 'term' may cause error in TermChanged autocommandv8.2.0302
Problem: Setting 'term' may cause error in TermChanged autocommand. Solution: Use aucmd_prepbuf() to switch to the buffer where the autocommand is to be executed. (closes #5682)
-rw-r--r--src/term.c13
-rw-r--r--src/testdir/test_autocmd.vim20
-rw-r--r--src/version.c2
3 files changed, 30 insertions, 5 deletions
diff --git a/src/term.c b/src/term.c
index d269eb83c0..e9a9004a2d 100644
--- a/src/term.c
+++ b/src/term.c
@@ -2071,21 +2071,24 @@ set_termname(char_u *term)
check_map_keycodes(); // check mappings for terminal codes used
{
- bufref_T old_curbuf;
+ buf_T *buf;
+ aco_save_T aco;
/*
* Execute the TermChanged autocommands for each buffer that is
* loaded.
*/
- set_bufref(&old_curbuf, curbuf);
- FOR_ALL_BUFFERS(curbuf)
+ FOR_ALL_BUFFERS(buf)
{
if (curbuf->b_ml.ml_mfp != NULL)
+ {
+ aucmd_prepbuf(&aco, buf);
apply_autocmds(EVENT_TERMCHANGED, NULL, NULL, FALSE,
curbuf);
+ // restore curwin/curbuf and a few other things
+ aucmd_restbuf(&aco);
+ }
}
- if (bufref_valid(&old_curbuf))
- curbuf = old_curbuf.br_buf;
}
}
diff --git a/src/testdir/test_autocmd.vim b/src/testdir/test_autocmd.vim
index a16329b8cd..70e96087cf 100644
--- a/src/testdir/test_autocmd.vim
+++ b/src/testdir/test_autocmd.vim
@@ -2382,4 +2382,24 @@ func Test_FileChangedRO_winclose()
augroup! FileChangedROTest
endfunc
+func LogACmd()
+ call add(g:logged, line('$'))
+endfunc
+
+func Test_TermChanged()
+ enew!
+ tabnew
+ call setline(1, ['a', 'b', 'c', 'd'])
+ $
+ au TermChanged * call LogACmd()
+ let g:logged = []
+ let term_save = &term
+ set term=xterm
+ call assert_equal([1, 4], g:logged)
+
+ au! TermChanged
+ let &term = term_save
+ bwipe!
+endfunc
+
" vim: shiftwidth=2 sts=2 expandtab
diff --git a/src/version.c b/src/version.c
index cda4a81649..96ef2c1037 100644
--- a/src/version.c
+++ b/src/version.c
@@ -739,6 +739,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 302,
+/**/
301,
/**/
300,