mirror of
https://github.com/NotAShelf/nvf.git
synced 2026-05-20 22:08:47 +00:00
languages/haskell.nix: Address PR comments
- Move formatting responsibility to conform-nvim, instead of HLS - Wrap formatter binaries separately now that we are not using the HLS-bundled libraries - Add helpful assertion message to enforce the "not HLS if haskell-tools" invariant. - Add helpful assertion message to enforce the "not DAP if not haskell-tools" invariant.
This commit is contained in:
parent
f15c3f377a
commit
b2d6a252ce
2 changed files with 82 additions and 17 deletions
|
|
@ -10,17 +10,24 @@
|
||||||
inherit (lib.options) mkEnableOption mkOption literalExpression;
|
inherit (lib.options) mkEnableOption mkOption literalExpression;
|
||||||
inherit (lib.strings) optionalString;
|
inherit (lib.strings) optionalString;
|
||||||
inherit (lib.modules) mkIf mkMerge;
|
inherit (lib.modules) mkIf mkMerge;
|
||||||
inherit (lib.nvim.types) mkGrammarOption;
|
inherit (lib.nvim.types) mkGrammarOption deprecatedSingleOrListOf;
|
||||||
inherit (lib.nvim.lua) toLuaObject;
|
inherit (lib.nvim.lua) toLuaObject;
|
||||||
inherit (lib.nvim.dag) entryAfter;
|
inherit (lib.nvim.dag) entryAfter;
|
||||||
inherit (lib.meta) getExe';
|
inherit (lib.nvim.attrsets) mapListToAttrs;
|
||||||
|
inherit (lib.meta) getExe getExe';
|
||||||
inherit (pkgs) haskellPackages;
|
inherit (pkgs) haskellPackages;
|
||||||
|
|
||||||
cfg = config.vim.languages.haskell;
|
cfg = config.vim.languages.haskell;
|
||||||
|
|
||||||
defaultServers = ["haskell-language-server"];
|
defaultServers = ["haskell-language-server"];
|
||||||
servers = {
|
servers = ["haskell-language-server"];
|
||||||
haskell-language-server = {};
|
|
||||||
|
defaultFormat = ["ormolu"];
|
||||||
|
formats = {
|
||||||
|
ormolu = {command = getExe haskellPackages.ormolu;};
|
||||||
|
fourmolu = {command = getExe haskellPackages.fourmolu;};
|
||||||
|
stylish-haskell = {command = getExe haskellPackages.stylish-haskell;};
|
||||||
|
floskell = {command = getExe haskellPackages.floskell;};
|
||||||
};
|
};
|
||||||
in {
|
in {
|
||||||
options.vim.languages.haskell = {
|
options.vim.languages.haskell = {
|
||||||
|
|
@ -44,14 +51,23 @@ in {
|
||||||
defaultText = literalExpression "config.vim.lsp.enable";
|
defaultText = literalExpression "config.vim.lsp.enable";
|
||||||
};
|
};
|
||||||
servers = mkOption {
|
servers = mkOption {
|
||||||
type = listOf (enum (attrNames servers));
|
type = listOf (enum servers);
|
||||||
default = defaultServers;
|
default = defaultServers;
|
||||||
description = "Haskell LSP server to use";
|
description = "Haskell LSP server to use";
|
||||||
};
|
};
|
||||||
formattingProvider = mkOption {
|
};
|
||||||
type = enum ["ormolu" "fourmolu" "stylish-haskell" "brittany" "floskell" "none"];
|
|
||||||
default = "ormolu";
|
format = {
|
||||||
description = "Formatter used by HLS";
|
enable =
|
||||||
|
mkEnableOption "Haskell formatting"
|
||||||
|
// {
|
||||||
|
default = config.vim.languages.enableFormat;
|
||||||
|
defaultText = literalExpression "config.vim.languages.enableFormat";
|
||||||
|
};
|
||||||
|
type = mkOption {
|
||||||
|
type = deprecatedSingleOrListOf "vim.languages.haskell.format.type" (enum (attrNames formats));
|
||||||
|
default = defaultFormat;
|
||||||
|
description = "Haskell formatter to use";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -77,6 +93,27 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
config = mkIf cfg.enable (mkMerge [
|
config = mkIf cfg.enable (mkMerge [
|
||||||
|
{
|
||||||
|
assertions = [
|
||||||
|
{
|
||||||
|
assertion = !(cfg.lsp.enable && cfg.extensions.haskell-tools.enable);
|
||||||
|
message = ''
|
||||||
|
vim.languages.haskell: haskell-tools.nvim manages the LSP directly and
|
||||||
|
is incompatible with vim.languages.haskell.lsp.enable. Disable one or
|
||||||
|
the other. See https://github.com/mrcjkb/haskell-tools.nvim/blob/fe9ed6e6adfa6311e06c84569d8536190f172030/doc/haskell-tools.txt#L22
|
||||||
|
'';
|
||||||
|
}
|
||||||
|
{
|
||||||
|
assertion = !(cfg.dap.enable && !cfg.extensions.haskell-tools.enable);
|
||||||
|
message = ''
|
||||||
|
vim.languages.haskell: DAP support requires haskell-tools.nvim, which
|
||||||
|
handles adapter registration and launch configuration discovery.
|
||||||
|
Enable vim.languages.haskell.extensions.haskell-tools to use DAP.
|
||||||
|
'';
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
(mkIf cfg.treesitter.enable {
|
(mkIf cfg.treesitter.enable {
|
||||||
vim.treesitter = {
|
vim.treesitter = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
|
@ -84,18 +121,33 @@ in {
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
|
|
||||||
# haskell-tools prefers to manage the lsp directly,
|
(mkIf cfg.lsp.enable {
|
||||||
# so we only configure the lsp ourselves if haskell-tools is disabled
|
|
||||||
(mkIf (cfg.lsp.enable && !cfg.extensions.haskell-tools.enable) {
|
|
||||||
vim.lsp = {
|
vim.lsp = {
|
||||||
presets = genAttrs cfg.lsp.servers (_: {enable = true;});
|
presets = genAttrs cfg.lsp.servers (_: {enable = true;});
|
||||||
servers = genAttrs cfg.lsp.servers (_: {
|
servers = genAttrs cfg.lsp.servers (_: {
|
||||||
filetypes = ["haskell" "lhaskell"];
|
filetypes = ["haskell" "lhaskell"];
|
||||||
settings.haskell.formattingProvider = cfg.lsp.formattingProvider;
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
|
|
||||||
|
(mkIf cfg.format.enable {
|
||||||
|
vim.formatter.conform-nvim = {
|
||||||
|
enable = true;
|
||||||
|
setupOpts = {
|
||||||
|
formatters_by_ft = {
|
||||||
|
haskell = cfg.format.type;
|
||||||
|
lhaskell = cfg.format.type;
|
||||||
|
};
|
||||||
|
formatters =
|
||||||
|
mapListToAttrs (name: {
|
||||||
|
inherit name;
|
||||||
|
value = formats.${name};
|
||||||
|
})
|
||||||
|
cfg.format.type;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
})
|
||||||
|
|
||||||
(mkIf cfg.extensions.haskell-tools.enable {
|
(mkIf cfg.extensions.haskell-tools.enable {
|
||||||
vim = {
|
vim = {
|
||||||
extraPackages = [haskellPackages.cabal-fmt];
|
extraPackages = [haskellPackages.cabal-fmt];
|
||||||
|
|
@ -129,7 +181,7 @@ in {
|
||||||
end,
|
end,
|
||||||
settings = {
|
settings = {
|
||||||
haskell = {
|
haskell = {
|
||||||
formattingProvider = "${cfg.lsp.formattingProvider}",
|
formattingProvider = "none",
|
||||||
cabalFormattingProvider = "cabal-fmt",
|
cabalFormattingProvider = "cabal-fmt",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -15,14 +15,27 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
vim.extraPackages = [pkgs.haskellPackages.cabal-fmt];
|
|
||||||
vim.lsp.servers.haskell-language-server = {
|
vim.lsp.servers.haskell-language-server = {
|
||||||
enable = true;
|
enable = true;
|
||||||
cmd = [(getExe' pkgs.haskellPackages.haskell-language-server "haskell-language-server-wrapper") "--lsp"];
|
cmd = [
|
||||||
|
(getExe' (pkgs.symlinkJoin {
|
||||||
|
name = "haskell-language-server-wrapper";
|
||||||
|
paths = [pkgs.haskellPackages.haskell-language-server];
|
||||||
|
meta.mainProgram = "haskell-language-server-wrapper";
|
||||||
|
buildInputs = [pkgs.makeBinaryWrapper];
|
||||||
|
postBuild = ''
|
||||||
|
wrapProgram $out/bin/haskell-language-server-wrapper \
|
||||||
|
--prefix PATH : ${pkgs.haskellPackages.cabal-fmt}/bin
|
||||||
|
'';
|
||||||
|
}) "haskell-language-server-wrapper")
|
||||||
|
"--lsp"
|
||||||
|
];
|
||||||
root_markers = ["hie.yaml" "stack.yaml" "cabal.project" "*.cabal" "package.yaml"];
|
root_markers = ["hie.yaml" "stack.yaml" "cabal.project" "*.cabal" "package.yaml"];
|
||||||
settings = {
|
settings = {
|
||||||
haskell = {
|
haskell = {
|
||||||
formattingProvider = "ormolu";
|
# formatting is handled by conform-nvim; disable HLS's built-in formatter
|
||||||
|
formattingProvider = "none";
|
||||||
|
# cabal-fmt is an external tool; it is wrapped into the LSP binary's PATH above
|
||||||
cabalFormattingProvider = "cabal-fmt";
|
cabalFormattingProvider = "cabal-fmt";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue