nix-community.nixvim/plugins/by-name/lsp-format/default.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

122 lines
3.4 KiB
Nix
Raw Normal View History

2023-05-12 11:01:10 +02:00
{
lib,
config,
pkgs,
2023-05-12 11:01:10 +02:00
...
}:
let
cfg = config.plugins.lsp-format;
in
{
options.plugins.lsp-format = lib.nixvim.neovim-plugin.extraOptionsOptions // {
enable = lib.mkEnableOption "lsp-format.nvim";
2023-05-12 11:01:10 +02:00
package = lib.mkPackageOption pkgs "lsp-format.nvim" {
default = [
"vimPlugins"
"lsp-format-nvim"
];
};
2023-05-12 11:01:10 +02:00
setup = lib.mkOption {
2023-05-12 11:01:10 +02:00
type =
with lib.types;
2023-05-12 11:01:10 +02:00
attrsOf (submodule {
# Allow the user to provide other options
freeformType = types.attrs;
options = {
exclude = lib.nixvim.mkNullOrOption (listOf str) "List of client names to exclude from formatting.";
2023-05-12 11:01:10 +02:00
order = lib.nixvim.mkNullOrOption (listOf str) ''
2023-05-12 11:01:10 +02:00
List of client names. Formatting is requested from clients in the following
order: first all clients that are not in the `order` table, then the remaining
clients in the order as they occur in the `order` table.
(same logic as |vim.lsp.buf.formatting_seq_sync()|).
'';
sync = lib.nixvim.defaultNullOpts.mkBool false ''
2023-05-12 11:01:10 +02:00
Whether to turn on synchronous formatting.
The editor will block until formatting is done.
'';
force = lib.nixvim.defaultNullOpts.mkBool false ''
2023-05-12 11:01:10 +02:00
If true, the format result will always be written to the buffer, even if the
buffer changed.
'';
};
2024-05-05 19:39:35 +02:00
});
2023-05-12 11:01:10 +02:00
description = "The setup option maps |filetypes| to format options.";
example = {
2024-05-19 18:33:14 +02:00
go = {
2023-05-12 11:01:10 +02:00
exclude = [ "gopls" ];
2024-05-05 19:39:35 +02:00
order = [
"gopls"
"efm"
];
2023-05-12 11:01:10 +02:00
sync = true;
force = true;
};
};
default = { };
2024-05-05 19:39:35 +02:00
};
2023-05-12 11:01:10 +02:00
lspServersToEnable = lib.mkOption {
2023-05-12 11:01:10 +02:00
type =
with lib.types;
2023-05-12 11:01:10 +02:00
either (enum [
"none"
"all"
]) (listOf str);
default = "all";
description = ''
Choose the LSP servers for which lsp-format should be enabled.
Possible values:
- "all" (default): Enable formatting for all language servers
- "none": Do not enable formatting on any language server.
You might choose this if for some reason you want to manually call
`require("lsp-format").on_attach(client)` in the `onAttach` function of your language
servers.
- list of LS names: Manually choose the servers by name
'';
example = [
"efm"
"gopls"
];
};
2024-05-05 19:39:35 +02:00
};
2023-05-12 11:01:10 +02:00
config =
let
setupOptions = cfg.setup // cfg.extraOptions;
in
lib.mkIf cfg.enable {
warnings = lib.mkIf (!config.plugins.lsp.enable) [
2023-05-12 11:01:10 +02:00
"You have enabled `plugins.lsp-format` but have `plugins.lsp` disabled."
];
extraPlugins = [ cfg.package ];
plugins.lsp = {
onAttach = lib.mkIf (cfg.lspServersToEnable == "all") ''
2023-05-12 11:01:10 +02:00
require("lsp-format").on_attach(client)
'';
servers =
if (lib.isList cfg.lspServersToEnable) then
lib.genAttrs cfg.lspServersToEnable (serverName: {
2023-05-12 11:01:10 +02:00
onAttach.function = ''
require("lsp-format").on_attach(client)
'';
})
else
{ };
};
extraConfigLua = ''
require("lsp-format").setup(${lib.nixvim.toLuaObject setupOptions})
2023-05-12 11:01:10 +02:00
'';
};
}