🌙 LunarVim is an IDE layer for Neovim. Completely free and community driven.
Find a file
2021-09-25 20:47:50 +03:30
.github refactor(ci): better path handling (#1531) 2021-09-13 11:10:07 +02:00
colors onedarker colorscheme 2021-08-30 00:59:23 -04:00
ftdetect [Feature]: add basic JSONC support (#1535) 2021-09-21 09:02:15 +02:00
ftplugin fix not being able to add linters and formatters to docker (#1486) 2021-09-06 21:41:54 +04:30
lua update nvim-tree based on the refactor (#1617) 2021-09-25 20:47:50 +03:30
tests refactor: use more flexible paths (#1381) 2021-09-13 11:28:15 +02:00
utils fix: Rework Dockerfile to run lvim (#1593) 2021-09-23 15:38:31 +03:30
.gitignore stylua is always in root 2021-07-25 14:14:05 -04:00
.luacheckrc [Feature] Add lunarvim latest release tag to dashboard (#1436) 2021-09-17 04:13:52 -07:00
.pre-commit-config.yaml [Feature]: Add some very basic unit-tests (#1369) 2021-09-09 18:53:21 +02:00
.stylua.toml stylua is always in root 2021-07-25 14:14:05 -04:00
CONTRIBUTING.md fix: Fix matrix links (#1470) 2021-09-04 21:51:31 +04:30
init.lua refactor: use more flexible paths (#1381) 2021-09-13 11:28:15 +02:00
LICENSE update license 2021-03-15 10:47:00 -04:00
Makefile [Feature]: Add some very basic unit-tests (#1369) 2021-09-09 18:53:21 +02:00
README.md fix lsp_signature in readme 2021-09-21 12:23:02 +04:30

LunarVim Demo

Documentation

You can find all of the documentation for Lunarvim at lunarvim.org

Install In One Command!

Make sure you have the release version of Neovim (0.5).

If you have previously installed LunarVim, make sure to remove /usr/local/bin/lvim, as we've moved the launcher to ~/.local/bin/lvim

bash <(curl -s https://raw.githubusercontent.com/lunarvim/lunarvim/master/utils/installer/install.sh)

Install Language support

  • Enter :LspInstall followed by <TAB> to see your options for LSP

  • Enter :TSInstall followed by <TAB> to see your options for syntax highlighting

NOTE I recommend installing lua for autocomplete in config.lua

Demo1 Demo2 Demo3

Configuration file

To install plugins configure LunarVim use the config.lua located here: ~/.config/lvim/config.lua

Example:

-- general
lvim.format_on_save = true
lvim.colorscheme = "onedarker"

lvim.leader = "space"
-- add your own keymapping
lvim.keys.normal_mode["<C-s>"] = ":w<cr>"
-- unmap a default keymapping
-- lvim.keys.normal_mode["<C-Up>"] = ""
-- edit a default keymapping
-- lvim.keys.normal_mode["<C-q>"] = ":q<cr>"
-- set keymap with custom opts
-- lvim.keys.insert_mode["po"] = {'<ESC>', { noremap = true }}

-- Use which-key to add extra bindings with the leader-key prefix
-- lvim.builtin.which_key.mappings["P"] = { "<cmd>Telescope projects<CR>", "Projects" }

-- Configure builtin plugins
lvim.builtin.dashboard.active = true
lvim.builtin.terminal.active = true

-- Treesitter parsers change this to a table of the languages you want i.e. {"java", "python", javascript}
lvim.builtin.treesitter.ensure_installed = "maintained"
lvim.builtin.treesitter.ignore_install = { "haskell" }

-- Disable virtual text
lvim.lsp.diagnostics.virtual_text = false

-- set a formatter if you want to override the default lsp one (if it exists)
lvim.lang.python.formatters = {
  {
    exe = "black",
    args = {}
  }
}
-- set an additional linter
lvim.lang.python.linters = {
  {
    exe = "flake8",
    args = {}
  }
}


-- Additional Plugins
lvim.plugins = {
    {"lunarvim/colorschemes"},
    {"folke/tokyonight.nvim"}, {
        "ray-x/lsp_signature.nvim",
        config = function() require"lsp_signature".on_attach() end,
        event = "BufRead"
    }
}

Updating LunarVim

In order to update you should be aware of three things Plugins, LunarVim and Neovim

To update plugins:

:PackerUpdate

To update LunarVim:

cd ~/.local/share/lunarvim/lvim && git pull
lvim +LvimCacheReset +PackerUpdate

Known Issues

If you get either of the following errors

  • init.lua:6: module 'bootstrap' not found:
  • /home/user/.config/nvim/config.lua not found, falling back to /home/user/.config/nvim/lv-config.lua

Try the following methods:

  1. clear up the cache files used by the startup processing. You can either pass it as an argument
lvim +LvimCacheReset

or just call it manually when inside LunarVim :LvimCacheReset

  1. make sure your lvim binary is up-to-date
LUNARVIM_RUNTIME_DIR="${LUNARVIM_RUNTIME_DIR:-$HOME/.local/share/lunarvim}"
bash "$LUNARVIM_RUNTIME_DIR/utils/installer/install_bin.sh"

Resources

Testimonials

"I have the processing power of a potato with 4 gb of ram and LunarVim runs perfectly."

  • @juanCortelezzi, LunarVim user.

"My minimal config with a good amount less code than LunarVim loads 40ms slower. Time to switch."

  • @mvllow, Potential LunarVim user.

Lua