2023-04-18 00:38:57 +03:00
|
|
|
{
|
|
|
|
|
config,
|
2024-03-08 20:34:19 +03:00
|
|
|
pkgs,
|
2023-04-18 00:38:57 +03:00
|
|
|
lib,
|
|
|
|
|
...
|
2023-11-07 19:16:46 -07:00
|
|
|
}: let
|
2025-11-16 19:49:21 +01:00
|
|
|
inherit (builtins) attrNames warn;
|
2025-03-27 20:13:07 +01:00
|
|
|
inherit (lib.meta) getExe;
|
2024-05-08 00:22:12 +03:00
|
|
|
inherit (lib.modules) mkIf mkMerge;
|
2024-03-08 20:34:19 +03:00
|
|
|
inherit (lib.options) mkEnableOption mkOption;
|
2025-11-16 19:49:21 +01:00
|
|
|
inherit (lib.types) bool enum listOf str nullOr;
|
2025-05-22 16:11:38 +01:00
|
|
|
inherit (lib.nvim.lua) toLuaObject;
|
2025-11-16 19:49:21 +01:00
|
|
|
inherit (lib.nvim.types) diagnostics mkGrammarOption mkPluginSetupOption deprecatedSingleOrListOf;
|
2024-12-31 07:02:13 +03:00
|
|
|
inherit (lib.nvim.dag) entryAnywhere;
|
2025-05-22 16:11:38 +01:00
|
|
|
inherit (lib.nvim.attrsets) mapListToAttrs;
|
2023-11-07 19:16:46 -07:00
|
|
|
|
2023-04-18 00:38:57 +03:00
|
|
|
cfg = config.vim.languages.markdown;
|
2025-05-22 16:11:38 +01:00
|
|
|
defaultServers = ["marksman"];
|
2024-01-18 17:28:46 +01:00
|
|
|
servers = {
|
|
|
|
|
marksman = {
|
2025-05-22 16:11:38 +01:00
|
|
|
enable = true;
|
2025-05-30 13:29:04 +01:00
|
|
|
cmd = [(getExe pkgs.marksman) "server"];
|
|
|
|
|
filetypes = ["markdown" "markdown.mdx"];
|
|
|
|
|
root_markers = [".marksman.toml" ".git"];
|
2024-01-18 17:28:46 +01:00
|
|
|
};
|
2025-09-07 00:47:04 +00:00
|
|
|
|
|
|
|
|
markdown-oxide = {
|
|
|
|
|
enable = true;
|
|
|
|
|
cmd = [(getExe pkgs.markdown-oxide)];
|
|
|
|
|
filetypes = ["markdown"];
|
|
|
|
|
root_markers = [".git" ".obsidian" ".moxide.toml"];
|
|
|
|
|
};
|
2024-01-18 17:28:46 +01:00
|
|
|
};
|
2024-05-06 22:22:43 +03:00
|
|
|
|
2025-11-16 19:49:21 +01:00
|
|
|
defaultFormat = ["deno_fmt"];
|
2024-05-06 22:22:43 +03:00
|
|
|
formats = {
|
2025-03-27 20:13:07 +01:00
|
|
|
# for backwards compatibility
|
2024-05-06 22:22:43 +03:00
|
|
|
denofmt = {
|
2025-11-16 19:49:21 +01:00
|
|
|
command = getExe pkgs.deno;
|
2025-03-27 20:13:07 +01:00
|
|
|
};
|
|
|
|
|
deno_fmt = {
|
2025-11-16 19:49:21 +01:00
|
|
|
command = getExe pkgs.deno;
|
2024-05-06 22:22:43 +03:00
|
|
|
};
|
2025-01-11 12:48:41 +01:00
|
|
|
prettierd = {
|
2025-11-16 19:49:21 +01:00
|
|
|
command = getExe pkgs.prettierd;
|
2025-01-11 12:48:41 +01:00
|
|
|
};
|
2024-05-06 22:22:43 +03:00
|
|
|
};
|
2025-03-31 12:15:02 -07:00
|
|
|
defaultDiagnosticsProvider = ["markdownlint-cli2"];
|
|
|
|
|
diagnosticsProviders = {
|
|
|
|
|
markdownlint-cli2 = {
|
|
|
|
|
package = pkgs.markdownlint-cli2;
|
2025-01-11 12:48:41 +01:00
|
|
|
};
|
2024-05-06 22:22:43 +03:00
|
|
|
};
|
2023-04-18 00:38:57 +03:00
|
|
|
in {
|
|
|
|
|
options.vim.languages.markdown = {
|
2023-06-05 23:10:25 +03:00
|
|
|
enable = mkEnableOption "Markdown markup language support";
|
2023-04-18 00:38:57 +03:00
|
|
|
|
2023-04-18 00:55:27 +03:00
|
|
|
treesitter = {
|
|
|
|
|
enable = mkOption {
|
2024-03-08 20:34:19 +03:00
|
|
|
type = bool;
|
2023-04-18 00:55:27 +03:00
|
|
|
default = config.vim.languages.enableTreesitter;
|
2024-05-08 00:22:12 +03:00
|
|
|
description = "Enable Markdown treesitter";
|
2023-04-18 00:55:27 +03:00
|
|
|
};
|
2024-03-08 20:34:19 +03:00
|
|
|
mdPackage = mkGrammarOption pkgs "markdown";
|
|
|
|
|
mdInlinePackage = mkGrammarOption pkgs "markdown-inline";
|
2023-04-18 00:55:27 +03:00
|
|
|
};
|
2024-01-18 17:28:46 +01:00
|
|
|
|
|
|
|
|
lsp = {
|
2025-06-02 09:18:23 +01:00
|
|
|
enable = mkEnableOption "Markdown LSP support" // {default = config.vim.lsp.enable;};
|
2024-01-18 17:28:46 +01:00
|
|
|
|
2025-05-22 16:11:38 +01:00
|
|
|
servers = mkOption {
|
2024-05-08 00:22:12 +03:00
|
|
|
description = "Markdown LSP server to use";
|
2025-11-16 19:49:21 +01:00
|
|
|
type = deprecatedSingleOrListOf "vim.language.markdown.lsp.servers" (enum (attrNames servers));
|
2025-05-22 16:11:38 +01:00
|
|
|
default = defaultServers;
|
2024-01-18 17:28:46 +01:00
|
|
|
};
|
|
|
|
|
};
|
2024-05-06 22:22:43 +03:00
|
|
|
|
|
|
|
|
format = {
|
|
|
|
|
enable = mkEnableOption "Markdown formatting" // {default = config.vim.languages.enableFormat;};
|
|
|
|
|
|
|
|
|
|
type = mkOption {
|
2025-11-16 19:49:21 +01:00
|
|
|
type = deprecatedSingleOrListOf "vim.language.markdown.format.type" (enum (attrNames formats));
|
2024-05-06 22:22:43 +03:00
|
|
|
default = defaultFormat;
|
2025-03-27 20:13:07 +01:00
|
|
|
description = "Markdown formatter to use. `denofmt` is deprecated and currently aliased to deno_fmt.";
|
2024-05-06 22:22:43 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
extraFiletypes = mkOption {
|
|
|
|
|
type = listOf str;
|
|
|
|
|
default = [];
|
2024-05-08 00:31:23 +03:00
|
|
|
description = "Extra filetypes to format with the Markdown formatter";
|
2024-05-06 22:22:43 +03:00
|
|
|
};
|
|
|
|
|
};
|
2024-12-31 07:02:13 +03:00
|
|
|
|
|
|
|
|
extensions = {
|
|
|
|
|
render-markdown-nvim = {
|
|
|
|
|
enable =
|
|
|
|
|
mkEnableOption ""
|
|
|
|
|
// {
|
|
|
|
|
description = ''
|
|
|
|
|
[render-markdown.nvim]: https://github.com/MeanderingProgrammer/render-markdown.nvim
|
|
|
|
|
|
|
|
|
|
Inline Markdown rendering with [render-markdown.nvim]
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
setupOpts = mkPluginSetupOption "render-markdown" {
|
2025-04-22 17:55:21 +01:00
|
|
|
file_types = lib.mkOption {
|
2025-04-22 22:36:11 +01:00
|
|
|
type = nullOr (listOf str);
|
|
|
|
|
default = null;
|
2025-04-22 21:32:53 +01:00
|
|
|
description = ''
|
|
|
|
|
List of buffer filetypes to enable this plugin in.
|
|
|
|
|
|
|
|
|
|
This will cause the plugin to attach to new buffers who
|
|
|
|
|
have any of these filetypes.
|
|
|
|
|
'';
|
2024-12-31 07:02:13 +03:00
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
};
|
2025-03-10 12:51:19 +03:00
|
|
|
markview-nvim = {
|
|
|
|
|
enable =
|
|
|
|
|
mkEnableOption ""
|
|
|
|
|
// {
|
|
|
|
|
description = ''
|
|
|
|
|
[markview.nvim]: https://github.com/OXY2DEV/markview.nvim
|
|
|
|
|
|
|
|
|
|
[markview.nvim] - a hackable markdown, Typst, latex, html(inline) & YAML previewer
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
setupOpts = mkPluginSetupOption "markview-nvim" {};
|
|
|
|
|
};
|
2024-12-31 07:02:13 +03:00
|
|
|
};
|
2025-03-31 12:15:02 -07:00
|
|
|
|
|
|
|
|
extraDiagnostics = {
|
|
|
|
|
enable = mkEnableOption "extra Markdown diagnostics" // {default = config.vim.languages.enableExtraDiagnostics;};
|
|
|
|
|
types = diagnostics {
|
|
|
|
|
langDesc = "Markdown";
|
|
|
|
|
inherit diagnosticsProviders;
|
|
|
|
|
inherit defaultDiagnosticsProvider;
|
|
|
|
|
};
|
|
|
|
|
};
|
2023-04-18 00:38:57 +03:00
|
|
|
};
|
2024-05-08 00:22:12 +03:00
|
|
|
|
|
|
|
|
config = mkIf cfg.enable (mkMerge [
|
|
|
|
|
(mkIf cfg.treesitter.enable {
|
|
|
|
|
vim.treesitter.enable = true;
|
|
|
|
|
vim.treesitter.grammars = [cfg.treesitter.mdPackage cfg.treesitter.mdInlinePackage];
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
(mkIf cfg.lsp.enable {
|
2025-05-22 16:11:38 +01:00
|
|
|
vim.lsp.servers =
|
|
|
|
|
mapListToAttrs (n: {
|
|
|
|
|
name = n;
|
|
|
|
|
value = servers.${n};
|
|
|
|
|
})
|
|
|
|
|
cfg.lsp.servers;
|
2024-05-08 00:22:12 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
|
|
(mkIf cfg.format.enable {
|
2025-03-27 20:13:07 +01:00
|
|
|
vim.formatter.conform-nvim = {
|
|
|
|
|
enable = true;
|
2025-11-16 19:49:21 +01:00
|
|
|
setupOpts = {
|
|
|
|
|
formatters_by_ft.markdown = cfg.format.type;
|
|
|
|
|
formatters = let
|
|
|
|
|
names = map (name:
|
|
|
|
|
if name == "denofmt"
|
|
|
|
|
then
|
|
|
|
|
warn ''
|
|
|
|
|
vim.languages.markdown.format.type: "denofmt" is renamed to "deno_fmt".
|
|
|
|
|
'' "deno_fmt"
|
|
|
|
|
else name)
|
|
|
|
|
cfg.format.type;
|
|
|
|
|
in
|
|
|
|
|
mapListToAttrs (name: {
|
|
|
|
|
inherit name;
|
|
|
|
|
value = formats.${name};
|
|
|
|
|
})
|
|
|
|
|
names;
|
2025-03-27 20:13:07 +01:00
|
|
|
};
|
|
|
|
|
};
|
2024-05-08 00:22:12 +03:00
|
|
|
})
|
2024-12-31 07:02:13 +03:00
|
|
|
|
|
|
|
|
# Extensions
|
|
|
|
|
(mkIf cfg.extensions.render-markdown-nvim.enable {
|
|
|
|
|
vim.startPlugins = ["render-markdown-nvim"];
|
|
|
|
|
vim.pluginRC.render-markdown-nvim = entryAnywhere ''
|
|
|
|
|
require("render-markdown").setup(${toLuaObject cfg.extensions.render-markdown-nvim.setupOpts})
|
|
|
|
|
'';
|
|
|
|
|
})
|
2025-03-10 12:51:19 +03:00
|
|
|
|
|
|
|
|
(mkIf cfg.extensions.markview-nvim.enable {
|
|
|
|
|
vim.startPlugins = ["markview-nvim"];
|
|
|
|
|
vim.pluginRC.markview-nvim = entryAnywhere ''
|
|
|
|
|
require("markview").setup(${toLuaObject cfg.extensions.markview-nvim.setupOpts})
|
|
|
|
|
'';
|
|
|
|
|
})
|
2025-05-10 07:54:24 +03:00
|
|
|
|
2025-03-31 12:15:02 -07:00
|
|
|
(mkIf cfg.extraDiagnostics.enable {
|
|
|
|
|
vim.diagnostics.nvim-lint = {
|
|
|
|
|
enable = true;
|
|
|
|
|
linters_by_ft.markdown = cfg.extraDiagnostics.types;
|
|
|
|
|
linters = mkMerge (map (name: {
|
|
|
|
|
${name}.cmd = getExe diagnosticsProviders.${name}.package;
|
|
|
|
|
})
|
|
|
|
|
cfg.extraDiagnostics.types);
|
|
|
|
|
};
|
|
|
|
|
})
|
2024-05-08 00:22:12 +03:00
|
|
|
]);
|
2023-04-18 00:38:57 +03:00
|
|
|
}
|