Compare commits

..

No commits in common. "96f3524a4ddd8229da0c61cfef8f701259fcbe51" and "1a1569e6dd52889533b8f4f77c7107fe8cadf551" have entirely different histories.

4 changed files with 122 additions and 45 deletions

View file

@ -1,9 +1,13 @@
{lib}: let {lib}: let
inherit (builtins) isString getAttr; inherit (builtins) isString getAttr;
inherit (lib.options) mkOption; inherit (lib.options) mkOption;
inherit (lib.types) listOf bool str submodule attrsOf anything either nullOr; inherit (lib.strings) concatStringsSep;
inherit (lib.types) listOf bool str submodule attrsOf anything either nullOr oneOf enum;
inherit (lib.attrsets) attrNames;
inherit (lib.nvim.attrsets) mapListToAttrs; inherit (lib.nvim.attrsets) mapListToAttrs;
inherit (lib.nvim.types) luaInline; inherit (lib.nvim.types) luaInline;
inherit (lib.lists) isList;
inherit (lib) genAttrs recursiveUpdate;
in { in {
# TODO: remove # TODO: remove
diagnosticsToLua = { diagnosticsToLua = {
@ -34,6 +38,18 @@ in {
description = "Turn on ${desc} for enabled languages by default"; description = "Turn on ${desc} for enabled languages by default";
}; };
# resolveLspOptions
# servers: AttrsOf lspOptions
# selected: AttrsOf lspOptions | List of string keys from servers
# Returns: AttrsOf lspOptions
resolveLspOptions = {
servers,
selected,
}:
if isList selected
then genAttrs selected (name: servers.${name})
else selected;
lspOptions = submodule { lspOptions = submodule {
freeformType = attrsOf anything; freeformType = attrsOf anything;
options = { options = {
@ -77,4 +93,27 @@ in {
}; };
}; };
}; };
mkLspOption = {servers, ...} @ args: let
serverNames = attrNames servers;
defaultAttrs = {
type = oneOf [
(attrsOf lib.nvim.languages.lspOptions)
(listOf (enum serverNames))
];
description = ''
Either a full set of selected LSP options as an attribute set,
or a list of server names from: ${concatStringsSep ", " serverNames}.
'';
default = {};
example = {
clangd = {
filetypes = ["c"];
root_markers = ["CMakeLists.txt"];
};
};
};
cleanedArgs = removeAttrs args ["servers"];
in
mkOption (recursiveUpdate defaultAttrs cleanedArgs);
} }

View file

@ -11,19 +11,43 @@
inherit (lib.attrsets) mapAttrsToList attrNames filterAttrs; inherit (lib.attrsets) mapAttrsToList attrNames filterAttrs;
inherit (lib.generators) mkLuaInline; inherit (lib.generators) mkLuaInline;
inherit (lib.nvim.languages) lspOptions; inherit (lib.nvim.languages) lspOptions;
inherit (lib.nvim.dag) entryAfter; inherit (lib.nvim.dag) entryAnywhere;
inherit (lib.nvim.lua) toLuaObject; inherit (lib.nvim.lua) toLuaObject;
cfg = config.vim.lsp; cfg = config.vim.lsp;
lspConfigurations = lspConfigurations =
mapAttrsToList ( mapAttrsToList (
name: value: '' # TODO: Determine the best thing to do about merging in lspconfig
vim.lsp.config["${name}"] = ${toLuaObject value} name: value:
'' /*
lua
*/
''vim.lsp.config["${name}"] = ${toLuaObject value}''
) )
cfg.servers; cfg.servers;
# Approach 1:
# Create function perhaps called mkLspConfig
# mkLspConfig servers;
# that expands to something like
# vim.lsp.servers = cfg.lsp.servers......
# vim.luaConfigRC.lspconfigMerge = entryAfter ["lsp-servers"] ''vim.lsp.config["${name}"] = vim.tbl_deep_extend("force", lspconfig.${name}, vim.lsp.config["${name}"])''
# Approach 2:
# lspConfigurations =
# mapAttrsToList (
# name: value: ''vim.lsp.config["${name}"] = vim.tbl_deep_extend("force", lspconfig.${name}, ${toLuaObject value})''
# )
# (filterAttrs (n: _: n != "*") cfg.servers);
# Then also need to configure global * settings
# globalConfiguration =
# mapAttrsToList (
# name: value: ''vim.lsp.config["${name}"] = ${toLuaObject value}''
# )
# (filterAttrs (n: _: n == "*") cfg.servers);
enabledServers = filterAttrs (_: u: u.enable) cfg.servers; enabledServers = filterAttrs (_: u: u.enable) cfg.servers;
in { in {
options = { options = {
@ -81,15 +105,18 @@ in {
} }
(mkIf (cfg.servers != {}) { (mkIf (cfg.servers != {}) {
# Enable lspconfig in order to merge in the predefined opts vim.luaConfigRC.lsp-servers =
vim.lsp.lspconfig.enable = true; entryAnywhere
vim.luaConfigRC.lsp-servers = entryAfter ["lspconfig"] '' # Or entryAfter ["lspconfig"] if we go with the second approach
-- Individual LSP configurations managed by nvf. /*
${concatLines lspConfigurations} lua
*/
''
${concatLines lspConfigurations}
-- Enable configured LSPs explicitly -- Enable configured LSPs explicitly
vim.lsp.enable(${toLuaObject (filter (name: name != "*") (attrNames enabledServers))}) vim.lsp.enable(${toLuaObject (filter (name: name != "*") (attrNames enabledServers))});
''; '';
}) })
]; ];
} }

View file

@ -9,18 +9,27 @@
inherit (lib.modules) mkIf mkMerge; inherit (lib.modules) mkIf mkMerge;
inherit (lib.options) mkEnableOption mkOption; inherit (lib.options) mkEnableOption mkOption;
inherit (lib.lists) isList; inherit (lib.lists) isList;
inherit (lib.types) bool enum package listOf str nullOr; inherit (lib.types) bool enum either package listOf str nullOr;
inherit (lib.nvim.lua) toLuaObject; inherit (lib.nvim.lua) expToLua toLuaObject;
inherit (lib.nvim.types) diagnostics mkGrammarOption mkPluginSetupOption; inherit (lib.nvim.types) diagnostics mkGrammarOption mkPluginSetupOption;
inherit (lib.nvim.dag) entryAnywhere; inherit (lib.nvim.dag) entryAnywhere;
inherit (lib.nvim.attrsets) mapListToAttrs;
cfg = config.vim.languages.markdown; cfg = config.vim.languages.markdown;
defaultServers = ["marksman"]; defaultServer = "marksman";
servers = { servers = {
marksman = { marksman = {
enable = true; package = pkgs.marksman;
cmd = ["${pkgs.marksman}/bin/marksman" "server"]; lspConfig = ''
lspconfig.marksman.setup{
capabilities = capabilities;
on_attach = default_on_attach;
cmd = ${
if isList cfg.lsp.package
then expToLua cfg.lsp.package
else ''{"${cfg.lsp.package}/bin/marksman", "server"}''
},
}
'';
}; };
}; };
@ -60,10 +69,17 @@ in {
lsp = { lsp = {
enable = mkEnableOption "Enable Markdown LSP support" // {default = config.vim.lsp.enable;}; enable = mkEnableOption "Enable Markdown LSP support" // {default = config.vim.lsp.enable;};
servers = mkOption { server = mkOption {
type = enum (attrNames servers);
default = defaultServer;
description = "Markdown LSP server to use"; description = "Markdown 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.jdt-language-server " - data " " ~/.cache/jdtls/workspace "]'';
description = "Markdown LSP server package, or the command to run as a list of strings";
}; };
}; };
@ -145,12 +161,8 @@ in {
}) })
(mkIf cfg.lsp.enable { (mkIf cfg.lsp.enable {
vim.lsp.servers = vim.lsp.lspconfig.enable = true;
mapListToAttrs (n: { vim.lsp.lspconfig.sources.markdown-lsp = servers.${cfg.lsp.server}.lspConfig;
name = n;
value = servers.${n};
})
cfg.lsp.servers;
}) })
(mkIf cfg.format.enable { (mkIf cfg.format.enable {

View file

@ -6,14 +6,15 @@
}: let }: let
inherit (builtins) attrNames; inherit (builtins) attrNames;
inherit (lib) concatStringsSep; inherit (lib) concatStringsSep;
inherit (lib.generators) mkLuaInline;
inherit (lib.meta) getExe; inherit (lib.meta) getExe;
inherit (lib.options) mkEnableOption mkOption; inherit (lib.options) mkEnableOption mkOption;
inherit (lib.modules) mkIf mkMerge; inherit (lib.modules) mkIf mkMerge;
inherit (lib.lists) isList; inherit (lib.lists) isList;
inherit (lib.types) enum package listOf; inherit (lib.types) enum package;
inherit (lib.nvim.types) mkGrammarOption diagnostics; inherit (lib.nvim.types) mkGrammarOption diagnostics;
inherit (lib.nvim.attrsets) mapListToAttrs;
inherit (lib.nvim.lua) expToLua; inherit (lib.nvim.lua) expToLua;
inherit (lib.nvim.languages) resolveLspOptions mkLspOption;
cfg = config.vim.languages.nix; cfg = config.vim.languages.nix;
@ -22,18 +23,18 @@
then expToLua package then expToLua package
else ''{"${package}/bin/${defaultCmd}"}''; else ''{"${package}/bin/${defaultCmd}"}'';
formattingCmd = mkIf (cfg.format.enable && cfg.lsp.enable) { formattingCmd = lib.mkIf (cfg.format.enable && cfg.lsp.enable) {
formatting = mkMerge [ formatting = lib.mkMerge [
(mkIf (cfg.format.type == "alejandra") { (lib.mkIf (cfg.format.type == "alejandra") {
command = ["${cfg.format.package}/bin/alejandra" "--quiet"]; command = ["${cfg.format.package}/bin/alejandra" "--quiet"];
}) })
(mkIf (cfg.format.type == "nixfmt") { (lib.mkIf (cfg.format.type == "nixfmt") {
command = ["${cfg.format.package}/bin/nixfmt"]; command = ["${cfg.format.package}/bin/nixfmt"];
}) })
]; ];
}; };
defaultServers = ["nil_ls"]; defaultServers = ["nil_ls"]
servers = { servers = {
nil_ls = { nil_ls = {
enable = true; enable = true;
@ -100,11 +101,9 @@ in {
lsp = { lsp = {
enable = mkEnableOption "Nix LSP support" // {default = config.vim.lsp.enable;}; enable = mkEnableOption "Nix LSP support" // {default = config.vim.lsp.enable;};
servers = mkOption { servers = mkLspOption {
description = "Nix LSP server to use"; inherit servers;
type = listOf (enum (attrNames servers));
default = defaultServers; default = defaultServers;
example = ["nixd"];
}; };
}; };
@ -154,14 +153,14 @@ in {
}) })
(mkIf cfg.lsp.enable { (mkIf cfg.lsp.enable {
vim.lsp.servers = # TODO: Map this to include lspconfig stuff so that we can do
mapListToAttrs (n: { vim.lsp.servers = resolveLspOptions {
name = n; inherit servers;
value = servers.${n}; selected = cfg.lsp.servers;
}) };
cfg.lsp.servers;
}) })
# TODO: Figure out what do here. This is not necessarily correct as other lsps might not have formatting by default
(mkIf (cfg.format.enable && !cfg.lsp.enable) { (mkIf (cfg.format.enable && !cfg.lsp.enable) {
vim.formatter.conform-nvim = { vim.formatter.conform-nvim = {
enable = true; enable = true;