GitHub - elihunter173/dirbuf.nvim: A file manager for Neovim which lets you edit your filesystem like you edit text (original) (raw)
A directory buffer for Neovim that lets you edit your filesystem like you edit text. Inspired by vim-dirvish and vidir.
Features
- Intuitive: Create, copy, delete, and rename files, directories, and more by editing their lines in the directory buffer. Buffer names are automatically updated to reflect changes.
- Minimal: Works out of the box with no configuration. Default mappings easily changed.
- Unobtrusive: Preserves alternate buffers and navigation history. Switch between files with
Ctrl-^(Ctrl-6) and jump around your navigation history with custom<Plug>mappings. - Safe: Does not modify the filesystem until you save the buffer. Optionally request confirmation and dry-run saving.
- Reliable: Resolves inter-dependencies in batch renames, including cycles.
- Polite: Plays nicely with tree-based file viewers like nvim-tree.lua,fern.vim, and carbon.nvim. dirbuf_demo_2022-04-06.mp4
Installation
Requires Neovim 0.6 or higher.
- vim-plug:
Plug "elihunter173/dirbuf.nvim" - packer.nvim:
use "elihunter173/dirbuf.nvim"
Notes
If you use nvim-tree.lua, you must disable the :help nvim-tree.update_to_buf_dir option. Otherwise, Dirbuf will fail to open directory buffers.
require("nvim-tree").setup { update_to_buf_dir = { enable = false } }
Usage
Run the command :Dirbuf to open a directory buffer. Press - in any buffer to open a directory buffer for its parent. Editing a directory will also open up a directory buffer, overriding Netrw.
Inside a directory buffer, there are the following keybindings:
<CR>: Open the file or directory at the cursor.gh: Toggle showing hidden files (i.e. dot files).-: Open parent directory.
See :help dirbuf.txt for more info.
Configuration
Configuration is not necessary for Dirbuf to work. But for those that want to override the default config, the following options are available with their default values listed.
require("dirbuf").setup { hash_padding = 2, show_hidden = true, sort_order = "default", write_cmd = "DirbufSync", }
Read the documentation for more information (:help dirbuf-options).
Development
A Justfile is provided to test and lint the project.
Run unit tests
$ just test
Run luacheck
$ just lint
just test will automatically download plenary.nvim's test harness and run the *_spec.lua tests in tests/.