diff --git a/docs/default.nix b/docs/default.nix index 211bf3890..2a5142cb5 100644 --- a/docs/default.nix +++ b/docs/default.nix @@ -29,25 +29,68 @@ ]; }; + githubDeclaration = user: repo: subpath: let + urlRef = "main"; + in { + url = "https://github.com/${user}/${repo}/blob/${urlRef}/${subpath}"; + name = "<${repo}/${subpath}>"; + }; + dontCheckDefinitions = {_module.check = false;}; - nvimModuleDocs = nmd.buildModulesDocs { + nvimPath = toString ./..; + + buildOptionsDocs = args @ { + modules, + includeModuleSystemsOptions ? true, + ... + }: let + options = (lib.evalModules {inherit modules;}).options; + in + pkgs.buildPackages.nixosOptionsDoc + ({ + options = + if includeModuleSystemsOptions + then options + else builtins.removeAttrs (options ["_module"]); + transformOptions = opt: + opt + // { + # Clean up declaration sites to not refer to local source tree + declarations = + map + (decl: + if lib.hasPrefix nvimPath (toString decl) + then + githubDeclaration "notashelf" "neovim-flake" + (lib.removePrefix "/" (lib.removePrefix nvimPath (toString decl))) + else decl) + opt.declarations; + }; + } + // builtins.removeAttrs args ["modules" "includeModuleSystemsOptions"]); + + nvimModuleDocs = buildOptionsDocs { modules = - import ../modules/modules.nix { + import ../modules/modules.nix + { inherit pkgs lib; check = false; } - ++ [scrubbedPkgsModule dontCheckDefinitions]; - moduleRootPaths = [./..]; - mkModuleUrl = path: "https://github.com/notashelf/neovim-flake/blob/main/${path}#blob-path"; - channelName = "neovim-flake"; - docBook.id = "neovim-flake-options"; + ++ [scrubbedPkgsModule]; + variablelistId = "neovim-flake-options"; }; docs = nmd.buildDocBookDocs { pathName = "neovim-flake"; projectName = "neovim-flake"; - modulesDocs = [nvimModuleDocs]; + modulesDocs = [ + { + docBook = pkgs.linkFarm "nvim-module-docs-for-nmd" { + "nmd-result/neovim-flake-options.xml" = nvimModuleDocs.optionsDocBook; + }; + } + ]; documentsDirectory = ./.; documentType = "book"; chunkToc = '' @@ -65,7 +108,24 @@ ''; }; in { - options.json = nvimModuleDocs.json.override {path = "share/doc/neovim-flake/options.json";}; - manPages = docs.manPages; + options.json = + pkgs.runCommand "options.json" + # TODO: Use `nvimOptionsDoc.optionsJSON` directly once upstream + # `nixosOptionsDoc` is more customizable + { + meta.description = "List of neovim-flake options in JSON format"; + } '' + mkdir -p $out/{share/doc,nix-support} + cp -a ${nvimModuleDocs.optionsJSON}/share/doc/nixos $out/share/doc/neovim-flake + substitute \ + ${nvimModuleDocs.optionsJSON}/nix-support/hydra-build-products \ + $out/nix-support/hydra-build-products \ + --replace \ + '${nvimModuleDocs.optionsJSON}/share/doc/nixos' \ + "$out/share/doc/neovim-flake" + ''; + + inherit (docs) manPages; + manual = {inherit (docs) html htmlOpenTool;}; } diff --git a/docs/man-configuration.xml b/docs/man-configuration.xml index 84e914e95..e0c870fbd 100644 --- a/docs/man-configuration.xml +++ b/docs/man-configuration.xml @@ -45,6 +45,6 @@ You can use the following options in your neovim configuration. - + diff --git a/docs/manual.xml b/docs/manual.xml index 0584b9c59..2278f9a86 100644 --- a/docs/manual.xml +++ b/docs/manual.xml @@ -25,7 +25,6 @@ Configuration Options - + - diff --git a/docs/manual/hacking.adoc b/docs/manual/hacking.adoc index 33ed8e04a..51995b858 100644 --- a/docs/manual/hacking.adoc +++ b/docs/manual/hacking.adoc @@ -144,6 +144,7 @@ For example: [source,nix] ---- # parent modules should always be unfolded +# which means module = { value = ... } instead of module.value = { ... } module = { value = mkEnableOption "some description" // { default = true; }; # merges can be done inline where possible @@ -202,7 +203,7 @@ without any error messages (you can check the output of `:messages` inside neovi your changes are good to go. Open your pull request, and it will be reviewed as soon as posssible. If it is not a new module, but a change to an existing one, then make sure the module you have changed is enabled in the -maximal configuration by editing configuration.nix, and then run it with `nix run .#maximal -Lv`. Same procedure as +maximal configuration by editing `configuration.nix`, and then run it with `nix run .#maximal -Lv`. Same procedure as adding a new module will apply here. [[sec-keybinds]] diff --git a/docs/release-notes/rl-0.5.adoc b/docs/release-notes/rl-0.5.adoc index f0c72b814..bc0dde976 100644 --- a/docs/release-notes/rl-0.5.adoc +++ b/docs/release-notes/rl-0.5.adoc @@ -74,6 +74,11 @@ https://github.com/notashelf[notashelf]: * Added `nvim-docs-view`, a plugin to display lsp hover documentation in a side panel +* Switched to `nixosOptionsDoc` in option documentation. +To quote home-manager commit: "Output is mostly unchanged aside from some minor typographical and +formatting changes, along with better source links." + + https://github.com/jacekpoz[jacekpoz]: * Fixed scrollOffset not being used diff --git a/lib/default.nix b/lib/default.nix index ad6771a19..2bdaab6bc 100644 --- a/lib/default.nix +++ b/lib/default.nix @@ -3,6 +3,5 @@ booleans = import ./booleans.nix {inherit lib;}; types = import ./types {inherit lib;}; languages = import ./languages.nix {inherit lib;}; - nmd = import ./nmd.nix; lua = import ./lua.nix {inherit lib;}; } diff --git a/lib/stdlib-extended.nix b/lib/stdlib-extended.nix index a54e5e939..983324873 100644 --- a/lib/stdlib-extended.nix +++ b/lib/stdlib-extended.nix @@ -70,5 +70,4 @@ in # For forward compatibility. literalExpression = super.literalExpression or super.literalExample; - literalDocBook = super.literalDocBook or super.literalExample; }) diff --git a/lib/types/plugins.nix b/lib/types/plugins.nix index 344c40577..ee33a4287 100644 --- a/lib/types/plugins.nix +++ b/lib/types/plugins.nix @@ -112,6 +112,7 @@ with lib; let options = { package = mkOption { type = pluginType; + description = "Plugin Package."; }; after = mkOption { type = listOf str; diff --git a/modules/autopairs/nvim-autopairs/nvim-autopairs.nix b/modules/autopairs/nvim-autopairs/nvim-autopairs.nix index 9dc8c64ac..d64b5cbd3 100644 --- a/modules/autopairs/nvim-autopairs/nvim-autopairs.nix +++ b/modules/autopairs/nvim-autopairs/nvim-autopairs.nix @@ -15,7 +15,7 @@ with builtins; { map_cr = mkOption { type = types.bool; default = true; - description = nvim.nmd.asciiDoc ''map on insert mode''; + description = ''map on insert mode''; }; map_complete = mkOption { diff --git a/modules/completion/nvim-cmp/nvim-cmp.nix b/modules/completion/nvim-cmp/nvim-cmp.nix index fa7041b7e..fb9be8648 100644 --- a/modules/completion/nvim-cmp/nvim-cmp.nix +++ b/modules/completion/nvim-cmp/nvim-cmp.nix @@ -22,7 +22,7 @@ with builtins; { }; sources = mkOption { - description = nvim.nmd.asciiDoc '' + description = '' Attribute set of source names for nvim-cmp. If an attribute set is provided, then the menu value of @@ -40,23 +40,22 @@ with builtins; { formatting = { format = mkOption { - description = nvim.nmd.asciiDoc '' + description = '' The function used to customize the appearance of the completion menu. - If <> is true, then the function + If [](#opt-vim.lsp.lspkind.enable) is true, then the function will be called before modifications from lspkind. Default is to call the menu mapping function. ''; type = types.str; default = "nvim_cmp_menu_map"; - example = nvim.nmd.literalAsciiDoc '' - [source,lua] - --- + example = lib.literalMD '' + ```lua function(entry, vim_item) return vim_item end - --- + ``` ''; }; }; diff --git a/modules/core/default.nix b/modules/core/default.nix index fd097ef8b..2a352629e 100644 --- a/modules/core/default.nix +++ b/modules/core/default.nix @@ -27,23 +27,23 @@ with builtins; let mapConfigOptions = { silent = mkBool false - (nvim.nmd.asciiDoc "Whether this mapping should be silent. Equivalent to adding to a map."); + "Whether this mapping should be silent. Equivalent to adding to a map."; nowait = mkBool false - (nvim.nmd.asciiDoc "Whether to wait for extra input on ambiguous mappings. Equivalent to adding to a map."); + "Whether to wait for extra input on ambiguous mappings. Equivalent to adding to a map."; script = mkBool false - (nvim.nmd.asciiDoc "Equivalent to adding