Some notes from installing it:
- Make sure all plugins are installed by calling
:Lazyand syncing all plugins. - Will have to reinstall debugpy python venv based on your OS.
- Live grep requires
ripgrep, which is a command line tool you need to install system wide (not just a nvim dependency). - We use
lazy.nvimfor all plugins, butmason.nvimjust to manage some LSP handlers (e.g., pyright). - Node has to be >= v14 for
pyrightto work. If it isn't, it may not work and mentionnodeerrors in the lsp-log.nvmis a useful way to manage multiple node versions.
Lockfiles are kept in lockfiles so you can keep track of different files for different systems. You can restore your plugins to those versions using :Lazy restore. When you generate a new lockfile, copy it to this directory. That way you have the current config as lazy-lock.json and a backup in lockfiles.
See the lazy.nvim documentation for a list of the commands. Here are the main ones you need to know:
:Lazy install: Installs missing plugins.:Lazy clean: Cleans plugins that are no longer needed.:Lazy update: Update plugins to newer versions (from online). This updates the lockfile to these new versions.:Lazy sync: Runinstall,clean, andupdate.:Lazy restore: Restore plugins to the state in the lockfile.
kickstart-nvim.mp4
This is a fork of nvim-lua/kickstart.nvim that moves from a single file to a multi file configuration.
A starting point for Neovim that is:
- Small
- Documented
- Modular
NOTE Backup your previous configuration (if any exists)
Requirements:
- Make sure to review the readmes of the plugins if you are experiencing errors. In particular:
- See Windows Installation if you have trouble with
telescope-fzf-native
Neovim's configurations are located under the following paths, depending on your OS:
| OS | PATH |
|---|---|
| Linux | $XDG_CONFIG_HOME/nvim, ~/.config/nvim |
| MacOS | $XDG_CONFIG_HOME/nvim, ~/.config/nvim |
| Windows (cmd) | %userprofile%\AppData\Local\nvim\ |
| Windows (powershell) | $env:USERPROFILE\AppData\Local\nvim\ |
Clone kickstart.nvim:
- on Linux and Mac
git clone https://github.com/nvim-lua/kickstart.nvim.git "${XDG_CONFIG_HOME:-$HOME/.config}"/nvim- on Windows (cmd)
git clone https://github.com/nvim-lua/kickstart.nvim.git %userprofile%\AppData\Local\nvim\
- on Windows (powershell)
git clone https://github.com/nvim-lua/kickstart.nvim.git $env:USERPROFILE\AppData\Local\nvim\
Start Neovim
nvimThe Lazy plugin manager will start automatically on the first run and install the configured plugins - as can be seen in the introduction video. After the installation is complete you can press q to close the Lazy UI and you are ready to go! Next time you run nvim Lazy will no longer show up.
If you would prefer to hide this step and run the plugin sync from the command line, you can use:
nvim --headless "+Lazy! sync" +qa- For adding plugins, there are 3 primary options:
- Add new configuration in
lua/custom/plugins/*files, which will be auto sourced usinglazy.nvim(uncomment the line importing thecustom/pluginsdirectory in theinit.luafile to enable this) - Modify
init.luawith additional plugins. - Include the
lua/kickstart/plugins/*files in your configuration.
- Add new configuration in
In the file: lua/custom/plugins/autopairs.lua, add:
-- File: lua/custom/plugins/autopairs.lua
return {
"windwp/nvim-autopairs",
-- Optional dependency
dependencies = { 'hrsh7th/nvim-cmp' },
config = function()
require("nvim-autopairs").setup {}
-- If you want to automatically add `(` after selecting a function or method
local cmp_autopairs = require('nvim-autopairs.completion.cmp')
local cmp = require('cmp')
cmp.event:on(
'confirm_done',
cmp_autopairs.on_confirm_done()
)
end,
}This will automatically install windwp/nvim-autopairs and enable it on startup. For more information, see documentation for lazy.nvim.
In the file: lua/custom/plugins/filetree.lua, add:
-- Unless you are still migrating, remove the deprecated commands from v1.x
vim.cmd([[ let g:neo_tree_remove_legacy_commands = 1 ]])
return {
"nvim-neo-tree/neo-tree.nvim",
version = "*",
dependencies = {
"nvim-lua/plenary.nvim",
"nvim-tree/nvim-web-devicons", -- not strictly required, but recommended
"MunifTanjim/nui.nvim",
},
config = function ()
require('neo-tree').setup {}
end,
}This will install the tree plugin and add the command :Neotree for you. You can explore the documentation at neo-tree.nvim for more information.
- What should I do if I already have a pre-existing neovim configuration?
- You should back it up, then delete all files associated with it.
- This includes your existing init.lua and the neovim files in
~/.localwhich can be deleted withrm -rf ~/.local/share/nvim/ - You may also want to look at the migration guide for lazy.nvim
- Can I keep my existing configuration in parallel to kickstart?
- Yes! You can use NVIM_APPNAME
=nvim-NAMEto maintain multiple configurations. For example you can install the kickstart configuration in~/.config/nvim-kickstartand create an alias:When you run Neovim usingalias nvim-kickstart='NVIM_APPNAME="nvim-kickstart" nvim'nvim-kickstartalias it will use the alternative config directory and the matching local directory~/.local/share/nvim-kickstart. You can apply this approach to any Neovim distribution that you would like to try out.
- Yes! You can use NVIM_APPNAME
- What if I want to "uninstall" this configuration:
- See lazy.nvim uninstall information
- Are there any cool videos about this plugin?
- Current iteration of kickstart (coming soon)
- Here is one about the previous iteration of kickstart: video introduction to Kickstart.nvim. Note the install via init.lua no longer works as specified. Please follow the install instructions in this file instead as they're up to date.
- Why is the kickstart
init.luaa single file? Wouldn't it make sense to split it into multiple files?- The main purpose of kickstart is to serve as a teaching tool and a reference
configuration that someone can easily
git cloneas a basis for their own. As you progress in learning Neovim and Lua, you might consider splittinginit.luainto smaller parts. A fork of kickstart that does this while maintaining the exact same functionality is available here: - Discussions on this topic can be found here:
- The main purpose of kickstart is to serve as a teaching tool and a reference
configuration that someone can easily
Installation may require installing build tools, and updating the run command for telescope-fzf-native
See telescope-fzf-native documentation for more details
This requires:
- Install CMake, and the Microsoft C++ Build Tools on Windows
{'nvim-telescope/telescope-fzf-native.nvim', build = 'cmake -S. -Bbuild -DCMAKE_BUILD_TYPE=Release && cmake --build build --config Release && cmake --install build --prefix build' }