Skip to content

Lean mean Neovim machine, carefully crafted with ❤️ Use with latest Neovim.

Notifications You must be signed in to change notification settings

rafi/vim-config

Repository files navigation

Rafael Bodill's Neovim Config

Lean mean Neovim machine, 30-45ms startup time. Works best with Neovim ≥0.10

⚙️ See "Extending" for customizing configuration and adding plugins.

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)

Features

  • Fast startup time — plugins are almost entirely lazy-loaded!
  • Robust, yet light-weight
  • Plugin management with folke/lazy.nvim. Use with :Lazy or Space+l
  • Install LSP, DAP, linters, and formatters. Use with :Mason or Space+mm
  • LSP configuration with nvim-lspconfig
  • telescope.nvim centric work-flow with lists (try ;+f…)
  • Custom context-menu (try it! ;+c)
  • Auto-complete extensive setup with nvim-cmp (try Tab or Ctrl+Space in insert-mode)
  • Structure view with [hedyhli/outline.nvim]
  • Git features using lewis6991/gitsigns.nvim, sindrets/diffview.nvim, and more
  • Session management with folke/persistence.nvim
  • Unobtrusive, yet informative status & tab lines
  • Premium color-schemes
  • Remembers last-used colorscheme

Screenshot

Vim screenshot

Prerequisites

  • git ≥ 2.19.0 (brew install git)
  • Neovim ≥ v0.10.0 (brew install neovim)

Optional, but highly recommended:

  • bat (brew install bat)
  • fd (brew install fd)
  • fzf (brew install fzf)
  • ripgrep (brew install ripgrep)
  • zoxide (brew install zoxide)

Install

  1. Let's clone this repo! Clone to ~/.config/nvim

    mkdir -p ~/.config
    git clone git@github.com:rafi/vim-config.git ~/.config/nvim
    cd ~/.config/nvim
  2. Run nvim (will install all plugins the first time).

    It's highly recommended running :checkhealth to ensure your system is healthy and meet the requirements.

  3. Inside Neovim, run :LazyExtras and use x to install extras.

Enjoy! 😄

Install LSP, DAP, Linters, Formatters

Use :Mason (or Space+mm) to install and manage LSP servers, DAP servers, linters and formatters. See :h mason.nvim and williamboman/mason.nvim for more information.

Language-Server Protocol (LSP)

You can install LSP servers using :Mason UI, or :MasonInstall <name>, or :LspInstall <name> (use Tab to list available servers). See Mason's PACKAGES.md for the official list, and the Language server mapping list. You can also view at :h mason-lspconfig-server-map

You'll need utilities like npm and curl to install some extensions, see requirements (or :h mason-requirements) for more information.

See lua/rafi/plugins/lsp/init.lua for custom key-mappings and configuration for some language-servers.

Recommended LSP

:MasonInstall ansible-language-server bash-language-server css-lsp
:MasonInstall dockerfile-language-server gopls html-lsp json-lsp
:MasonInstall lua-language-server marksman pyright sqlls
:MasonInstall svelte-language-server typescript-language-server
:MasonInstall tailwindcss-language-server
:MasonInstall vim-language-server yaml-language-server

and more

Recommended Linters

:MasonInstall vint shellcheck editorconfig-checker flake8 gitlint hadolint
:MasonInstall markdownlint mypy selene shellharden write-good yamllint

Recommended Formatters

:MasonInstall black fixjson gofumpt golines isort
:MasonInstall shfmt sql-formatter stylua

Recommended Fonts

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

Upgrade

To upgrade packages and plugins:

  • Neovim plugins: :Lazy update
  • Mason packages: :Mason and press U

To update Neovim configuration from my repo:

git pull --ff --ff-only

Structure

  • after/ — Language specific custom settings and plugins.
  • lua/ — Lua configurations
  • snippets/ — Personal code snippets

Extending

Extend: Config

Fork this repository and create a directory lua/config with one or more of these files: (Optional)

  • lua/config/autocmds.lua — Custom auto-commands
  • lua/config/options.lua — Custom options
  • lua/config/keymaps.lua — Custom key-mappings
  • lua/config/setup.lua — Override config, see extend defaults.

Adding plugins or override existing options:

  • lua/plugins/*.lua or lua/plugins.lua — Plugins (See lazy.nvim specs for syntax)

Extend: Plugins

Install "extras" plugins using :LazyExtras and installing with x. This saves choices in lazyvim.json which you can also edit manually, here's a recommended starting point:

{
  "extras": [
    "lazyvim.plugins.extras.ai.copilot",
    "lazyvim.plugins.extras.dap.core",
    "lazyvim.plugins.extras.dap.nlua",
    "lazyvim.plugins.extras.lang.docker",
    "lazyvim.plugins.extras.lang.json",
    "lazyvim.plugins.extras.lang.typescript",
    "lazyvim.plugins.extras.lang.yaml",
    "lazyvim.plugins.extras.test.core",
    "rafi.plugins.extras.coding.align",
    "rafi.plugins.extras.editor.harpoon2",
    "rafi.plugins.extras.git.cmp-git",
    "rafi.plugins.extras.lang.ansible",
    "rafi.plugins.extras.lang.go",
    "rafi.plugins.extras.lang.helm",
    "rafi.plugins.extras.lang.markdown",
    "rafi.plugins.extras.lang.python",
    "rafi.plugins.extras.lang.tmux",
    "rafi.plugins.extras.ui.deadcolumn"
  ],
  "news": [],
  "version": 2
}

For installing/overriding/disabling plugins, create a lua/plugins/foo.lua file (or lua/plugins/foo/bar.lua or simply lua/plugins.lua) and manage your own plugin collection. You can add or override existing plugins' options, or just disable them all-together. Here's an example:

return {

  -- Disable default tabline
  { 'akinsho/bufferline.nvim', enabled = false },

  -- And choose a different one!
  -- { 'itchyny/lightline.vim' },
  -- { 'vim-airline/vim-airline' },
  -- { 'glepnir/galaxyline.nvim' },
  -- { 'glepnir/spaceline.vim' },
  -- { 'liuchengxu/eleline.vim' },

  -- Enable GitHub's Copilot
  { import = 'lazyvim.plugins.extras.ai.copilot' },

  -- Enable incline, displaying filenames on each window
  { import = 'rafi.plugins.extras.ui.incline' },

  -- Disable built-in plugins
  { 'shadmansaleh/lualine.nvim', enabled = false },
  { 'folke/persistence.nvim', enabled = false },

  -- Change built-in plugins' options
  {
    'nvim-treesitter/nvim-treesitter',
    opts = {
      ensure_installed = {
        'bash', 'comment', 'css', 'diff', 'dockerfile', 'fennel', 'fish',
        'gitcommit', 'gitignore', 'gitattributes', 'git_rebase', 'go', 'gomod',
        'gosum', 'gowork', 'graphql', 'hcl', 'html', 'javascript', 'jsdoc',
        'json', 'json5', 'jsonc', 'jsonnet', 'lua', 'make', 'markdown',
        'markdown_inline', 'nix', 'perl', 'php', 'pug', 'python', 'regex',
        'rst', 'ruby', 'rust', 'scss', 'sql', 'svelte', 'terraform', 'toml',
        'tsx', 'typescript', 'vim', 'vimdoc', 'vue', 'yaml', 'zig',
      },
    },
  },

}

Extend: Defaults

  1. Create lua/config/options.lua and set any Neovim/RafiVim/LazyVim features: (Default values are shown)

    -- Elite-mode (hjkl mode. arrow-keys resize window)
    vim.g.elite_mode = false
    
    -- External file diff program
    vim.g.diffprg = 'bcompare'
    
    -- Auto format on-save
    vim.g.autoformat = false
    
    -- Snacks animations
    vim.g.snacks_animate = false
  2. You can override LazyVim options. For example in lua/plugins/lazyvim.lua:

    return {
      {
        'LazyVim/LazyVim',
        opts = {
          icons = {
            diagnostics = {
              Error = '',
              Warn  = '',
              Info  = '',
            },
            status = {
              diagnostics = {
                error = 'E',
                warn  = 'W',
                info  = 'I',
                hint  = 'H',
              },
            },
          },
        },
      },
    }
  3. You can override lazy.nvim (package-manager) global options. Create lua/config/setup.lua and return this function:

    • lazy_opts() — override LazyVim setup options

    For example:

    local M = {}
    
    ---@return table
    function M.lazy_opts()
      return {
        -- See /~https://github.com/folke/lazy.nvim/#%EF%B8%8F-configuration
        concurrency = jit.os:find('Windows') and (vim.uv.available_parallelism() * 2) or nil,
      }
    end
    
    return M
  4. You can completely override lazy.nvim setup by creating lua/config/lazy.lua to replace lua/rafi/config/lazy.lua with your own procedure.

Extend: LSP Settings

Override server options with nvim-lspconfig plugin, for example:

{
  'neovim/nvim-lspconfig',
  opts = {
    servers = {
      yamlls = {
        filetypes = { 'yaml', 'yaml.ansible', 'yaml.docker-compose' },
      },
      lua_ls = {
        settings = {
          Lua = {
            workspace = { checkThirdParty = false },
            completion = { callSnippet = 'Replace' },
          },
        },
      },
    },
  }
}

Plugin Highlights

  • 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.

Plugins Included

List of plugins (🔎 Click to expand/collapse)

Completion & Code-Analysis

Name Description
neovim/nvim-lspconfig Quickstart configurations for the Nvim LSP client
williamboman/mason.nvim Portable package manager for Neovim
williamboman/mason-lspconfig.nvim Mason extension for easier lspconfig integration
stevearc/conform.nvim Lightweight yet powerful formatter plugin
mfussenegger/nvim-lint Asynchronous linter plugin

Editor Plugins

Name Description
folke/lazy.nvim Modern plugin manager for Neovim
nmac427/guess-indent.nvim Automatic indentation style detection
tweekmonster/helpful.vim Display vim version numbers in docs
lambdalisue/suda.vim An alternative sudo for Vim and Neovim
folke/persistence.nvim Simple lua plugin for automated session management
mbbill/undotree Ultimate undo history visualizer
folke/flash.nvim Search labels, enhanced character motions
folke/todo-comments.nvim Highlight, list and search todo comments in your projects
folke/trouble.nvim Pretty lists to help you solve all code diagnostics
[hedyhli/outline.nvim] Code outline sidebar powered by LSP
s1n7ax/nvim-window-picker Fancy Window picker
dnlhc/glance.nvim Pretty window for navigating LSP locations
MagicDuck/grug-far.nvim Search/replace in multiple files

Coding Plugins

Name Description
hrsh7th/nvim-cmp Completion plugin for neovim written in Lua
hrsh7th/cmp-nvim-lsp nvim-cmp source for neovim builtin LSP client
hrsh7th/cmp-buffer nvim-cmp source for buffer words
hrsh7th/cmp-path nvim-cmp source for path
hrsh7th/cmp-emoji nvim-cmp source for emoji
rafamadriz/friendly-snippets Preconfigured snippets for different languages
echasnovski/mini.pairs Automatically manage character pairs
echasnovski/mini.surround Fast and feature-rich surround actions
JoosepAlviste/nvim-ts-context-commentstring Set the commentstring based on the cursor location
numToStr/Comment.nvim Powerful line and block-wise commenting
echasnovski/mini.splitjoin Split and join arguments
echasnovski/mini.trailspace Trailing whitespace highlight and remove
AndrewRadev/linediff.vim Perform diffs on blocks of code
echasnovski/mini.ai Extend and create a/i textobjects
folke/lazydev.nvim Faster LuaLS setup
Bilal2453/luvit-meta Manage libuv types with lazy

Colorscheme Plugins

Name Description
rafi/theme-loader.nvim Use last-used colorscheme
rafi/neo-hybrid.vim Modern dark colorscheme, hybrid improved
rafi/awesome-colorschemes Awesome color-schemes

Git Plugins

Name Description
lewis6991/gitsigns.nvim Git signs written in pure lua
sindrets/diffview.nvim Tabpage interface for cycling through diffs
NeogitOrg/neogit Magit clone for Neovim
FabijanZulj/blame.nvim Git blame visualizer
rhysd/committia.vim Pleasant editing on Git commit messages

Misc Plugins

Name Description
folke/snacks.nvim Collection of small QoL plugins
hoob3rt/lualine.nvim Statusline plugin written in pure lua
nvim-neo-tree/neo-tree.nvim File explorer written in Lua
nvim-telescope/telescope.nvim Find, Filter, Preview, Pick. All lua.
jvgrootveld/telescope-zoxide Telescope extension for Zoxide
rafi/telescope-thesaurus.nvim Browse synonyms for a word
nvim-lua/plenary.nvim Lua functions library

Treesitter & Syntax

Name Description
nvim-treesitter/nvim-treesitter Nvim Treesitter configurations and abstraction layer
nvim-treesitter/nvim-treesitter-textobjects Textobjects using treesitter queries
windwp/nvim-ts-autotag Use treesitter to auto close and auto rename html tag
andymass/vim-matchup Modern matchit and matchparen
iloginow/vim-stylus Better vim plugin for stylus
mustache/vim-mustache-handlebars Mustache and handlebars syntax
lifepillar/pgsql.vim PostgreSQL syntax and indent
MTDL9/vim-log-highlighting Syntax highlighting for generic log files
reasonml-editor/vim-reason-plus Reason syntax and indent

UI Plugins

Name Description
echasnovski/mini.icons Icon provider
MunifTanjim/nui.nvim UI Component Library
stevearc/dressing.nvim Improve the default vim-ui interfaces
akinsho/bufferline.nvim Snazzy tab/bufferline
folke/noice.nvim Replaces the UI for messages, cmdline and the popupmenu
SmiteshP/nvim-navic Shows your current code context in winbar/statusline
chentau/marks.nvim Interacting with and manipulating marks
lukas-reineke/indent-blankline.nvim Visually display indent levels
echasnovski/mini.indentscope Visualize and operate on indent scope
folke/which-key.nvim Create key bindings that stick
tenxsoydev/tabs-vs-spaces.nvim Hint and fix deviating indentation
t9md/vim-quickhl Highlight words quickly

Extra Plugins

List of extras (🔎 Click to expand/collapse)

You can view all LazyVim's extras at www.lazyvim.org/extras.

These plugins aren't enabled by default. You'll have to install them using :LazyExtras and installing with x. (Or import them using specs) See Extend: Plugins on how to add plugins and examples.

Following are extra-extras available with Rafi's Neovim on-top of LazyVim's:

Extra Plugins: Coding

Spec: rafi.plugins.extras.coding.<name>

Name Repository Description
align echasnovski/mini.align Align text interactively
chainsaw chrisgrieser/nvim-chainsaw Create log statements on the fly
editorconfig sgur/vim-editorconfig EditorConfig plugin written entirely in Vimscript
emmet mattn/emmet-vim Provides support for expanding abbreviations alá emmet
luasnip L3MON4D3/LuaSnip saadparwaiz1/cmp_luasnip Snippet Engine and cmp source
neogen danymat/neogen Annotation generator
sandwich machakann/vim-sandwich Search, select, and edit sandwich text objects

Extra Plugins: Colorscheme

Spec: rafi.plugins.extras.colorscheme.<name>

Name Repository Description
nordic AlexvZyl/nordic.nvim Nord for Neovim, but warmer and darker
tokyonight folke/tokyonight.nvim Clean, dark Neovim theme
kanagawa rebelot/kanagawa.nvim Inspired by the colors of the famous painting by Katsushika Hokusai
onedarkpro olimorris/onedarkpro.nvim OneDarkPro theme
nightfox EdenEast/nightfox.nvim Highly customizable theme
oxocarbon nyoom-engineering/oxocarbon.nvim Dark and light theme inspired by IBM Carbon
bamboo ribru17/bamboo.nvim Warm green theme
catppuccin catppuccin/nvim Soothing pastel theme

Extra Plugins: Editor

Spec: rafi.plugins.extras.editor.<name>

Name Repository Description
anyjump pechorin/any-jump.vim Jump to any definition and references without overhead
flybuf glepnir/flybuf.nvim List buffers in a float window
harpoon ThePrimeagen/harpoon Marks for navigating your project
mini-visits echasnovski/mini.visits Track and reuse file system visits
rest rest-nvim/rest.nvim Fast Neovim http client written in Lua
sidebar sidebar-nvim/sidebar.nvim Generic and modular lua sidebar
ufo kevinhwang91/nvim-ufo Make folds look modern and keep a high performance

Extra Plugins: Git

Spec: rafi.plugins.extras.git.<name>

Name Repository Description
cmp-git petertriho/cmp-git Git source for nvim-cmp
fugitive tpope/vim-fugitive Git client, including junegunn/gv.vim

Extra Plugins: Lang

Spec: rafi.plugins.extras.lang.<name>

Name Description
ansible imports lazyvim.plugins.extras.lang.ansible, add syntax and pearofducks/ansible-vim
go imports lazyvim.plugins.extras.lang.go, add tools, patterns, etc.
helm imports lazyvim.plugins.extras.lang.helm, add filetype patterns
kubernetes imports lazyvim.plugins.extras.lang.yaml, add filetype patterns and ramilito/kubectl.nvim
markdown imports lazyvim.plugins.extras.lang.markdown, disable headlines, add mzlogin/vim-markdown-toc
python imports lazyvim.plugins.extras.lang.python, add syntax and filetype patterns
tmux syntax, completion andersevenrud/cmp-tmux, keymaps christoomey/tmux-navigator

Extra Plugins: LSP

Spec: rafi.plugins.extras.lsp.<name>

Key Name Description
gtd hrsh7th/nvim-gtd LSP's go-to definition plugin
lightbulb kosayoda/nvim-lightbulb VSCode 💡 for neovim's built-in LSP
yaml-companion yaml-companion.nvim Get, set and autodetect YAML schemas in your buffers

Extra Plugins: Org

Spec: rafi.plugins.extras.org.<name>

Key Name Description
calendar itchyny/calendar.vim Calendar application
kiwi serenevoid/kiwi.nvim Stripped down VimWiki
telekasten renerocksai/telekasten.nvim Manage text-based, markdown zettelkasten or wiki with telescope
vimwiki vimwiki/vimwiki Personal Wiki for Vim
zk-nvim zk-org/zk-nvim Extension for the zk plain text note-taking assistant

Extra Plugins: Treesitter

Spec: rafi.plugins.extras.treesitter.<name>

Key Name Description
endwise RRethy/nvim-treesitter-endwise Wisely add "end" in various filetypes
treesj Wansmer/treesj Splitting and joining blocks of code

Extra Plugins: UI

Spec: rafi.plugins.extras.ui.<name>

Key Name Description
alpha goolord/alpha-nvim Fast and fully programmable greeter
barbecue utilyre/barbecue.nvim VS Code like winbar
bookmarks tomasky/bookmarks.nvim Bookmarks plugin with global file store
bqf kevinhwang91/nvim-bqf Better quickfix window
ccc uga-rosa/ccc.nvim Super powerful color picker/colorizer plugin
cursorword itchyny/cursorword Underlines word under cursor
cybu ghillb/cybu.nvim Cycle buffers with a customizable notification window
deadcolumn Bekaboo/deadcolumn.nvim Show colorcolumn dynamically
goto-preview rmagatti/goto-preview Preview definitions using floating windows
headlines lukas-reineke/headlines.nvim Adds horizontal highlights for headlines and code background.
illuminate RRethy/vim-illuminate Highlights other uses of the word under the cursor
incline b0o/incline.nvim Floating statuslines
marks chentoast/marks.nvim Interacting with and manipulating marks
mini-clue echasnovski/mini.clue Show next key clues
mini-map echasnovski/mini.map Window with buffer text overview, scrollbar and highlights
symbols-outline simrat39/symbols-outline.nvim Tree like view for symbols using LSP

LazyVim Extras

LazyVim is imported in specs (see lua/rafi/config/lazy.lua) Therefore, you can import any of the "Extras" plugins defined at LazyVim/LazyVim and documented in lazyvim.org.

These are only highlights:

Language

  • lazyvim.plugins.extras.lang.json
  • lazyvim.plugins.extras.lang.markdown
  • lazyvim.plugins.extras.lang.terraform
  • lazyvim.plugins.extras.lang.typescript

DAP (Debugging)

Test

Custom Key-mappings

Note that,

  • Leader key set as Space
  • Local-Leader key set as ; and used for navigation and search (Telescope and Neo-tree)
  • Disable in normal mode by enabling vim.g.elite_mode.
Key-mappings (🔎 Click to expand/collapse)

Legend: | Ⓝormal | Ⓥisual | Ⓢelect | Ⓘnsert | Ⓞperator | Ⓒommand |

Toggle Features

Key Mode Action
Space dph Toggle profiler highlights
Space dpp Toggle profiler
Space uA Toggle animation
Space uA Toggle tabline
Space ub Toggle background dark/light
Space uc Toggle conceal level
Space ud Toggle buffer diagnostics
Space uD Toggle text dim
Space uf Toggle format on Save
Space uF Toggle format on Save (Global)
Space ug Toggle indentation lines
Space uh Toggle inlay-hints
Space ui Show highlight groups for word
Space ul Toggle line numbers
Space uL Toggle relative line numbers
Space un Dismiss all notifications
Space up Disable auto-pairs
Space ur Redraw, clear hlsearch, and diff update
Space us Toggle spell-checker
Space uS Toggle scroll
Space uT Toggle tree-sitter
Space uw Toggle wrap
Space uz Toggle distraction-free zen writing
Space uZ Toggle window zoom

Navigation

Key Mode Action Plugin or Mapping
j / k Ⓝ Ⓥ Cursor moves through display-lines g j/k
]i / [i Ⓝ Ⓥ Jump to scope edges folke/snacks.nvim
gh / gl Ⓝ Ⓥ Easier line-wise movement g^ g$
zl / zh Scroll horizontally and vertically wider z4 l/h
Ctrl+j Move to split below <C-w>j or christoomey/tmux-navigator
Ctrl+k Move to upper split <C-w>k or christoomey/tmux-navigator
Ctrl+h Move to left split <C-w>h or christoomey/tmux-navigator
Ctrl+l Move to right split <C-w>l or christoomey/tmux-navigator
Return Toggle fold under cursor za
Shift+Return Focus the current fold by closing all others zMzv
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
Ctrl+Tab Go to next tab :tabnext
Ctrl+ShiftTab Go to previous tab :tabprevious
Alt+j or ] Go to next tab :tabnext
Alt+k or [ Go to previous tab :tabprevious
Alt+{ Move tab backward :-tabmove
Alt+} Move tab forward :+tabmove

Selection

Key Mode Action Plugin or Mapping
Space+Space Ⓝ Ⓥ Toggle visual-line mode V / Escape
Ctrl+Space / V Increment/shrink selection nvim-treesitter
vsp Select last paste config/keymaps.lua
sg Replace within selected area config/keymaps.lua
Ctrl+r Replace selection with step-by-step confirmation config/keymaps.lua
> / < Indent and re-select config/keymaps.lua
Tab / Shift+Tab Indent and re-select config/keymaps.lua
I / gI / A Force blockwise operation config/keymaps.lua

Jump To

Key Mode Action Plugin or Mapping
], or [, Next/previous parameter akinsho/bufferline.nvim
]q or [q Next/previous on quick-fix :cnext / :cprev
]a or [a Next/previous on location-list :lnext / :lprev
]d or [d Next/previous diagnostics config/keymaps.lua
]e or [e Next/previous error config/keymaps.lua
]w or [w Next/previous warning config/keymaps.lua
]b or [b Next/previous buffer akinsho/bufferline.nvim
]f or [f Next/previous function start echasnovski/mini.ai
]F or [F Next/previous function end echasnovski/mini.ai
]c or [c Next/previous class start echasnovski/mini.ai
]C or [C Next/previous class end echasnovski/mini.ai
]m or [m Next/previous method start echasnovski/mini.ai
]M or [M Next/previous method end echasnovski/mini.ai
]g or [g Next/previous Git hunk lewis6991/gitsigns.nvim
]i or [i Next/previous indent scope echasnovski/mini.indentscope
]t or [t Next/previous TODO folke/todo-comments.nvim
]z or [z Next/previous whitespace error config/keymaps.lua

Buffers

Key Mode Action Plugin or Mapping
Space+bd Delete buffer folke/snacks.nvim

Clipboard

Key Mode Action Plugin or Mapping
p or P Paste without yank :let @+=@0
Space+y Copy relative file-path to clipboard config/keymaps.lua
Space+Y Copy absolute file-path to clipboard config/keymaps.lua

Auto-Completion

Key Mode Action Plugin or Mapping
Tab / Shift-Tab Ⓘ Ⓢ Navigate/open completion-menu nvim-cmp
Tab / Shift-Tab Ⓘ Ⓢ Navigate snippet placeholders L3MON4D3/LuaSnip
Ctrl+Space Open completion menu nvim-cmp
Enter Select completion item or expand snippet nvim-cmp
Shift+Enter Select and replace with completion item nvim-cmp
Ctrl+n/p Movement in completion pop-up nvim-cmp
Ctrl+f/b Scroll documentation nvim-cmp
Ctrl+d/u Scroll candidates nvim-cmp
Ctrl+e Abort selection and close pop-up nvim-cmp
Ctrl+l Expand snippet at cursor L3MON4D3/LuaSnip
Ctrl+c Close completion menu nvim-cmp

LSP

Key Mode Action Plugin or Mapping
gr Go to references plugins/lsp/keymaps.lua
gR List references with Trouble folke/trouble.nvim
gd Go to definition plugins/lsp/keymaps.lua
gD Go to declaration plugins/lsp/keymaps.lua
gI Go to implementation plugins/lsp/keymaps.lua
gy Go to type definition plugins/lsp/keymaps.lua
K Show hover help or collapsed fold plugins/lsp/keymaps.lua
gK Show signature help plugins/lsp/keymaps.lua
Space cr Rename plugins/lsp/keymaps.lua
Space ce Open diagnostics window plugins/lsp/keymaps.lua
Space cs Formatter menu selection plugins/lsp/keymaps.lua
Space ca Ⓝ Ⓥ Code action plugins/lsp/keymaps.lua
Space cA Source action plugins/lsp/keymaps.lua
Space cli LSP incoming calls plugins/lsp/keymaps.lua
Space clo LSP outgoing calls plugins/lsp/keymaps.lua
Space fwa Add workspace folder plugins/lsp/keymaps.lua
Space fwr Remove workspace folder plugins/lsp/keymaps.lua
Space fwl List workspace folders plugins/lsp/keymaps.lua
Space cgd Glance definitions dnlhc/glance.nvim
Space cgr Glance references dnlhc/glance.nvim
Space cgy Glance type definitions dnlhc/glance.nvim
Space cgi Glance implementations dnlhc/glance.nvim
Space cgu Glance resume dnlhc/glance.nvim

Diagnostics

Key Mode Action Plugin or Mapping
Space ud Toggle buffer diagnostics plugins/lsp/keymaps.lua
Space xt List TODO with Trouble folke/todo-comments.nvim
Space xT List TODO/FIXME with Trouble folke/todo-comments.nvim
Space st Select TODO with Telescope folke/todo-comments.nvim
Space sT Select TODO/FIXME with Telescope folke/todo-comments.nvim
Space xx Toggle Trouble folke/trouble.nvim
Space xd Toggle Trouble document folke/trouble.nvim
Space xw Toggle Trouble workspace folke/trouble.nvim
Space xq Toggle Quickfix via Trouble folke/trouble.nvim
Space xl Toggle Locationlist via Trouble folke/trouble.nvim

Coding

Key Mode Action Plugin or Mapping
Ctrl+q Start recording macro q
Space cf Ⓝ Ⓥ Format [plugins/formatting.lua]
Space cF Ⓝ Ⓥ Format injected langs [plugins/formatting.lua]
Space cc Generate doc annotations danymat/neogen
Shift+Return Start new line from any cursor position <C-o>o
] Space Add new line below o<Esc>
[ Space Add new line above O<Esc>
gc Ⓝ Ⓥ Comment prefix numToStr/Comment.nvim
gcc Ⓝ Ⓥ Toggle comments numToStr/Comment.nvim
Space+j or k Ⓝ Ⓥ Move lines down/up :m
Space+v Ⓝ Ⓥ Toggle line-wise comments numToStr/Comment.nvim
Space+V Ⓝ Ⓥ Toggle block-wise comments numToStr/Comment.nvim
Space+dd Ⓝ Ⓥ Duplicate line or selection config/keymaps.lua
Space+cw Remove all spaces at EOL echasnovski/mini.trailspace
Space+cid LazyDev folke/lazydev.nvim
Space+cif LazyFormatterInfo [LazyVim/LazyVim]
Space+cir LazyRoot [LazyVim/LazyVim]
sj / sk Join/split arguments echasnovski/mini.splitjoin

Search, Substitute, Diff

Key Mode Action Plugin or Mapping
* / # Ⓝ Ⓥ Search partial words g* / g#
g* / g# Ⓝ Ⓥ Search whole-word forward/backward * / #
Ctrl+c Change inner word ciw
Escape Clear search highlight :nohlsearch
Backspace Match bracket %
Space+bf Diff current windows in tab windo diffthis
Space+bF External diff !vim.g.diffprg % #
ss Ⓝ Ⓥ Ⓞ Flash jump folke/flash.nvim
S Ⓝ Ⓥ Ⓞ Flash treesitter folke/flash.nvim
r Flash remote folke/flash.nvim
R Ⓥ Ⓞ Flash treesitter search folke/flash.nvim
Ctrl+s Toggle flash in search input folke/flash.nvim

Command & History

Key Mode Action Plugin or Mapping
g! Read vim command into buffer :put=execute('⌴')
Ctrl+n / p Switch history search pairs /
/ Switch history search pairs Ctrl n/p

File Operations

Key Mode Action Plugin or Mapping
Space+cd Switch tab to the directory of current buffer :tcd %:p:h
Space+w or M+s Write buffer to file :write
Ctrl+s Ⓝ Ⓥ Ⓒ Write buffer to file :write

Window Management

Key Mode Action Plugin or Mapping
q Quit window (if last window, quit nvim) :quit
Ctrl+x Rotate window placement C-w x
Space qq Quit all and exit :quitall
sp Choose a window to edit s1n7ax/nvim-window-picker
sw Switch editing window with selected s1n7ax/nvim-window-picker
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
sh Toggle colorscheme background=dark/light :set background

Plugins

Key Mode Action Plugin or Mapping
;+c Open context-menu lua/rafi/util/contextmenu.lua
gCtrl+o Navigate to previous file on jumplist util/edit.lua
gCtrl+i Navigate to next file on jumplist util/edit.lua
Ctrl+/ Toggle terminal folke/snacks.nvim
Space l Open Lazy folke/lazy.nvim
Space o Open Outline side [hedyhli/outline.nvim]
Space ? Open the macOS dictionary on current word :!open dict://
Space cp Toggle Markdown preview iamcco/markdown-preview.nvim
Space mc Open color-picker uga-rosa/ccc.nvim
Space tt Open terminal (root dir) config/keymaps.lua
Space tT Open terminal (cwd) config/keymaps.lua
Space gt Open Lazygit (root dir) config/keymaps.lua
Space gT Open Lazygit (cwd) config/keymaps.lua
Space gF Open Lazygit on current file history config/keymaps.lua
Space gl Open Lazygit log config/keymaps.lua
Space gL Open Lazygit log (cwd) config/keymaps.lua
Space gb Git blame FabijanZulj/blame.nvim
Space gB Git blame in window FabijanZulj/blame.nvim
Space gm Reveal commit under cursor config/keymaps.lua
Space go Ⓝ Ⓥ Open source-code URL in browser config/keymaps.lua
Space gY Ⓝ Ⓥ Copy source-code URL config/keymaps.lua
Space gu Open undo-tree mbbill/undotree
Space mg Open Neogit NeogitOrg/neogit
Space ml Append modeline to end of buffer config/keymaps.lua
Space mda Sequentially mark region for diff AndrewRadev/linediff.vim
Space mdf Mark region for diff and compare if more than one AndrewRadev/linediff.vim
Space mds Shows the comparison for all marked regions AndrewRadev/linediff.vim
Space mdr Removes the signs denoting the diff regions AndrewRadev/linediff.vim
Space mh Open HTTP Rest UI rest-nvim/rest.nvim
Space mt Ⓝ Ⓥ Toggle highlighted word t9md/vim-quickhl
Space mo Update Markdown TOC mzlogin/vim-markdown-toc

Plugin: Mini.Surround

See echasnovski/mini.surround for more mappings and usage information.

Key Mode Action
sa & movement Ⓝ Ⓥ Add surrounding
cs & movement Replace surrounding
ds & movement Delete surrounding
gzf & movement Find surrounding (to the right)
gzF & movement Find surrounding (to the left)
gzh & movement Highlight surrounding
gzn & movement Update neighbor lines

Plugin: Gitsigns

See lewis6991/gitsigns.nvim for more mappings and usage information.

Key Mode Action
]g or ]g Next/previous Git hunk
gs Preview hunk
Space hp Preview hunk inline
Space hb Blame line
Space hs Ⓝ Ⓥ Stage hunk
Space hr Ⓝ Ⓥ Reset hunk
Space hu Undo stage hunk
Space hS Stage buffer
Space hR Reset buffer
Space hd Diff against the index
Space hD Diff against the last commit
Space hw Toggle word diff
Space hl Publish hunks to location-list
Space htb Toggle git current line blame
Space htd Toggle git deleted
Space htw Toggle git word diff
Space htl Toggle git line highlight
Space htn Toggle git number highlight
Space hts Toggle git signs
ih Select inner hunk operator

Plugin: Diffview

See sindrets/diffview.nvim for more mappings and usage information.

Key Mode Action
Space gd Diff view file history
Space gv Diff view open
 
Within diffview "view" window  
 
Tab / Shift+Tab Select next/previous entry
; a Focus file
; e Toggle files panel
 
Within diffview "file" panel  
 
q Close
h Previous entry
o Focus entry
gf Open file
sg Open file in split
st Open file in new tab
Ctrl+r Refresh files
; e Toggle panel
 
Within diffview "history" panel  
 
q Close diffview
o Focus entry
O Show options

Plugin: Telescope

See telescope.nvim for more mappings and usage information.

Key Mode Action
;r Results of the previous picker
;p List of the previous pickers
;f File search
;g Grep search
;b Buffers
;h Highlights
;j Jump points
;m Marks
;o Vim options
;t LSP workspace symbols
;v Ⓝ Ⓥ Yank history
;n Plugins
;k Thesaurus
;u Spelling suggestions
;s Sessions
;x Old files
;w Zk notes
;z Zoxide directories
;; Command history
;: Commands
;/ Search history
;dd LSP definitions
;di LSP implementations
;dr LSP references
;da Ⓝ Ⓥ LSP code actions
Space / Buffer fuzzy find
Space gs Git status
Space gr Git branches
Space gh Git stashes
Space gf Find files matching word under cursor
Space gg Ⓝ Ⓥ Grep word under cursor
Space sc Colorschemes
Space sd Document diagnostics
Space sD Workspace diagnostics
Space sh Help tags
Space sk Key-maps
Space sm Man pages
Space ss LSP document symbols
Space sS LSP workspace symbols
Space st Todo list
Space sT Todo/Fix/Fixme list
Space sw Grep string
 
Within Telescope window  
 
? Keymaps help screen
Ctrl+Space Move from none fuzzy search to fuzzy
jj or Escape Leave Insert mode
i Enter Insert mode (filter input)
q or Escape Exit Telescope
Tab or Shift+Tab Ⓝ Ⓘ Next/previous candidate
Ctrl+d/u Ⓝ Ⓘ Scroll down/upwards
Ctrl+f/b Ⓝ Ⓘ Scroll preview down/upwards
Ctrl+j/k Ⓝ Ⓘ Scroll preview vertically
Ctrl+h/l Ⓝ Ⓘ Scroll preview horizontally
J or K Select candidates up/downwards
st Open in a new tab
sg Open in a vertical split
sv Open in a split
* Toggle selection
u Drop all
w Smart send to quickfix list
e Send to quickfix list
Ctrl+q Send to quickfix list
dd Delete entry (buffer list)
! Edit in command line

Plugin: Neo-Tree

See nvim-neo-tree/neo-tree.nvim for more mappings and usage information.

Key Mode Action
fe / Spacee Toggle file explorer (root)
fE / SpaceE Toggle file explorer (cwd)
ge Open Git explorer
be Open Buffer explorer
xe Open Document explorer
;a Focus current file in file-explorer
 
Within Neo-Tree window  
 
g? Show help
q Close window
j or k Move up and down the tree
Tab or Shift+Tab Next or previous source
]g or [g Jump to next/previous git modified node
l Toggle collapse/expand directory or open file
h Collapse directory tree
Return Select window to open file
gr Grep in current position
gf Find files in current position
. Set as root directory
Backspace Change into parent directory
sv or S Open file in a horizontal split
sg or s Open file in a vertical split
st or t Open file in new tab
p Preview toggle
a Create new directories and/or files
N Create new directory
r Rename file or directory
dd Delete
c / m Copy/move
y / x / P Clipboard copy/cut/paste
! Filter
D Filter directories
# Fuzzy sorter
F Filter on submit
Ctrl+c Clear filter
Ctrl+r or R Refresh
fi / fe Include/exclude
H Toggle hidden files
e Toggle auto-expand window width
w Toggle window width
z Collapse all nodes

Plugin: Marks

See chentau/marks.nvim for more mappings and usage information.

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<Space> Delete all marks in the current buffer
m] Move to next mark
m[ Move to previous mark
m: a-z Preview mark
m/ List marks from all opened buffers

Plugin: Zk

See zk-org/zk-nvim and zk for more mappings and usage information.

Key Mode Action
Space+zn Ask for title and create new note
Space+zo Browse notes sorted by modification time
Space+zt Browse tags
Space+zf Search notes
Space+zf Search notes with selection
Space+zb Show backlinks
Space+zl Show links