mirror of
https://github.com/NotAShelf/nvf.git
synced 2026-01-19 16:48:43 +00:00
Compare commits
5 commits
8c8d250768
...
1381962326
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
1381962326 | ||
|
|
52136af007 | ||
|
|
77ab1152cb | ||
|
|
72d129f69a | ||
|
|
0bf6912626 |
5 changed files with 83 additions and 70 deletions
|
|
@ -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"];
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
||||||
|
|
@ -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 {
|
||||||
|
|
|
||||||
|
|
@ -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 {
|
||||||
|
|
|
||||||
|
|
@ -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 {
|
||||||
|
|
|
||||||
|
|
@ -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"];
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue