mirror of
https://github.com/NotAShelf/nvf.git
synced 2026-01-18 16:18:39 +00:00
Compare commits
No commits in common. "96f3524a4ddd8229da0c61cfef8f701259fcbe51" and "1a1569e6dd52889533b8f4f77c7107fe8cadf551" have entirely different histories.
96f3524a4d
...
1a1569e6dd
4 changed files with 122 additions and 45 deletions
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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,14 +105,17 @@ 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.
|
/*
|
||||||
|
lua
|
||||||
|
*/
|
||||||
|
''
|
||||||
${concatLines lspConfigurations}
|
${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))});
|
||||||
'';
|
'';
|
||||||
})
|
})
|
||||||
];
|
];
|
||||||
|
|
|
||||||
|
|
@ -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 {
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue