My favorite VIM based IDE !!

ChristianChiarulli ebb6225398 fix: move lualine theme for onedarker, we can fix this later 4 yıl önce
.github 32ca5afa4a feat: better error handling for packer (#1883) 4 yıl önce
colors 0f458a0468 onedarker colorscheme 4 yıl önce
ftdetect 68d2678af3 feat: add filetype detection for solidity 4 yıl önce
lua ebb6225398 fix: move lualine theme for onedarker, we can fix this later 4 yıl önce
tests 32ca5afa4a feat: better error handling for packer (#1883) 4 yıl önce
utils a6845c9cc7 fix: dashboard now runs on fresh installs (#1896) 4 yıl önce
.gitignore a6cf2e871a stylua is always in root 4 yıl önce
.luacheckrc 5cf8c07ee9 fix(bootstrap): support for using default neovim config and data directories (#1777) 4 yıl önce
.pre-commit-config.yaml 346925fcdc feat: add commitlint CI (#1459) 4 yıl önce
.stylua.toml a6cf2e871a stylua is always in root 4 yıl önce
CONTRIBUTING.md fe6e7591d8 fix: add proper installation link (#1665) 4 yıl önce
LICENSE d3e94f3086 update license 4 yıl önce
Makefile 38f53bf08c [Feature]: Add some very basic unit-tests (#1369) 4 yıl önce
README.md efe30f26a7 chore: update docs to reflect recent changes (#1841) 4 yıl önce
init.lua 7a813780a1 fix: overloading keymappings now works correctly even after reloading (#1789) 4 yıl önce

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

-- Select which servers should be configured manually. Requires `:LvimCacheRest` to take effect.
-- See the full default list `:lua print(vim.inspect(lvim.lsp.override))`
vim.list_extend(lvim.lsp.override, { "pyright" })

-- set a formatter, this will override the language server formatting capabilities (if it exists)
local formatters = require "lvim.lsp.null-ls.formatters"
formatters.setup {
  { exe = "black" },
  {
    exe = "prettier",
    ---@usage specify which filetypes to enable. By default a providers will attach to all the filetypes it supports.
    filetypes = { "typescript", "typescriptreact" },
  },
}

-- set additional linters
local linters = require "lvim.lsp.null-ls.linters"
linters.setup {
  { exe = "black" },
  {
    exe = "eslint_d",
    ---@usage specify which filetypes to enable. By default a providers will attach to all the filetypes it supports.
    filetypes = { "javascript", "javascriptreact" },
  },
}


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

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)