My favorite VIM based IDE !!

kylo252 f87416c141 fix(null-ls): add common lsp-setup hooks (#1763) 4 gadi atpakaļ
.github e270bdbd6f [Bugfix]: Use local install in Github actions (#1628) 4 gadi atpakaļ
colors 0f458a0468 onedarker colorscheme 4 gadi atpakaļ
ftdetect 68d2678af3 feat: add filetype detection for solidity 4 gadi atpakaļ
lua f87416c141 fix(null-ls): add common lsp-setup hooks (#1763) 4 gadi atpakaļ
tests 52b7455741 feat: add an independent lvim namespace (#1699) 4 gadi atpakaļ
utils 8e4f97b0fb fix: restore windows installer default branch 4 gadi atpakaļ
.gitignore a6cf2e871a stylua is always in root 4 gadi atpakaļ
.luacheckrc 254ab2102b [Feature] Add lunarvim latest release tag to dashboard (#1436) 4 gadi atpakaļ
.pre-commit-config.yaml 346925fcdc feat: add commitlint CI (#1459) 4 gadi atpakaļ
.stylua.toml a6cf2e871a stylua is always in root 4 gadi atpakaļ
CONTRIBUTING.md fe6e7591d8 fix: add proper installation link (#1665) 4 gadi atpakaļ
LICENSE d3e94f3086 update license 4 gadi atpakaļ
Makefile 38f53bf08c [Feature]: Add some very basic unit-tests (#1369) 4 gadi atpakaļ
README.md efd8f589b7 fix: add deprecation notice for lvim.lang.foo.lsp (#1670) 4 gadi atpakaļ
init.lua 52b7455741 feat: add an independent lvim namespace (#1699) 4 gadi atpakaļ

README.md

LunarVim Demo

Documentation

You can find all the documentation for LunarVim at lunarvim.org

Install In One Command!

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

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

  • inside LunarVim :LvimUpdate
  • from the command-line lvim +LvimUpdate +q

Update the plugins

  • inside LunarVim :PackerUpdate

Breaking changes

  • lvim.lang.FOO.lsp is no longer supported after #1584. You can either use :NlspConfig for most of the settings you might need, or override the setup by adding an entry to lvim.lsp.override = { "FOO" }.

Resources

Testimonials

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

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

  • @mvllow, Potential LunarVim user.
[![Lua](https://img.shields.io/badge/Made%20with%20Lua-blue.svg?style=for-the-badge&logo=lua)](#madewithlua)