My favorite VIM based IDE !!

Abouzar Parvan 168eb232d1 feature: make peek function work in neovim head and 0.5 (#1559) 3 yıl önce
.github fcb764cd63 refactor(ci): better path handling (#1531) 3 yıl önce
colors 0f458a0468 onedarker colorscheme 3 yıl önce
ftdetect f82ffdca1f Add support for bicep (#1451) 3 yıl önce
ftplugin 5cdd742354 fix not being able to add linters and formatters to docker (#1486) 3 yıl önce
lua 168eb232d1 feature: make peek function work in neovim head and 0.5 (#1559) 3 yıl önce
tests 8eed75d67f refactor: use more flexible paths (#1381) 3 yıl önce
utils edcf15ba67 chore: add demo images 3 yıl önce
.gitignore a6cf2e871a stylua is always in root 4 yıl önce
.luacheckrc 8eed75d67f refactor: use more flexible paths (#1381) 3 yıl önce
.pre-commit-config.yaml 38f53bf08c [Feature]: Add some very basic unit-tests (#1369) 3 yıl önce
.stylua.toml a6cf2e871a stylua is always in root 4 yıl önce
CONTRIBUTING.md 0df3ec9277 fix: Fix matrix links (#1470) 3 yıl önce
LICENSE d3e94f3086 update license 4 yıl önce
Makefile 38f53bf08c [Feature]: Add some very basic unit-tests (#1369) 3 yıl önce
README.md edcf15ba67 chore: add demo images 3 yıl önce
init.lua 8eed75d67f refactor: use more flexible paths (#1381) 3 yıl önce

README.md

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 = "InsertEnter"
    }
}

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
:PackerSync

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:

which lvim
# if output is /usr/local/bin/lvim remove it
sudo rm /usr/local/bin/lvim

which lvim
# if output is ~/.local/bin/lvim, open lvim and run :PackerSync.  That should get you to a working state

# otherwise if `which lvim` returns `not found`, 
Make sure the `lvim` file exists in `~/.local/bin/lvim`.  
If the file exists,make sure `~/.local/bin` is in your PATH.  If not, [add it](https://www.lunarvim.org/02-after-install.html#add-lvim-to-path)
either reinstall again or manually add the lunarvim launcher

If the file doesn't exist, create the file
cd ~/.local/bin
touch lvim
chmod 755 lvim

And then add the following to the lvim file you created. Replace all torvalds with your user name

#!/bin/sh

export LUNARVIM_CONFIG_DIR="${LUNARVIM_CONFIG_DIR:-/home/torvalds/.config/lvim}"
export LUNARVIM_RUNTIME_DIR="${LUNARVIM_RUNTIME_DIR:-/home/torvalds/.local/share/lunarvim}"

exec nvim -u "$LUNARVIM_RUNTIME_DIR/lvim/init.lua" "$@"

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)