diff options
author | Bram Moolenaar <Bram@vim.org> | 2021-10-04 23:13:13 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2021-10-04 23:13:13 +0100 |
commit | d3710cf01ef6ab1b2f233866ff01dab76686f642 (patch) | |
tree | 28e2058098833e3f613c0ecf75733ee4e0cc1627 /src/buffer.c | |
parent | 08d7b1c82866a61b61a55e55b6c190dba04e54ea (diff) | |
download | vim-git-d3710cf01ef6ab1b2f233866ff01dab76686f642.tar.gz |
patch 8.2.3476: renaming a buffer on startup may cause using freed memoryv8.2.3476
Problem: Renaming a buffer on startup may cause using freed memory.
Solution: Check if the buffer is used in a window. (closes #8955)
Diffstat (limited to 'src/buffer.c')
-rw-r--r-- | src/buffer.c | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/src/buffer.c b/src/buffer.c index 5616487da..bcbdf839d 100644 --- a/src/buffer.c +++ b/src/buffer.c @@ -3399,7 +3399,17 @@ setfname( #endif if (obuf != NULL && obuf != buf) { - if (obuf->b_ml.ml_mfp != NULL) // it's loaded, fail + win_T *win; + tabpage_T *tab; + int in_use = FALSE; + + // during startup a window may use a buffer that is not loaded yet + FOR_ALL_TAB_WINDOWS(tab, win) + if (win->w_buffer == obuf) + in_use = TRUE; + + // it's loaded or used in a window, fail + if (obuf->b_ml.ml_mfp != NULL || in_use) { if (message) emsg(_("E95: Buffer with this name already exists")); |