Last active
January 5, 2023 08:29
-
-
Save rob1121/d25e74acf1baa916f11b75e8c54ae5c7 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
--[[ | |
THESE ARE EXAMPLE CONFIGS FEEL FREE TO CHANGE TO WHATEVER YOU WANT | |
`lvim` is the global options object | |
]] | |
-- Enable powershell as your default shell | |
vim.opt.shell = "pwsh.exe -NoLogo" | |
vim.opt.shellcmdflag = | |
"-NoLogo -NoProfile -ExecutionPolicy RemoteSigned -Command [Console]::InputEncoding=[Console]::OutputEncoding=[System.Text.Encoding]::UTF8;" | |
vim.cmd [[ | |
let &shellredir = '2>&1 | Out-File -Encoding UTF8 %s; exit $LastExitCode' | |
let &shellpipe = '2>&1 | Out-File -Encoding UTF8 %s; exit $LastExitCode' | |
set shellquote= shellxquote= | |
]] | |
-- Set a compatible clipboard manager | |
vim.g.clipboard = { | |
copy = { | |
["+"] = "win32yank.exe -i --crlf", | |
["*"] = "win32yank.exe -i --crlf", | |
}, | |
paste = { | |
["+"] = "win32yank.exe -o --lf", | |
["*"] = "win32yank.exe -o --lf", | |
}, | |
} | |
-- general | |
lvim.log.level = "warn" | |
lvim.format_on_save.enabled = false | |
lvim.colorscheme = "lunar" | |
-- to disable icons and use a minimalist setup, uncomment the following | |
-- lvim.use_icons = false | |
-- keymappings [view all the defaults by pressing <leader>Lk] | |
lvim.leader = "space" | |
-- add your own keymapping | |
lvim.keys.normal_mode["<C-s>"] = ":w<cr>" | |
lvim.keys.normal_mode["<S-h>"] = ":bprev<cr>" | |
lvim.keys.normal_mode["<S-l>"] = ":bnext<cr>" | |
vim.keymap.set('i','jj','<Esc>') | |
vim.keymap.set('i','jk','<Esc>') | |
vim.keymap.set('i','kj','<Esc>') | |
vim.keymap.set('i','kk','<Esc>') | |
-- lvim.keys.normal_mode["<S-l>"] = ":BufferLineCycleNext<CR>" | |
-- lvim.keys.normal_mode["<S-h>"] = ":BufferLineCyclePrev<CR>" | |
-- unmap a default keymapping | |
-- vim.keymap.del("n", "<C-Up>") | |
-- override a default keymapping | |
-- lvim.keys.normal_mode["<C-q>"] = ":q<cr>" -- or vim.keymap.set("n", "<C-q>", ":q<cr>" ) | |
-- Change Telescope navigation to use j and k for navigation and n and p for history in both input and normal mode. | |
-- we use protected-mode (pcall) just in case the plugin wasn't loaded yet. | |
-- local _, actions = pcall(require, "telescope.actions") | |
lvim.builtin.telescope.defaults.mappings = { | |
-- -- for input mode | |
i = { | |
-- ["<C-j>"] = actions.move_selection_next, | |
-- ["<C-k>"] = actions.move_selection_previous, | |
-- ["<C-n>"] = actions.cycle_history_next, | |
-- ["<C-p>"] = actions.cycle_history_prev, | |
} | |
-- -- for normal mode | |
-- n = { | |
-- ["<C-j>"] = actions.move_selection_next, | |
-- ["<C-k>"] = actions.move_selection_previous, | |
-- }, | |
} | |
-- Change theme settings | |
-- lvim.builtin.theme.options.dim_inactive = true | |
-- lvim.builtin.theme.options.style = "storm" | |
-- Use which-key to add extra bindings with the leader-key prefix | |
-- lvim.builtin.which_key.mappings["P"] = { "<cmd>Telescope projects<CR>", "Projects" } | |
-- lvim.builtin.which_key.mappings["t"] = { | |
-- name = "+Trouble", | |
-- r = { "<cmd>Trouble lsp_references<cr>", "References" }, | |
-- f = { "<cmd>Trouble lsp_definitions<cr>", "Definitions" }, | |
-- d = { "<cmd>Trouble document_diagnostics<cr>", "Diagnostics" }, | |
-- q = { "<cmd>Trouble quickfix<cr>", "QuickFix" }, | |
-- l = { "<cmd>Trouble loclist<cr>", "LocationList" }, | |
-- w = { "<cmd>Trouble workspace_diagnostics<cr>", "Workspace Diagnostics" }, | |
-- } | |
-- After changing plugin config exit and reopen LunarVim, Run :PackerInstall :PackerCompile | |
lvim.builtin.alpha.active = true | |
lvim.builtin.alpha.mode = "dashboard" | |
lvim.builtin.terminal.active = false | |
-- lvim.builtin.terminal.shell = "pwsh.exe -NoLogo" | |
-- nvim-tree has some performance issues on windows, see kyazdani42/nvim-tree.lua#549 | |
lvim.builtin.nvimtree.setup.diagnostics.enable = nil | |
lvim.builtin.nvimtree.setup.filters.custom = nil | |
lvim.builtin.nvimtree.setup.git.enable = nil | |
lvim.builtin.nvimtree.setup.update_cwd = nil | |
lvim.builtin.nvimtree.setup.update_focused_file.update_cwd = nil | |
lvim.builtin.nvimtree.setup.view.side = "left" | |
lvim.builtin.nvimtree.setup.renderer.highlight_git = nil | |
lvim.builtin.nvimtree.setup.renderer.icons.show.git = nil | |
-- if you don't want all the parsers change this to a table of the ones you want | |
lvim.builtin.treesitter.ensure_installed = { | |
"c", | |
"lua", | |
} | |
lvim.builtin.treesitter.ignore_install = { "haskell" } | |
lvim.builtin.treesitter.highlight.enable = true | |
-- generic LSP settings | |
-- -- make sure server will always be installed even if the server is in skipped_servers list | |
-- lvim.lsp.installer.setup.ensure_installed = { | |
-- "sumneko_lua", | |
-- "jsonls", | |
-- } | |
-- -- change UI setting of `LspInstallInfo` | |
-- -- see <https://github.com/williamboman/nvim-lsp-installer#default-configuration> | |
-- lvim.lsp.installer.setup.ui.check_outdated_servers_on_open = false | |
-- lvim.lsp.installer.setup.ui.border = "rounded" | |
-- lvim.lsp.installer.setup.ui.keymaps = { | |
-- uninstall_server = "d", | |
-- toggle_server_expand = "o", | |
-- } | |
-- ---@usage disable automatic installation of servers | |
-- lvim.lsp.installer.setup.automatic_installation = false | |
-- ---configure a server manually. !!Requires `:LvimCacheReset` to take effect!! | |
-- ---see the full default list `:lua print(vim.inspect(lvim.lsp.automatic_configuration.skipped_servers))` | |
-- vim.list_extend(lvim.lsp.automatic_configuration.skipped_servers, { "pyright" }) | |
-- local opts = {} -- check the lspconfig documentation for a list of all possible options | |
-- require("lvim.lsp.manager").setup("pyright", opts) | |
-- ---remove a server from the skipped list, e.g. eslint, or emmet_ls. !!Requires `:LvimCacheReset` to take effect!! | |
-- ---`:LvimInfo` lists which server(s) are skipped for the current filetype | |
-- lvim.lsp.automatic_configuration.skipped_servers = vim.tbl_filter(function(server) | |
-- return server ~= "emmet_ls" | |
-- end, lvim.lsp.automatic_configuration.skipped_servers) | |
-- -- you can set a custom on_attach function that will be used for all the language servers | |
-- -- See <https://github.com/neovim/nvim-lspconfig#keybindings-and-completion> | |
-- lvim.lsp.on_attach_callback = function(client, bufnr) | |
-- local function buf_set_option(...) | |
-- vim.api.nvim_buf_set_option(bufnr, ...) | |
-- end | |
-- --Enable completion triggered by <c-x><c-o> | |
-- buf_set_option("omnifunc", "v:lua.vim.lsp.omnifunc") | |
-- end | |
local formatters = require "lvim.lsp.null-ls.formatters" | |
formatters.setup { | |
-- { command = "black", filetypes = { "python" } }, | |
-- { command = "isort", filetypes = { "python" } }, | |
{ | |
-- -- each formatter accepts a list of options identical to https://github.com/jose-elias-alvarez/null-ls.nvim/blob/main/doc/BUILTINS.md#Configuration | |
command = "prettier", | |
prefer_local = "node_modules/.bin", | |
-- ---@usage arguments to pass to the formatter | |
-- -- these cannot contain whitespaces, options such as `--line-width 80` become either `{'--line-width', '80'}` or `{'--line-width=80'}` | |
-- extra_args = { "--print-with", "100" }, | |
-- ---@usage specify which filetypes to enable. By default a providers will attach to all the filetypes it supports. | |
filetypes = { "typescript", "typescriptreact", "javascript", "javascriptreact", "json", "css", "graphql", "vue" }, | |
}, | |
} | |
-- -- 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", filetypes = { "python" } }, | |
-- { command = "isort", filetypes = { "python" } }, | |
-- { | |
-- -- each formatter accepts a list of options identical to https://github.com/jose-elias-alvarez/null-ls.nvim/blob/main/doc/BUILTINS.md#Configuration | |
-- command = "prettier", | |
-- ---@usage arguments to pass to the formatter | |
-- -- these cannot contain whitespaces, options such as `--line-width 80` become either `{'--line-width', '80'}` or `{'--line-width=80'}` | |
-- extra_args = { "--print-with", "100" }, | |
-- ---@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 = "flake8", filetypes = { "python" } }, | |
-- { | |
-- -- each linter accepts a list of options identical to https://github.com/jose-elias-alvarez/null-ls.nvim/blob/main/doc/BUILTINS.md#Configuration | |
-- command = "shellcheck", | |
-- ---@usage arguments to pass to the formatter | |
-- -- these cannot contain whitespaces, options such as `--line-width 80` become either `{'--line-width', '80'}` or `{'--line-width=80'}` | |
-- extra_args = { "--severity", "warning" }, | |
-- }, | |
-- { | |
-- command = "codespell", | |
-- ---@usage specify which filetypes to enable. By default a providers will attach to all the filetypes it supports. | |
-- filetypes = { "javascript", "python" }, | |
-- }, | |
-- } | |
-- Additional Plugins | |
-- lvim.plugins = { | |
-- { | |
-- "folke/trouble.nvim", | |
-- cmd = "TroubleToggle", | |
-- }, | |
-- } | |
-- Autocommands (https://neovim.io/doc/user/autocmd.html) | |
-- vim.api.nvim_create_autocmd("BufEnter", { | |
-- pattern = { "*.json", "*.jsonc" }, | |
-- -- enable wrap mode for json files only | |
-- command = "setlocal wrap", | |
-- }) | |
-- vim.api.nvim_create_autocmd("FileType", { | |
-- pattern = "zsh", | |
-- callback = function() | |
-- -- let treesitter use bash highlight for zsh files as well | |
-- require("nvim-treesitter.highlight").attach(0, "bash") | |
-- end, | |
-- }) |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment