Rafael Bodill's Neovim Config
Lean mean Neovim machine, 30-45ms startup time.
Works best with Neovim ≥0.7 ⚠️ For Vim 8.x, use the
vim
git tag .
I encourage you to fork this repo and create your own experience.
Learn how to tweak and change Neovim to the way YOU like it.
This is my cultivation of years of tweaking, use it as a git remote
and stay in-touch with upstream for reference or cherry-picking.
Table of Contents
(🔎 Click to expand/collapse)
Neovim
(brew install neovim
) ≥ v0.7.0
Plugins are parsed from YAML and cached.
Ensure one of these tools is installed:
yj (brew install yj
)
yq (brew install yq
)
yaml2json
Ruby
Python with PyYAML (pip install PyYAML
)
1. Let's clone this repo! Clone to ~/.config/nvim
mkdir ~ /.config
git clone [email protected] :rafi/vim-config.git ~ /.config/nvim
cd ~ /.config/nvim
2. Run make test
to test your nvim version and capabilities.
3. Run make
to install all plugins.
4. If you are experiencing problems, run and read nvim -c checkhealth
Enjoy! 😄
Language-Server Protocol (LSP)
To leverage LSP auto-completions and other functionalities, run
:LspInstall <server>
to use williamboman/nvim-lsp-installer installation
feature. Use Tab to list available servers.
Instead, you can use the UI with ':LspInstallInfo'.
Here's some popular servers to install:
:LspInstall html cssls jsonls yamlls
:LspInstall gopls
:LspInstall pylsp
:LspInstall bashls vimls sumneko_lua
:LspInstall tsserver
and more …
See lua/plugins/lspconfig.lua and lua/lsp/* for built-in
mapping and configuration for some language-servers. You'll need utilities
like npm
and curl
to install some extensions. For more information, see:
cd ~ /.config/nvim
make update
This will run git pull --ff --ff-only
and update all plugins using
Shougo/dein.vim package-manager (:call dein#update()
).
On macOS with Homebrew, choose one of the Nerd Fonts ,
for example, here are some popular fonts:
brew tap homebrew/cask-fonts
brew search nerd-font
brew install --cask font-victor-mono-nerd-font
brew install --cask font-iosevka-nerd-font-mono
brew install --cask font-hack-nerd-font
brew install --cask font-fira-code
brew install vint shellcheck jsonlint yamllint
brew install tflint ansible-lint tidy-html5 proselint write-good
yarn global add markdownlint-cli eslint jshint stylelint sass-lint
pip3 install --user pycodestyle pyflakes flake8
For custom configuration , create the config/local.vim
file
and add your personal vimscript there.
For installing plugins , create a config/plugins.local.yaml
file and
manage your own plugin collection. If you want to disable some of the plugins
I use, you can overwrite them, e.g. :
- { repo: shadmansaleh/lualine.nvim, if: 0 }
Using config/plugins.local.yaml
you can install any plugin you want, e.g. :
# Choose only ONE of these statuslines ;)
- repo : itchyny/lightline.vim
- repo : vim-airline/vim-airline
- repo : glepnir/galaxyline.nvim
- repo : glepnir/spaceline.vim
- repo : liuchengxu/eleline.vim
You can set global specific features by defining in your local
config/local.vim
:
let g: elite_mode = 1 " Set arrow-keys to window resize
let g: global_symbol_padding = ' ' " Padding after nerd symbols
let g: tabline_plugin_enable = 0 " Disable built-in tabline
let g: enable_universal_quit_mapping = 0 " Disable normal 'q' mapping
let g: disable_mappings = 0 " Disable config/mappings.vim
To override LSP configurations , create a lua/lsp-local/<server_name>.lua
file. Must return a table with config
function. For example, create
lua/lsp-local/go.lua
:
local config = {
settings = {
gopls = {
staticcheck = true
}
}
}
return {
config = function (_ ) return config end ,
}
⚠️ This will completely overwrite built-in lua/lsp/go.lua
.
after/ - Language specific custom settings and plugins
config/ - Configuration
lua/ - Lua plugin configurations
lsp/ - LSP configurations
lsp-local - Custom user LSP configurations
plugins/ - Plugins configurations
badge.lua - Badges for status lines
user.lua - Custom functions
snippets/ - Personal code snippets
themes/ - Colorscheme overrides
filetype.vim - Custom filetype detection
Plugin management with cache and lazy loading for speed
Auto-completion with Language-Server Protocol (LSP)
Project-aware tabline
Extensive syntax highlighting with nvim-treesitter .
Note that 95% of the plugins are lazy-loaded .
List (🔎 Click to expand/collapse)
Completion & Code-Analysis
Note that,
Leader key set as Space
Local-Leader key set as ; and used for navigation and search
(Telescope and Tree)
Disable ← ↑ → ↓ in normal mode by enabling g:elite_mode
in .vault.vim
Key-mappings
(🔎 Click to expand/collapse)
Modes: 𝐍=normal 𝐕=visual 𝐒=select 𝐈=insert 𝐂=command
Key
Mode
Action
Plugin or Mapping
j / k
𝐍 𝐕
Cursor moves through display-lines
g
j/k
g +j / k
𝐍 𝐕 𝐒
Jump to edge upward/downward
haya14busa/vim-edgemotion
gh / gl
𝐍 𝐕
Easier line-wise movement
g
^/$
Space +Space
𝐍 𝐕
Toggle visual-line mode
V
/ Escape
zl / zh
𝐍
Scroll horizontally and vertically wider
z4
l/h
Ctrl +j
𝐍
Move to split below
christoomey/tmux-navigator
Ctrl +k
𝐍
Move to upper split
christoomey/tmux-navigator
Ctrl +h
𝐍
Move to left split
christoomey/tmux-navigator
Ctrl +l
𝐍
Move to right split
christoomey/tmux-navigator
Return
𝐍
Toggle fold
za
Shift +Return
𝐍
Focus the current fold by closing all others
zMzvzt
]q or ]q
𝐍
Next/previous on quickfix list
:cnext
/ :cprev
]a or ]a
𝐍
Next/previous on location-list
:lnext
/ :lprev
]w or ]w
𝐍
Next/previous whitespace error
plugin/whitespace.vim
]g or ]g
𝐍
Next/previous Git hunk
lewis6991/gitsigns.nvim
]d or ]d
𝐍
Next/previous LSP diagnostic
lua/plugins/lspconfig.lua
Ctrl +f
𝐂
Move cursor forwards in command
Right
Ctrl +b
𝐂
Move cursor backwards in command
Left
Ctrl +h
𝐂
Move cursor to the beginning in command
Home
Ctrl +l
𝐂
Move cursor to the end in command
End
Key
Mode
Action
Plugin or Mapping
Space +cd
𝐍
Switch to the directory of opened buffer
:lcd %:p:h
gf
𝐍
Open file under the cursor in a vsplit
:rightbelow wincmd f
Space +w
𝐍
Write buffer to file
:write
Ctrl +s
𝐍 𝐕 𝐂
Write buffer to file
:write
Key
Mode
Action
Plugin or Mapping
Ctrl +y
𝐈
Expand emmet abbreviation
mattn/emmet-vim
Q
𝐍
Start/stop macro recording
q
gQ
𝐍
Play macro 'q'
@q
Shift +Return
𝐈
Start new line from any cursor position
<C-o>o
<
𝐕
Indent to left and re-select
<gv
>
𝐕
Indent to right and re-select
`>gv
Tab
𝐕
Indent to right and re-select
`>gv
Shift +Tab
𝐕
Indent to left and re-select
<gv
gc
𝐍 𝐕
Comment prefix
b3nj5m1n/kommentary
gcc
𝐍 𝐕
Toggle comments
b3nj5m1n/kommentary
Space +v
𝐍 𝐕
Toggle single-line comments
b3nj5m1n/kommentary
Space +V
𝐍 𝐕
Toggle comment block
b3nj5m1n/kommentary
Space +j or k
𝐍 𝐕
Move lines down/up
:m
…
Space +d
𝐍 𝐕
Duplicate line or selection
Space +cn / cN
𝐍 𝐕
Change current word in a repeatable manner
Space +cp
𝐍
Duplicate paragraph
yap<S-}>p
Space +cw
𝐍
Remove all spaces at EOL
:%s/\s\+$//e
sj / sk
𝐍
Join/split arguments
AndrewRadev/splitjoin.vim
dsf / csf
𝐍
Delete/change surrounding function call
AndrewRadev/dsf.vim
Key
Mode
Action
Plugin or Mapping
* / #
𝐍 𝐕
Search selection forward/backward
haya14busa/vim-asterisk
g* / g#
𝐍 𝐕
Search whole-word forward/backward
haya14busa/vim-asterisk
Backspace
𝐍
Match bracket
%
gpp
𝐍
Select last paste
sg
𝐕
Replace within selected area
:s/⌴/gc
Ctrl +r
𝐕
Replace selection with step-by-step confirmation
:%s/\V/⌴/gc
Key
Mode
Action
Plugin or Mapping
p or P
𝐕
Paste without yank
s:visual_paste
Y
𝐍
Yank to the end of line
y$
Space +y
𝐍
Copy relative file-path to clipboard
Space +Y
𝐍
Copy absolute file-path to clipboard
Key
Mode
Action
Plugin or Mapping
!
𝐍
Shortcut for shell command
:!
g!
𝐍
Read vim command into buffer
:put=execute('⌴')
Ctrl +n / p
𝐂
Switch history search pairs
↓ / ↑
↓ / ↑
𝐂
Switch history search pairs
Ctrl
n
/p
Key
Mode
Action
Plugin or Mapping
Space +ts
𝐍
Toggle spell-checker
:setlocal spell!
Space +tn
𝐍
Toggle line numbers
:setlocal nonumber!
Space +tl
𝐍
Toggle hidden characters
:setlocal nolist!
Space +th
𝐍
Toggle highlighted search
:set hlsearch!
Space +tw
𝐍
Toggle wrap
:setlocal wrap!
…
Space +ti
𝐍
Toggle indentation lines
nathanaelkane/vim-indent-guides
Space +tt
𝐍
Show highlight groups for word
g1
𝐍
Go to first tab
:tabfirst
g9
𝐍
Go to last tab
:tablast
g5
𝐍
Go to previous tab
:tabprevious
Ctrl +Tab
𝐍
Go to next tab
:tabnext
Ctrl +Shift Tab
𝐍
Go to previous tab
:tabprevious
Alt +j
𝐍
Go to next tab
:tabnext
Alt +k
𝐍
Go to previous tab
:tabprevious
Alt +{
𝐍
Move tab backward
:-tabmove
Alt +}
𝐍
Move tab forward
:+tabmove
Key
Mode
Action
Plugin or Mapping
q
𝐍
Quit window (and Vim, if last window)
:quit
Ctrl +x
𝐍
Rotate window placement
C-w
x
sv
𝐍
Horizontal split
:split
sg
𝐍
Vertical split
:vsplit
st
𝐍
Open new tab
:tabnew
so
𝐍
Close other windows
:only
sb
𝐍
Previous buffer
:b#
sc
𝐍
Close current buffer
:close
sd
𝐍
Delete buffer
:bdelete
sq
𝐍
Quit window
:quit
sx
𝐍
Delete buffer, leave blank window
:enew │ bdelete
sz
𝐍
Toggle window zoom
:vertical resize │ resize
ssv
𝐍
Split with previous buffer
:split │ wincmd p │ e#
ssg
𝐍
Vertical split with previous buffer
:vsplit │ wincmd p │ e#
sh
𝐍
Toggle colorscheme background=dark/light
:set background
…
Key
Mode
Action
ds
𝐍
Delete around with query
dss
𝐍
Delete around automatically
cs
𝐍
Change around with query
css
𝐍
Change around automatically
sa
𝐍 𝐕 𝐎
Trigger add operator
sd
𝐍 𝐕
Trigger delete operator
sdb
𝐍
Delete around automatically
sr
𝐍 𝐕
Trigger replace operator
srb
𝐍
Replace around automatically
ir
𝐕 𝐎
Inner automatically
ab
𝐕 𝐎
Around automatically
Key
Mode
Action
]g or ]g
𝐍
Next/previous Git hunk
gs
𝐍
Preview hunk
Space +hp
𝐍
Preview hunk
Space +hb
𝐍
Blame line
Space +hs
𝐍 𝐕
Stage hunk
Space +hu
𝐍
Undo stage hunk
Space +hr
𝐍 𝐕
Reset hunk
Space +hR
𝐍
Reset buffer
Space +hl
𝐍
Publish hunks to location-list
Key
Mode
Action
Space +ga
𝐍
Git add current file
Space +gd
𝐍
Git diff
Space +gc
𝐍
Git commit
Space +gb
𝐍
Git blame
Space +gs
𝐍
Git status -s
Space +gl
𝐍
Git log --graph --all
Space +gF
𝐍
Git fetch
Space +gp
𝐍
Git push
Space +go
𝐍 𝐕
Open SCM detailed URL in browser
Key
Mode
Action
;r
𝐍
Results of the previous picker
;R
𝐍
List of the previous pickers
;f
𝐍
File search
;g
𝐍
Grep search
;b
𝐍
Buffers
;x
𝐍
Old files
;v
𝐍 𝐕
Yank history
;m
𝐍
Marks
;n
𝐍
Dein plugin list
;j
𝐍
Jump points
;u
𝐍
Spelling suggestions
;o
𝐍
Vim options
;s
𝐍
Sessions
;t
𝐍
LSP workspace symbols
;h
𝐍
Highlights
;w
𝐍
Memo list
;z
𝐍
Zoxide directories
;;
𝐍
Command history
;/
𝐍
Search history
Space +gt
𝐍
Find symbols matching word under cursor
Space +gf
𝐍
Find files matching word under cursor
Space +gg
𝐍 𝐕
Grep word under cursor
Within Telescope window
?
𝐍
Keymaps help screen
jj or Escape
𝐈
Leave Insert mode
i
𝐍
Enter Insert mode (filter input)
q or Escape
𝐍
Exit denite window
Tab or Shift +Tab
𝐍 𝐈
Next/previous candidate
Ctrl d /u
𝐍 𝐈
Scroll down/upwards
Ctrl f /b
𝐍 𝐈
Scroll preview down/upwards
J or K
𝐍
Select candidates up/downwards
st
𝐍
Open in a new tab
sg
𝐍
Open in a vertical split
sv
𝐍
Open in a split
w
𝐍
Smart send to quickfix list
e
𝐍
Send to quickfix list
dd
𝐍
Delete entry (buffer list)
Key
Mode
Action
;e
𝐍
Open file-explorer (toggle)
;a
𝐍
Focus current file in file-explorer
Within Neo-Tree window
j or k
𝐍
Move up and down the tree
J or K or Space
𝐍
Select entries up/downwards
l or Return
𝐍
Toggle collapse/expand directory or open file
h
𝐍
Collapse directory tree
gr
𝐍
Grep in current position
gf
𝐍
Find files in current position
!
𝐍
Toggle hidden files
^
𝐍
Change into project root directory
Backspace
𝐍
Change into parent directory
o
𝐍
Open bookmarks
B
𝐍
Save location as bookmark
st
𝐍
Open file in new tab
sv
𝐍
Open file in a horizontal split
sg
𝐍
Open file in a vertical split
N
𝐍
Create new directories and/or files
Ctrl +n
𝐍
Create new directory
c / m
𝐍
Copy/move
C / M / P
𝐍
Clipboard copy/move/paste
R
𝐍
Rename file or directory
D
𝐍
Trash selected files and directories
fi / fe
𝐍
Include/exclude
yy
𝐍
Yank path to clipboard
w
𝐍
Toggle window size
x
𝐍
Execute associated system application
Key
Mode
Action
Tab / Shift-Tab
𝐈
Navigate completion-menu
Tab / Shift-Tab
𝐈 𝐒
Navigate snippet placeholders
Ctrl +Space
𝐈
Open completion menu
Enter
𝐈
Select completion or expand snippet
Ctrl +p /n
𝐈
Movement in completion pop-up
Ctrl +b /f
𝐈
Scroll documentation
Ctrl +y
𝐈
Expand Emmet sequence
Ctrl +e
𝐈
Abort selection and close pop-up
Ctrl +l
𝐈
Expand snippet at cursor
Key
Mode
Action
Space +so
𝐍
Open spectre window
Space +sw
𝐍
Open spectre window with current word
Space +s
𝐕
Open spectre window with visual selection
Space +sp
𝐍
Search in current file
Key
Mode
Action
Space +ii
𝐍
Jump to definition under cursor
Space +ii
𝐕
Jump to selected text in visual mode
Space +ib
𝐍
Open previous opened file (after jump)
Space +il
𝐍
Open last closed search window again
Key
Mode
Action
m,
𝐍
Set the next available alphabetical (lowercase) mark
m;
𝐍
Toggle the next available mark at the current line
m a-z
𝐍
Set mark
dm a-z
𝐍
Remove mark
dm-
𝐍
Delete all marks on the current line
dm
𝐍
Delete all marks in the current buffer
m]
𝐍
Move to next mark
m[
𝐍
Move to previous mark
m:
𝐍
Preview mark, prompts you for a specific mark.