patch 8.2.0302: setting 'term' may cause error in TermChanged autocommand
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)
diff --git a/src/term.c b/src/term.c
index d269eb8..e9a9004 100644
--- a/src/term.c
+++ b/src/term.c
@@ -2071,21 +2071,24 @@
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;
}
}