_ __ __ ________
_ __(_)___ ___ _____/ /___ ________ / /_ __ __/ __/ __/__ _____
| | / / / __ `__ \______/ ___/ / __ \/ ___/ _ \/ __ \/ / / / /_/ /_/ _ \/ ___/
| |/ / / / / / / /_____/ /__/ / /_/ (__ ) __/ /_/ / /_/ / __/ __/ __/ /
|___/_/_/ /_/ /_/ \___/_/\____/____/\___/_.___/\__,_/_/ /_/ \___/_/
Have you ever been frustrated by Vim's behavior when closing buffers, where your carefully arranged split window layout gets ruined? You’re not alone. Vim CloseBuffer is a plugin designed to help you close buffers without disrupting your window layout, making your Vim experience smoother and more efficient.
When you close a buffer in Vim using the default commands, Vim can sometimes close the window as well, collapsing your split layout and leaving you with a disorganized workspace. This plugin prevents that by allowing you to close buffers without affecting the current window arrangement.
To install the Vim CloseBuffer plugin, you can use any popular Vim plugin manager. For instance, if you're using vim-plug, add the following line to your .vimrc:
Plug 'caesar003/vim-closebuffer'
Then, install the plugin by running:
:PlugInstall
Alternatively, if you’re using a different plugin manager like lazy.nvim, Vundle, or Packer, refer to its specific documentation to install the plugin.
Here’s how you might add it with lazy.nvim:
return {
-- other plugins
{ 'caesar003/vim-closebuffer' },
}
After installing the plugin, you can use the following command to safely close your buffers:
:CloseBuffer
This command provides an interactive prompt if there are unsaved changes, allowing you to save, discard, or cancel the close operation. It ensures that your split layout remains intact, no matter how you choose to handle the buffer.
You are free to define convenient mappings to make using the plugin even easier. For example:
nnoremap <leader>c :CloseBuffer<cr>
Or with lazy.nvim
return {
-- other plugins
{
"caesar003/vim-closebuffer",
config = function()
vim.api.nvim_set_keymap("n", "<leader>c", ":CloseBuffer<CR>", { noremap = true, silent = true, desc = "Delete Buffer" })
end,
},
}
Feel free to customize the mapping to fit your preferred keybindings.
If you find any issues or have suggestions for improvements, feel free to open an issue or submit a pull request on GitHub. Contributions are always welcome!
This plugin is open-source and licensed under the MIT License.