patch 9.2.0232: fileinfo not shown after :bd of last listed buffer
Commit:
https://github.com/vim/vim/commit/3d472d86753c451ce6914f70161ffc40ee37ea96
Author: Hirohito Higashi <[email protected]>
Date: Sun Mar 22 21:41:42 2026 +0000
patch 9.2.0232: fileinfo not shown after :bd of last listed buffer
Problem: fileinfo not shown after :bd of last listed buffer
(memeplex)
Solution: Set need_fileinfo to true in empty_curbuf()
(Hirohito Higashi)
When deleting the last listed buffer with :bd, the new empty buffer's
file info (e.g. "[No Name]" --No lines in buffer--) was not displayed.
do_ecmd() only calls fileinfo() for existing buffers (oldbuf), not for
newly created empty buffers.
Set need_fileinfo in empty_curbuf() so the file info is displayed after
redraw.
fixes: #548
closes: #19802
Co-Authored-By: Claude Opus 4.6 (1M context) <[email protected]>
Signed-off-by: Hirohito Higashi <[email protected]>
Signed-off-by: Christian Brabandt <[email protected]>
diff --git a/src/buffer.c b/src/buffer.c
index fa0119785..26e3ec969 100644
--- a/src/buffer.c
+++ b/src/buffer.c
@@ -1323,6 +1323,9 @@ empty_curbuf(
close_buffer(NULL, buf, action, FALSE, FALSE);
if (!close_others)
need_fileinfo = FALSE;
+ else if (retval == OK && !shortmess(SHM_FILEINFO))
+ // do_ecmd() does not display file info for a new empty buffer.
+ need_fileinfo = TRUE;
return retval;
}
diff --git a/src/testdir/test_messages.vim b/src/testdir/test_messages.vim
index 0942fe2b8..5fa84e954 100644
--- a/src/testdir/test_messages.vim
+++ b/src/testdir/test_messages.vim
@@ -811,4 +811,28 @@ func Test_long_formatprg_no_hit_enter()
call StopVimInTerminal(buf)
endfunc
+" Test that fileinfo is shown after deleting the last listed buffer with :bd
+func Test_fileinfo_after_last_bd()
+ CheckRunVimInTerminal
+
+ let content =<< trim END
+ set shortmess-=F
+ edit xxx
+ edit yyy
+ END
+
+ call writefile(content, 'Xtest_fileinfo_last_bd', 'D')
+ let buf = RunVimInTerminal('-S Xtest_fileinfo_last_bd', #{rows: 10})
+ call WaitForAssert({-> assert_match('^"yyy" \[New\]', term_getline(buf,
10))})
+
+ call term_sendkeys(buf, ":bd\<CR>")
+ call WaitForAssert({-> assert_match('^"xxx" \[New\]', term_getline(buf,
10))})
+
+ call term_sendkeys(buf, ":bd\<CR>")
+ call WaitForAssert({-> assert_match('^\"\[No Name\]\" --No lines in
buffer--', term_getline(buf, 10))})
+
+ " clean up
+ call StopVimInTerminal(buf)
+endfunc
+
" vim: shiftwidth=2 sts=2 expandtab
diff --git a/src/version.c b/src/version.c
index b7344e387..a542cb79d 100644
--- a/src/version.c
+++ b/src/version.c
@@ -734,6 +734,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
+/**/
+ 232,
/**/
231,
/**/
--
--
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php
---
You received this message because you are subscribed to the Google Groups
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to [email protected].
To view this discussion visit
https://groups.google.com/d/msgid/vim_dev/E1w4k2P-002SRL-QK%40256bit.org.