diff options
author | Naïm Favier <n@monade.li> | 2023-01-09 11:57:01 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-01-09 11:57:01 +0100 |
commit | bff4bb554028cbf083bc0d1e0a6a251653e5056d (patch) | |
tree | e0fc4768d98a58e68076bf11e578ec3f0b53e843 /nixos/lib/make-options-doc | |
parent | 8cd3fc50f9f13a1dc93f237c97789fac3675d524 (diff) | |
parent | 4fb500d62937dcce11c84e7c36fcc0d5db354d5c (diff) |
Merge pull request #208762 from ncfavier/link-manpages-options-doc
Diffstat (limited to 'nixos/lib/make-options-doc')
-rw-r--r-- | nixos/lib/make-options-doc/default.nix | 2 | ||||
-rw-r--r-- | nixos/lib/make-options-doc/mergeJSON.py | 10 |
2 files changed, 11 insertions, 1 deletions
diff --git a/nixos/lib/make-options-doc/default.nix b/nixos/lib/make-options-doc/default.nix index ecd8350b959d6..e2ed7bb71885b 100644 --- a/nixos/lib/make-options-doc/default.nix +++ b/nixos/lib/make-options-doc/default.nix @@ -131,6 +131,8 @@ in rec { if baseOptionsJSON == null then builtins.toFile "base.json" "{}" else baseOptionsJSON; + + MANPAGE_URLS = pkgs.path + "/doc/manpage-urls.json"; } '' # Export list of options in different format. diff --git a/nixos/lib/make-options-doc/mergeJSON.py b/nixos/lib/make-options-doc/mergeJSON.py index 7b14af40c313b..c4f490fc2ad87 100644 --- a/nixos/lib/make-options-doc/mergeJSON.py +++ b/nixos/lib/make-options-doc/mergeJSON.py @@ -1,5 +1,6 @@ import collections import json +import os import sys from typing import Any, Dict, List @@ -46,6 +47,8 @@ def unpivot(options: Dict[Key, Option]) -> Dict[str, JSON]: result[opt.name] = opt.value return result +manpage_urls = json.load(open(os.getenv('MANPAGE_URLS'))) + admonitions = { '.warning': 'warning', '.important': 'important', @@ -119,9 +122,14 @@ class Renderer(mistune.renderers.BaseRenderer): def env(self, text): return f"<envar>{escape(text)}</envar>" def manpage(self, page, section): + man = f"{page}({section})" title = f"<refentrytitle>{escape(page)}</refentrytitle>" vol = f"<manvolnum>{escape(section)}</manvolnum>" - return f"<citerefentry>{title}{vol}</citerefentry>" + ref = f"<citerefentry>{title}{vol}</citerefentry>" + if man in manpage_urls: + return self.link(manpage_urls[man], text=ref) + else: + return ref def finalize(self, data): return "".join(data) |