Compare commits

..

5 commits

Author SHA1 Message Date
sjcobb
1381962326 convert clojure module 2025-06-03 00:03:28 +01:00
sjcobb
52136af007 convert bash module 2025-06-02 23:56:40 +01:00
sjcobb
77ab1152cb cleanup nix moduke 2025-06-02 23:49:27 +01:00
sjcobb
72d129f69a astro module overhaul 2025-06-02 23:48:36 +01:00
sjcobb
0bf6912626 asm module overhaul 2025-06-02 23:48:27 +01:00
5 changed files with 83 additions and 70 deletions

View file

@ -37,7 +37,6 @@ in {
description = "Assembly LSP server to use"; description = "Assembly LSP server to use";
type = listOf (enum (attrNames servers)); type = listOf (enum (attrNames servers));
default = defaultServers; default = defaultServers;
example = ["asm-lsp"];
}; };
}; };
}; };

View file

@ -12,25 +12,46 @@
inherit (lib.types) enum either listOf package str; inherit (lib.types) enum either listOf package str;
inherit (lib.generators) mkLuaInline; inherit (lib.generators) mkLuaInline;
inherit (lib.nvim.lua) expToLua; inherit (lib.nvim.lua) expToLua;
inherit (lib.nvim.attrsets) mapListToAttrs;
inherit (lib.nvim.types) mkGrammarOption diagnostics; inherit (lib.nvim.types) mkGrammarOption diagnostics;
cfg = config.vim.languages.astro; cfg = config.vim.languages.astro;
defaultServer = "astro"; defaultServers = ["astro"];
servers = { servers = {
astro = { astro = {
package = pkgs.astro-language-server; enable = true;
lspConfig = '' cmd = [(getExe pkgs.astro-language-server) "--stdio"];
lspconfig.astro.setup { filetypes = ["astro"];
capabilities = capabilities, root_markers = ["package.json" "tsconfig.json" "jsconfig.json" ".git"];
on_attach = attach_keymaps, init_options = {
cmd = ${ typescript = {};
if isList cfg.lsp.package };
then expToLua cfg.lsp.package before_init =
else ''{"${cfg.lsp.package}/bin/astro-ls", "--stdio"}'' mkLuaInline
} /*
} lua
''; */
''
function(_, config)
-- TODO: Make this a shared util function
local get_typescript_server_path = function(root_dir)
local project_roots = vim.fs.find('node_modules', { path = root_dir, upward = true, limit = math.huge })
for _, project_root in ipairs(project_roots) do
local typescript_path = project_root .. '/typescript'
local stat = vim.loop.fs_stat(typescript_path)
if stat and stat.type == 'directory' then
return typescript_path .. '/lib'
end
end
return '''
end
if config.init_options and config.init_options.typescript and not config.init_options.typescript.tsdk then
config.init_options.typescript.tsdk = get_typescript_server_path(config.root_dir)
end
end
'';
}; };
}; };
@ -82,18 +103,10 @@ in {
lsp = { lsp = {
enable = mkEnableOption "Astro LSP support" // {default = config.vim.lsp.enable;}; enable = mkEnableOption "Astro LSP support" // {default = config.vim.lsp.enable;};
servers = mkOption {
server = mkOption {
type = enum (attrNames servers);
default = defaultServer;
description = "Astro LSP server to use"; description = "Astro LSP server to use";
}; type = listOf (enum (attrNames servers));
default = defaultServers;
package = mkOption {
type = either package (listOf str);
default = servers.${cfg.lsp.server}.package;
example = ''[lib.getExe pkgs.astro-language-server "--minify" "--stdio"]'';
description = "Astro LSP server package, or the command to run as a list of strings";
}; };
}; };
@ -131,8 +144,12 @@ in {
}) })
(mkIf cfg.lsp.enable { (mkIf cfg.lsp.enable {
vim.lsp.lspconfig.enable = true; vim.lsp.servers =
vim.lsp.lspconfig.sources.astro-lsp = servers.${cfg.lsp.server}.lspConfig; mapListToAttrs (n: {
name = n;
value = servers.${n};
})
cfg.lsp.servers;
}) })
(mkIf cfg.format.enable { (mkIf cfg.format.enable {

View file

@ -10,26 +10,24 @@
inherit (lib.modules) mkIf mkMerge; inherit (lib.modules) mkIf mkMerge;
inherit (lib.lists) isList; inherit (lib.lists) isList;
inherit (lib.types) enum either package listOf str bool; inherit (lib.types) enum either package listOf str bool;
inherit (lib.generators) mkLuaInline;
inherit (lib.nvim.types) diagnostics mkGrammarOption; inherit (lib.nvim.types) diagnostics mkGrammarOption;
inherit (lib.nvim.lua) expToLua; inherit (lib.nvim.lua) expToLua;
cfg = config.vim.languages.bash; cfg = config.vim.languages.bash;
defaultServer = "bash-ls"; defaultServers = ["bash-ls"];
servers = { servers = {
bash-ls = { bash-ls = {
package = pkgs.bash-language-server; enable = true;
lspConfig = '' cmd = [(getExe pkgs.bash-language-server) "start"];
lspconfig.bashls.setup{ filetypes = ["bash" "sh"];
capabilities = capabilities; root_markers = [".git"];
on_attach = default_on_attach; settings = {
cmd = ${ basheIde = {
if isList cfg.lsp.package globPattern = mkLuaInline "vim.env.GLOB_PATTERN or '*@(.sh|.inc|.bash|.command)'";
then expToLua cfg.lsp.package
else ''{"${cfg.lsp.package}/bin/bash-language-server", "start"}''
}; };
} };
'';
}; };
}; };
@ -56,19 +54,11 @@ in {
}; };
lsp = { lsp = {
enable = mkEnableOption "Enable Bash LSP support" // {default = config.vim.lsp.enable;}; enable = mkEnableOption "Bash LSP support" // {default = config.vim.lsp.enable;};
servers = mkOption {
server = mkOption {
description = "Bash LSP server to use"; description = "Bash LSP server to use";
type = enum (attrNames servers); type = listOf (enum (attrNames servers));
default = defaultServer; default = defaultServers;
};
package = mkOption {
description = "bash-language-server package, or the command to run as a list of strings";
example = literalExpression ''[lib.getExe pkgs.nodePackages.bash-language-server "start"]'';
type = either package (listOf str);
default = pkgs.bash-language-server;
}; };
}; };
@ -108,8 +98,12 @@ in {
}) })
(mkIf cfg.lsp.enable { (mkIf cfg.lsp.enable {
vim.lsp.lspconfig.enable = true; vim.lsp.servers =
vim.lsp.lspconfig.sources.bash-lsp = servers.${cfg.lsp.server}.lspConfig; mapListToAttrs (n: {
name = n;
value = servers.${n};
})
cfg.lsp.servers;
}) })
(mkIf cfg.format.enable { (mkIf cfg.format.enable {

View file

@ -13,6 +13,16 @@
inherit (lib.nvim.lua) expToLua; inherit (lib.nvim.lua) expToLua;
cfg = config.vim.languages.clojure; cfg = config.vim.languages.clojure;
defaultServers = ["clojure-lsp"];
servers = {
clojure-lsp = {
enable = true;
cmd = [(getExe pkgs.clojure-lsp)];
filetypes = ["clojure" "edn"];
root_markers = ["project.clj" "deps.edn" "build.boot" "shadow-cljs.edn" ".git" "bb.edn"];
};
};
in { in {
options.vim.languages.clojure = { options.vim.languages.clojure = {
enable = mkEnableOption "Clojure language support"; enable = mkEnableOption "Clojure language support";
@ -24,28 +34,22 @@ in {
lsp = { lsp = {
enable = mkEnableOption "Clojure LSP support" // {default = config.vim.lsp.enable;}; enable = mkEnableOption "Clojure LSP support" // {default = config.vim.lsp.enable;};
package = mkOption { servers = mkOption {
type = either package (listOf str); description = "Clojure LSP server to use";
default = pkgs.clojure-lsp; type = listOf (enum (attrNames servers));
description = "Clojure LSP"; default = defaultServers;
}; };
}; };
}; };
config = mkIf cfg.enable (mkMerge [ config = mkIf cfg.enable (mkMerge [
(mkIf cfg.lsp.enable { (mkIf cfg.lsp.enable {
vim.lsp.lspconfig.enable = true; vim.lsp.servers =
vim.lsp.lspconfig.sources.clojure-lsp = '' mapListToAttrs (n: {
lspconfig.clojure_lsp.setup { name = n;
capabilities = capabilities; value = servers.${n};
on_attach = default_on_attach; })
cmd = ${ cfg.lsp.servers;
if isList cfg.lsp.package
then expToLua cfg.lsp.package
else ''{"${getExe cfg.lsp.package}"}''
};
}
'';
}) })
(mkIf cfg.treesitter.enable { (mkIf cfg.treesitter.enable {

View file

@ -101,7 +101,6 @@ in {
description = "Nix LSP server to use"; description = "Nix LSP server to use";
type = listOf (enum (attrNames servers)); type = listOf (enum (attrNames servers));
default = defaultServers; default = defaultServers;
example = ["nixd"];
}; };
}; };