My favorite VIM based IDE !!

kylo252 d0840511d8 Merge branch 'rolling' 3 سال پیش
.github 679cadf590 chore: update the changelog 3 سال پیش
colors 0f458a0468 onedarker colorscheme 3 سال پیش
ftdetect 77bf0e3ea8 feat: add support for fsharp (#2021) 3 سال پیش
lua d0840511d8 Merge branch 'rolling' 3 سال پیش
tests 66e8facb15 chore(tests): use cmd_env in minimal_lsp.lua (#2158) 3 سال پیش
utils 4a66d4752d fix(null-ls): avoid sending invalid opts.args (#2154) 3 سال پیش
.gitignore a6cf2e871a stylua is always in root 4 سال پیش
.luacheckrc eefc148313 refactor(bootstrap): more robust git module (#2127) 3 سال پیش
.pre-commit-config.yaml 346925fcdc feat: add commitlint CI (#1459) 3 سال پیش
.stylua.toml a6cf2e871a stylua is always in root 4 سال پیش
CHANGELOG.md 8259cf60bb chore: update changelog 3 سال پیش
CONTRIBUTING.md fe6e7591d8 fix: add proper installation link (#1665) 3 سال پیش
LICENSE d3e94f3086 update license 4 سال پیش
Makefile 21b41688ee refactor: use a static lvim binary template (#1444) 3 سال پیش
README.md 4a66d4752d fix(null-ls): avoid sending invalid opts.args (#2154) 3 سال پیش
init.lua fe95dffe41 fix: no restart required when changing colorscheme (#2026) 3 سال پیش

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

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.notify.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 {
  { command = "black" },
  {
    command = "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 {
  { command = "black" },
  {
    command = "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 is no longer supported. Refer to https://www.lunarvim.org/languages for up-to-date instructions.
  • lvim.lsp.popup_border has been deprecated in favor of lvim.lsp.float.border and lvim.lsp.diagnostics.float.border.

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)