From 1d7b04a71c7222153ffa9cd48f73b51ea72204d1 Mon Sep 17 00:00:00 2001 From: seth Date: Sat, 18 Feb 2023 05:13:27 -0500 Subject: major refactor - `mkHost` now accepts an optional `specialArgs` argument to be passed to `nixosSystem()` - the `modules` argument for `mkHMUser` is now optional --- .../neovim/config/lua/getchoo/ftdetect.lua | 12 -- .../programs/neovim/config/lua/getchoo/init.lua | 52 -------- .../programs/neovim/config/lua/getchoo/keymap.lua | 27 ---- .../neovim/config/lua/getchoo/lsp/config/cmp.lua | 71 ---------- .../neovim/config/lua/getchoo/lsp/config/init.lua | 27 ---- .../config/lua/getchoo/lsp/config/lsp_config.lua | 44 ------ .../config/lua/getchoo/lsp/config/null_ls.lua | 42 ------ .../config/lua/getchoo/lsp/config/sources.lua | 26 ---- .../neovim/config/lua/getchoo/lsp/init.lua | 11 -- .../neovim/config/lua/getchoo/lsp/keymap.lua | 21 --- .../neovim/config/lua/getchoo/lsp/server.lua | 15 --- users/seth/programs/neovim/default.nix | 148 +++++++++------------ .../seth/programs/neovim/lua/getchoo/ftdetect.lua | 12 ++ users/seth/programs/neovim/lua/getchoo/init.lua | 49 +++++++ users/seth/programs/neovim/lua/getchoo/keymap.lua | 27 ++++ .../programs/neovim/lua/getchoo/lsp/config/cmp.lua | 71 ++++++++++ .../neovim/lua/getchoo/lsp/config/init.lua | 27 ++++ .../neovim/lua/getchoo/lsp/config/lsp_config.lua | 44 ++++++ .../neovim/lua/getchoo/lsp/config/null_ls.lua | 42 ++++++ .../neovim/lua/getchoo/lsp/config/sources.lua | 26 ++++ .../seth/programs/neovim/lua/getchoo/lsp/init.lua | 11 ++ .../programs/neovim/lua/getchoo/lsp/keymap.lua | 21 +++ .../programs/neovim/lua/getchoo/lsp/server.lua | 15 +++ 23 files changed, 405 insertions(+), 436 deletions(-) delete mode 100644 users/seth/programs/neovim/config/lua/getchoo/ftdetect.lua delete mode 100644 users/seth/programs/neovim/config/lua/getchoo/init.lua delete mode 100644 users/seth/programs/neovim/config/lua/getchoo/keymap.lua delete mode 100644 users/seth/programs/neovim/config/lua/getchoo/lsp/config/cmp.lua delete mode 100644 users/seth/programs/neovim/config/lua/getchoo/lsp/config/init.lua delete mode 100644 users/seth/programs/neovim/config/lua/getchoo/lsp/config/lsp_config.lua delete mode 100644 users/seth/programs/neovim/config/lua/getchoo/lsp/config/null_ls.lua delete mode 100644 users/seth/programs/neovim/config/lua/getchoo/lsp/config/sources.lua delete mode 100644 users/seth/programs/neovim/config/lua/getchoo/lsp/init.lua delete mode 100644 users/seth/programs/neovim/config/lua/getchoo/lsp/keymap.lua delete mode 100644 users/seth/programs/neovim/config/lua/getchoo/lsp/server.lua create mode 100644 users/seth/programs/neovim/lua/getchoo/ftdetect.lua create mode 100644 users/seth/programs/neovim/lua/getchoo/init.lua create mode 100644 users/seth/programs/neovim/lua/getchoo/keymap.lua create mode 100644 users/seth/programs/neovim/lua/getchoo/lsp/config/cmp.lua create mode 100644 users/seth/programs/neovim/lua/getchoo/lsp/config/init.lua create mode 100644 users/seth/programs/neovim/lua/getchoo/lsp/config/lsp_config.lua create mode 100644 users/seth/programs/neovim/lua/getchoo/lsp/config/null_ls.lua create mode 100644 users/seth/programs/neovim/lua/getchoo/lsp/config/sources.lua create mode 100644 users/seth/programs/neovim/lua/getchoo/lsp/init.lua create mode 100644 users/seth/programs/neovim/lua/getchoo/lsp/keymap.lua create mode 100644 users/seth/programs/neovim/lua/getchoo/lsp/server.lua (limited to 'users/seth/programs/neovim') diff --git a/users/seth/programs/neovim/config/lua/getchoo/ftdetect.lua b/users/seth/programs/neovim/config/lua/getchoo/ftdetect.lua deleted file mode 100644 index c13bdb6..0000000 --- a/users/seth/programs/neovim/config/lua/getchoo/ftdetect.lua +++ /dev/null @@ -1,12 +0,0 @@ --- --- load custom file types --- - -local filetypes = { - filename = { - PKGBUILD = "text", - [".makepkg.conf"] = "text", - }, -} - -vim.filetype.add(filetypes) diff --git a/users/seth/programs/neovim/config/lua/getchoo/init.lua b/users/seth/programs/neovim/config/lua/getchoo/init.lua deleted file mode 100644 index a719ac3..0000000 --- a/users/seth/programs/neovim/config/lua/getchoo/init.lua +++ /dev/null @@ -1,52 +0,0 @@ --- --- setup plugins --- - -local M = {} - -M.bufferline = { - animation = true, - auto_hide = true, - icons = true, - maximum_padding = 2, - semantic_letters = true, -} - -M.catppuccin = { - flavour = "mocha", -- mocha, macchiato, frappe, latte - integrations = { - barbar = true, - gitsigns = true, - lightspeed = true, - cmp = true, - nvimtree = true, - treesitter_context = true, - treesitter = true, - telescope = true, - lsp_trouble = true, - }, - no_italic = true, -} - -M.lualine = { - options = { - theme = "catppuccin", - }, - extensions = { "nvim-tree" }, -} - -M.tree = {} - -require("bufferline").setup(M.bufferline) -require("catppuccin").setup(M.catppuccin) -require("lualine").setup(M.lualine) -require("nvim-tree").setup(M.tree) - -if vim.g.use_lsp_plugins then - require("getchoo.ftdetect") - require("getchoo.lsp") -end - -require("getchoo.keymap") - -return M diff --git a/users/seth/programs/neovim/config/lua/getchoo/keymap.lua b/users/seth/programs/neovim/config/lua/getchoo/keymap.lua deleted file mode 100644 index 9a4484c..0000000 --- a/users/seth/programs/neovim/config/lua/getchoo/keymap.lua +++ /dev/null @@ -1,27 +0,0 @@ --- --- keymaps for general plugins --- - -local opts = { noremap = true, silent = true } -local set = function(mode, key, cmd) - vim.keymap.set(mode, key, cmd, opts) -end - -set("n", "t", function() - vim.cmd("NvimTreeToggle") -end) - -for i = 1, 9 do - set("n", "" .. i, function() - local cmd = "BufferGoto " .. i - vim.cmd(cmd) - end) -end - -set("n", "p", function() - vim.cmd("BufferPick") -end) - -set("n", "q", function() - vim.cmd("BufferClose") -end) diff --git a/users/seth/programs/neovim/config/lua/getchoo/lsp/config/cmp.lua b/users/seth/programs/neovim/config/lua/getchoo/lsp/config/cmp.lua deleted file mode 100644 index cef2ad1..0000000 --- a/users/seth/programs/neovim/config/lua/getchoo/lsp/config/cmp.lua +++ /dev/null @@ -1,71 +0,0 @@ --- --- config for nvim-cmp --- - -local cmp = require("cmp") -local mapping = cmp.mapping -local luasnip = require("luasnip") - -local M = {} - -local has_words_before = function() - local line, col = unpack(vim.api.nvim_win_get_cursor(0)) - return col ~= 0 and vim.api.nvim_buf_get_lines(0, line - 1, line, true)[1]:sub(col, col):match("%s") == nil -end - -local feedkey = function(key, mode) - vim.api.nvim_feedkeys(vim.api.nvim_replace_termcodes(key, true, true, true), mode, true) -end - -M.config = { - snippet = { - expand = function(args) - vim.fn["vsnip#anonymous"](args.body) - luasnip.lsp_expand(args.body) - end, - }, - mapping = mapping.preset.insert({ - [""] = cmp.mapping(function(fallback) - if cmp.visible() then - cmp.select_next_item() - elseif luasnip.expand_or_jumpable() then - luasnip.expand_or_jump() - elseif vim.fn["vsnip#available"](1) == 1 then - feedkey("(vsnip-expand-or-jump)", "") - elseif has_words_before() then - cmp.complete() - else - fallback() - end - end, { "i", "s" }), - [""] = cmp.mapping(function(fallback) - if cmp.visible() then - cmp.select_prev_item() - elseif luasnip.jumpable(-1) then - luasnip.jump(-1) - elseif vim.fn["vsnip#available"](-1) == 1 then - feedkey("(vsnip-jump-prev)", "") - else - fallback() - end - end, { "i", "s" }), - }), - sources = cmp.config.sources({ - { name = "nvim_lsp" }, - { name = "luasnip" }, - { name = "vsnip" }, - { name = "buffer" }, - { name = "path" }, - }), -} - -local capabilities = require("cmp_nvim_lsp").default_capabilities() -capabilities.textDocument.completion.completionItem.snippetSupport = true - -M.capabilities = capabilities - -M.on_attach = function(_, bufnr) - vim.api.nvim_buf_set_option(bufnr, "omnifunc", "v:lua.vim.lsp.omnifunc") -end - -return M diff --git a/users/seth/programs/neovim/config/lua/getchoo/lsp/config/init.lua b/users/seth/programs/neovim/config/lua/getchoo/lsp/config/init.lua deleted file mode 100644 index f2634d5..0000000 --- a/users/seth/programs/neovim/config/lua/getchoo/lsp/config/init.lua +++ /dev/null @@ -1,27 +0,0 @@ --- --- load all lsp configs --- - -local cmp = require("getchoo.lsp.config.cmp") -local lsp_config = require("getchoo.lsp.config.lsp_config") -local null_ls = require("getchoo.lsp.config.null_ls") - -local M = {} - -M.cmp = cmp.config - -M.lsp_servers = lsp_config.servers - -M.null_ls = null_ls.config - -M.treesitter = { - auto_install = false, - highlight = { - enable = true, - additional_vim_regex_highlighting = false, - }, -} - -M.trouble = {} - -return M diff --git a/users/seth/programs/neovim/config/lua/getchoo/lsp/config/lsp_config.lua b/users/seth/programs/neovim/config/lua/getchoo/lsp/config/lsp_config.lua deleted file mode 100644 index 9874820..0000000 --- a/users/seth/programs/neovim/config/lua/getchoo/lsp/config/lsp_config.lua +++ /dev/null @@ -1,44 +0,0 @@ --- --- setup lsp_config --- - -local cmp = require("getchoo.lsp.config.cmp") -local sources = require("getchoo.lsp.config.sources") - -local M = {} - -local on_attach = function(client, bufnr) - cmp.on_attach(client, bufnr) -end - -local all_config = { - capabilities = cmp.capabilities, - on_attach = on_attach, -} - -local servers = {} -for _, server in ipairs(sources.lsp_servers) do - servers[server] = all_config -end - -servers["sumneko_lua"] = { - capabilities = cmp.capabilities, - on_attach = on_attach, - settings = { - Lua = { - runtime = { - version = "LuaJIT", - }, - diagnostics = { - globals = { "vim" }, - }, - workspace = { - library = vim.api.nvim_get_runtime_file("", true), - }, - }, - }, -} - -M.servers = servers - -return M diff --git a/users/seth/programs/neovim/config/lua/getchoo/lsp/config/null_ls.lua b/users/seth/programs/neovim/config/lua/getchoo/lsp/config/null_ls.lua deleted file mode 100644 index 16b1b3c..0000000 --- a/users/seth/programs/neovim/config/lua/getchoo/lsp/config/null_ls.lua +++ /dev/null @@ -1,42 +0,0 @@ --- --- config for null_ls --- - -local sources = require("getchoo.lsp.config.sources") - -local M = {} - --- only use null-ls for formatting --- for neovim >= 8 -local lsp_formatting = function(bufnr) - vim.lsp.buf.format({ - filter = function(client) - return client.name == "null-ls" - end, - bufnr = bufnr, - }) -end - -local augroup = vim.api.nvim_create_augroup("LspFormatting", {}) -local formatting_on_attach = function(client, bufnr) - if client.supports_method("textDocument/formatting") then - vim.api.nvim_clear_autocmds({ group = augroup, buffer = bufnr }) - vim.api.nvim_create_autocmd("BufWritePre", { - group = augroup, - buffer = bufnr, - callback = function() - -- for neovim < 8 - ---- local params = require("vim.lsp.util").make_formatting_params({}) - ---- client.request("textDocument/formatting", params, nil, bufnr) - lsp_formatting(bufnr) -- neovim >= 8 - end, - }) - end -end - -M.config = { - on_attach = formatting_on_attach, - sources = sources.null_ls, -} - -return M diff --git a/users/seth/programs/neovim/config/lua/getchoo/lsp/config/sources.lua b/users/seth/programs/neovim/config/lua/getchoo/lsp/config/sources.lua deleted file mode 100644 index bed6361..0000000 --- a/users/seth/programs/neovim/config/lua/getchoo/lsp/config/sources.lua +++ /dev/null @@ -1,26 +0,0 @@ --- --- sources for lsp --- - -local null_ls = require("null-ls") -local diagnostics = null_ls.builtins.diagnostics -local formatting = null_ls.builtins.formatting - -local M = { - lsp_servers = { "rust_analyzer", "pyright", "bashls" }, - null_ls = { - diagnostics.alex, - diagnostics.codespell, - diagnostics.deadnix, - diagnostics.pylint, - diagnostics.statix, - formatting.alejandra, - formatting.codespell, - formatting.prettier, - formatting.rustfmt, - formatting.stylua, - formatting.yapf, - } -} - -return M diff --git a/users/seth/programs/neovim/config/lua/getchoo/lsp/init.lua b/users/seth/programs/neovim/config/lua/getchoo/lsp/init.lua deleted file mode 100644 index f354b2a..0000000 --- a/users/seth/programs/neovim/config/lua/getchoo/lsp/init.lua +++ /dev/null @@ -1,11 +0,0 @@ --- --- setup lsp environment --- - -require("getchoo.lsp.server") -require("getchoo.lsp.keymap") -local config = require("getchoo.lsp.config") - -require("gitsigns").setup() -require("nvim-treesitter.configs").setup(config.treesitter) -require("trouble").setup(config.trouble) diff --git a/users/seth/programs/neovim/config/lua/getchoo/lsp/keymap.lua b/users/seth/programs/neovim/config/lua/getchoo/lsp/keymap.lua deleted file mode 100644 index 9f34ffa..0000000 --- a/users/seth/programs/neovim/config/lua/getchoo/lsp/keymap.lua +++ /dev/null @@ -1,21 +0,0 @@ --- --- keymaps for lsp --- - -local opts = { noremap = true, silent = true } -local set = function(mode, key, cmd) - vim.keymap.set(mode, key, cmd, opts) -end - -set("n", "e", vim.diagnostic.open_float) -set("n", "[d", vim.diagnostic.goto_prev) -set("n", "]d", vim.diagnostic.goto_next) -set("n", "q", vim.diagnostic.setloclist) - -set("n", "f", function() - vim.cmd("Telescope") -end) - -set("n", "t", function() - vim.cmd("TroubleToggle") -end) diff --git a/users/seth/programs/neovim/config/lua/getchoo/lsp/server.lua b/users/seth/programs/neovim/config/lua/getchoo/lsp/server.lua deleted file mode 100644 index f238eb5..0000000 --- a/users/seth/programs/neovim/config/lua/getchoo/lsp/server.lua +++ /dev/null @@ -1,15 +0,0 @@ --- --- initialize lsp servers --- - -local cmp = require("cmp") -local lspconfig = require("lspconfig") -local null_ls = require("null-ls") -local config = require("getchoo.lsp.config") - -null_ls.setup(config.null_ls) -cmp.setup(config.cmp) - -for server, settings in pairs(config.lsp_servers) do - lspconfig[server].setup(settings) -end diff --git a/users/seth/programs/neovim/default.nix b/users/seth/programs/neovim/default.nix index 58d8071..0f814be 100644 --- a/users/seth/programs/neovim/default.nix +++ b/users/seth/programs/neovim/default.nix @@ -1,99 +1,71 @@ -{ - config, - pkgs, - ... -}: let - neovimConfig = - if config.seth.devel.enable - then "vim.g.use_lsp_plugins = true" - else "vim.g.use_lsp_plugins = false"; - - lspPackages = - if config.seth.devel.enable - then - with pkgs; [ - alejandra - clang - codespell - deadnix - nodePackages.alex - nodePackages.bash-language-server - nodePackages.prettier - nodePackages.pyright - pylint - rust-analyzer - rustfmt - statix - stylua - sumneko-lua-language-server - yapf - ] - else []; - - lspPlugins = - if config.seth.devel.enable - then - with pkgs.vimPlugins; [ - nvim-lspconfig - null-ls-nvim - plenary-nvim - nvim-treesitter.withAllGrammars - nvim-cmp - cmp-nvim-lsp - cmp-buffer - cmp-path - cmp-vsnip - vim-vsnip - luasnip - cmp_luasnip - trouble-nvim - telescope-nvim - gitsigns-nvim - editorconfig-nvim - ] - else []; -in { +{pkgs, ...}: { programs.neovim = { enable = true; - extraPackages = lspPackages; - plugins = with pkgs.vimPlugins; - [ - barbar-nvim - catppuccin-nvim - lightspeed-nvim - lualine-nvim - nvim-tree-lua - nvim-web-devicons - ] - ++ lspPlugins; + extraPackages = with pkgs; [ + alejandra + clang + codespell + deadnix + nodePackages.alex + nodePackages.bash-language-server + nodePackages.prettier + nodePackages.pyright + pylint + rust-analyzer + rustfmt + statix + stylua + sumneko-lua-language-server + yapf + ]; + plugins = with pkgs.vimPlugins; [ + barbar-nvim + catppuccin-nvim + cmp-nvim-lsp + cmp-buffer + cmp_luasnip + cmp-path + cmp-vsnip + editorconfig-nvim + gitsigns-nvim + lightspeed-nvim + lualine-nvim + luasnip + nvim-cmp + nvim-lspconfig + null-ls-nvim + nvim-tree-lua + nvim-treesitter.withAllGrammars + nvim-web-devicons + plenary-nvim + telescope-nvim + trouble-nvim + vim-vsnip + ]; }; xdg.configFile.nvim = { - source = ./config; + source = ./lua; recursive = true; }; xdg.configFile."nvim/init.lua" = { - text = - neovimConfig - + '' - - local cmd = vim.cmd - local opt = vim.opt - - require("getchoo") - - -- text options - opt.tabstop = 2 - opt.shiftwidth = 2 - opt.expandtab = false - opt.smartindent = true - opt.wrap = false + text = '' + local cmd = vim.cmd + local opt = vim.opt + require("getchoo") + vim.g.use_lsp_plugins = true + -- text options + opt.tabstop = 2 + opt.shiftwidth = 2 + opt.expandtab = false + opt.smartindent = true + opt.wrap = false - -- appearance - opt.syntax = "on" - cmd("filetype plugin indent on") - opt.termguicolors = true - vim.api.nvim_command("colorscheme catppuccin") - ''; + -- appearance + opt.syntax = "on" + cmd("filetype plugin indent on") + opt.termguicolors = true + vim.api.nvim_command("colorscheme catppuccin") + ''; }; } diff --git a/users/seth/programs/neovim/lua/getchoo/ftdetect.lua b/users/seth/programs/neovim/lua/getchoo/ftdetect.lua new file mode 100644 index 0000000..c13bdb6 --- /dev/null +++ b/users/seth/programs/neovim/lua/getchoo/ftdetect.lua @@ -0,0 +1,12 @@ +-- +-- load custom file types +-- + +local filetypes = { + filename = { + PKGBUILD = "text", + [".makepkg.conf"] = "text", + }, +} + +vim.filetype.add(filetypes) diff --git a/users/seth/programs/neovim/lua/getchoo/init.lua b/users/seth/programs/neovim/lua/getchoo/init.lua new file mode 100644 index 0000000..d73b5ae --- /dev/null +++ b/users/seth/programs/neovim/lua/getchoo/init.lua @@ -0,0 +1,49 @@ +-- +-- setup plugins +-- + +local M = {} + +M.bufferline = { + animation = true, + auto_hide = true, + icons = true, + maximum_padding = 2, + semantic_letters = true, +} + +M.catppuccin = { + flavour = "mocha", -- mocha, macchiato, frappe, latte + integrations = { + barbar = true, + gitsigns = true, + lightspeed = true, + cmp = true, + nvimtree = true, + treesitter_context = true, + treesitter = true, + telescope = true, + lsp_trouble = true, + }, + no_italic = true, +} + +M.lualine = { + options = { + theme = "catppuccin", + }, + extensions = { "nvim-tree" }, +} + +M.tree = {} + +require("bufferline").setup(M.bufferline) +require("catppuccin").setup(M.catppuccin) +require("lualine").setup(M.lualine) +require("nvim-tree").setup(M.tree) + +require("getchoo.ftdetect") +require("getchoo.lsp") +require("getchoo.keymap") + +return M diff --git a/users/seth/programs/neovim/lua/getchoo/keymap.lua b/users/seth/programs/neovim/lua/getchoo/keymap.lua new file mode 100644 index 0000000..9a4484c --- /dev/null +++ b/users/seth/programs/neovim/lua/getchoo/keymap.lua @@ -0,0 +1,27 @@ +-- +-- keymaps for general plugins +-- + +local opts = { noremap = true, silent = true } +local set = function(mode, key, cmd) + vim.keymap.set(mode, key, cmd, opts) +end + +set("n", "t", function() + vim.cmd("NvimTreeToggle") +end) + +for i = 1, 9 do + set("n", "" .. i, function() + local cmd = "BufferGoto " .. i + vim.cmd(cmd) + end) +end + +set("n", "p", function() + vim.cmd("BufferPick") +end) + +set("n", "q", function() + vim.cmd("BufferClose") +end) diff --git a/users/seth/programs/neovim/lua/getchoo/lsp/config/cmp.lua b/users/seth/programs/neovim/lua/getchoo/lsp/config/cmp.lua new file mode 100644 index 0000000..cef2ad1 --- /dev/null +++ b/users/seth/programs/neovim/lua/getchoo/lsp/config/cmp.lua @@ -0,0 +1,71 @@ +-- +-- config for nvim-cmp +-- + +local cmp = require("cmp") +local mapping = cmp.mapping +local luasnip = require("luasnip") + +local M = {} + +local has_words_before = function() + local line, col = unpack(vim.api.nvim_win_get_cursor(0)) + return col ~= 0 and vim.api.nvim_buf_get_lines(0, line - 1, line, true)[1]:sub(col, col):match("%s") == nil +end + +local feedkey = function(key, mode) + vim.api.nvim_feedkeys(vim.api.nvim_replace_termcodes(key, true, true, true), mode, true) +end + +M.config = { + snippet = { + expand = function(args) + vim.fn["vsnip#anonymous"](args.body) + luasnip.lsp_expand(args.body) + end, + }, + mapping = mapping.preset.insert({ + [""] = cmp.mapping(function(fallback) + if cmp.visible() then + cmp.select_next_item() + elseif luasnip.expand_or_jumpable() then + luasnip.expand_or_jump() + elseif vim.fn["vsnip#available"](1) == 1 then + feedkey("(vsnip-expand-or-jump)", "") + elseif has_words_before() then + cmp.complete() + else + fallback() + end + end, { "i", "s" }), + [""] = cmp.mapping(function(fallback) + if cmp.visible() then + cmp.select_prev_item() + elseif luasnip.jumpable(-1) then + luasnip.jump(-1) + elseif vim.fn["vsnip#available"](-1) == 1 then + feedkey("(vsnip-jump-prev)", "") + else + fallback() + end + end, { "i", "s" }), + }), + sources = cmp.config.sources({ + { name = "nvim_lsp" }, + { name = "luasnip" }, + { name = "vsnip" }, + { name = "buffer" }, + { name = "path" }, + }), +} + +local capabilities = require("cmp_nvim_lsp").default_capabilities() +capabilities.textDocument.completion.completionItem.snippetSupport = true + +M.capabilities = capabilities + +M.on_attach = function(_, bufnr) + vim.api.nvim_buf_set_option(bufnr, "omnifunc", "v:lua.vim.lsp.omnifunc") +end + +return M diff --git a/users/seth/programs/neovim/lua/getchoo/lsp/config/init.lua b/users/seth/programs/neovim/lua/getchoo/lsp/config/init.lua new file mode 100644 index 0000000..f2634d5 --- /dev/null +++ b/users/seth/programs/neovim/lua/getchoo/lsp/config/init.lua @@ -0,0 +1,27 @@ +-- +-- load all lsp configs +-- + +local cmp = require("getchoo.lsp.config.cmp") +local lsp_config = require("getchoo.lsp.config.lsp_config") +local null_ls = require("getchoo.lsp.config.null_ls") + +local M = {} + +M.cmp = cmp.config + +M.lsp_servers = lsp_config.servers + +M.null_ls = null_ls.config + +M.treesitter = { + auto_install = false, + highlight = { + enable = true, + additional_vim_regex_highlighting = false, + }, +} + +M.trouble = {} + +return M diff --git a/users/seth/programs/neovim/lua/getchoo/lsp/config/lsp_config.lua b/users/seth/programs/neovim/lua/getchoo/lsp/config/lsp_config.lua new file mode 100644 index 0000000..9874820 --- /dev/null +++ b/users/seth/programs/neovim/lua/getchoo/lsp/config/lsp_config.lua @@ -0,0 +1,44 @@ +-- +-- setup lsp_config +-- + +local cmp = require("getchoo.lsp.config.cmp") +local sources = require("getchoo.lsp.config.sources") + +local M = {} + +local on_attach = function(client, bufnr) + cmp.on_attach(client, bufnr) +end + +local all_config = { + capabilities = cmp.capabilities, + on_attach = on_attach, +} + +local servers = {} +for _, server in ipairs(sources.lsp_servers) do + servers[server] = all_config +end + +servers["sumneko_lua"] = { + capabilities = cmp.capabilities, + on_attach = on_attach, + settings = { + Lua = { + runtime = { + version = "LuaJIT", + }, + diagnostics = { + globals = { "vim" }, + }, + workspace = { + library = vim.api.nvim_get_runtime_file("", true), + }, + }, + }, +} + +M.servers = servers + +return M diff --git a/users/seth/programs/neovim/lua/getchoo/lsp/config/null_ls.lua b/users/seth/programs/neovim/lua/getchoo/lsp/config/null_ls.lua new file mode 100644 index 0000000..16b1b3c --- /dev/null +++ b/users/seth/programs/neovim/lua/getchoo/lsp/config/null_ls.lua @@ -0,0 +1,42 @@ +-- +-- config for null_ls +-- + +local sources = require("getchoo.lsp.config.sources") + +local M = {} + +-- only use null-ls for formatting +-- for neovim >= 8 +local lsp_formatting = function(bufnr) + vim.lsp.buf.format({ + filter = function(client) + return client.name == "null-ls" + end, + bufnr = bufnr, + }) +end + +local augroup = vim.api.nvim_create_augroup("LspFormatting", {}) +local formatting_on_attach = function(client, bufnr) + if client.supports_method("textDocument/formatting") then + vim.api.nvim_clear_autocmds({ group = augroup, buffer = bufnr }) + vim.api.nvim_create_autocmd("BufWritePre", { + group = augroup, + buffer = bufnr, + callback = function() + -- for neovim < 8 + ---- local params = require("vim.lsp.util").make_formatting_params({}) + ---- client.request("textDocument/formatting", params, nil, bufnr) + lsp_formatting(bufnr) -- neovim >= 8 + end, + }) + end +end + +M.config = { + on_attach = formatting_on_attach, + sources = sources.null_ls, +} + +return M diff --git a/users/seth/programs/neovim/lua/getchoo/lsp/config/sources.lua b/users/seth/programs/neovim/lua/getchoo/lsp/config/sources.lua new file mode 100644 index 0000000..bed6361 --- /dev/null +++ b/users/seth/programs/neovim/lua/getchoo/lsp/config/sources.lua @@ -0,0 +1,26 @@ +-- +-- sources for lsp +-- + +local null_ls = require("null-ls") +local diagnostics = null_ls.builtins.diagnostics +local formatting = null_ls.builtins.formatting + +local M = { + lsp_servers = { "rust_analyzer", "pyright", "bashls" }, + null_ls = { + diagnostics.alex, + diagnostics.codespell, + diagnostics.deadnix, + diagnostics.pylint, + diagnostics.statix, + formatting.alejandra, + formatting.codespell, + formatting.prettier, + formatting.rustfmt, + formatting.stylua, + formatting.yapf, + } +} + +return M diff --git a/users/seth/programs/neovim/lua/getchoo/lsp/init.lua b/users/seth/programs/neovim/lua/getchoo/lsp/init.lua new file mode 100644 index 0000000..f354b2a --- /dev/null +++ b/users/seth/programs/neovim/lua/getchoo/lsp/init.lua @@ -0,0 +1,11 @@ +-- +-- setup lsp environment +-- + +require("getchoo.lsp.server") +require("getchoo.lsp.keymap") +local config = require("getchoo.lsp.config") + +require("gitsigns").setup() +require("nvim-treesitter.configs").setup(config.treesitter) +require("trouble").setup(config.trouble) diff --git a/users/seth/programs/neovim/lua/getchoo/lsp/keymap.lua b/users/seth/programs/neovim/lua/getchoo/lsp/keymap.lua new file mode 100644 index 0000000..9f34ffa --- /dev/null +++ b/users/seth/programs/neovim/lua/getchoo/lsp/keymap.lua @@ -0,0 +1,21 @@ +-- +-- keymaps for lsp +-- + +local opts = { noremap = true, silent = true } +local set = function(mode, key, cmd) + vim.keymap.set(mode, key, cmd, opts) +end + +set("n", "e", vim.diagnostic.open_float) +set("n", "[d", vim.diagnostic.goto_prev) +set("n", "]d", vim.diagnostic.goto_next) +set("n", "q", vim.diagnostic.setloclist) + +set("n", "f", function() + vim.cmd("Telescope") +end) + +set("n", "t", function() + vim.cmd("TroubleToggle") +end) diff --git a/users/seth/programs/neovim/lua/getchoo/lsp/server.lua b/users/seth/programs/neovim/lua/getchoo/lsp/server.lua new file mode 100644 index 0000000..f238eb5 --- /dev/null +++ b/users/seth/programs/neovim/lua/getchoo/lsp/server.lua @@ -0,0 +1,15 @@ +-- +-- initialize lsp servers +-- + +local cmp = require("cmp") +local lspconfig = require("lspconfig") +local null_ls = require("null-ls") +local config = require("getchoo.lsp.config") + +null_ls.setup(config.null_ls) +cmp.setup(config.cmp) + +for server, settings in pairs(config.lsp_servers) do + lspconfig[server].setup(settings) +end -- cgit v1.2.3