diff --git a/dev/flake-module.nix b/dev/flake-module.nix index 216cb2a..60da698 100644 --- a/dev/flake-module.nix +++ b/dev/flake-module.nix @@ -1,4 +1,4 @@ -flakeModuleArgs@{ config, lib, inputs, ... }: +{ config, lib, inputs, ... }: { imports = [ @@ -28,22 +28,6 @@ flakeModuleArgs@{ config, lib, inputs, ... }: }; }; - packages = { - inherit (pkgs.nixosOptionsDoc { inherit (flakeModuleArgs) options; }) - optionsDocBook; - optionsMarkdown = pkgs.runCommand "options-markdown" - { - inherit (config.packages) optionsDocBook; - nativeBuildInputs = [ pkgs.pandoc ]; - } '' - mkdir $out - pandoc \ - --from docbook \ - --to markdown \ - --output $out/options.md \ - $optionsDocBook - ''; - }; }; flake = { options.herculesCI = lib.mkOption { type = lib.types.raw; }; @@ -57,7 +41,7 @@ flakeModuleArgs@{ config, lib, inputs, ... }: in { netlifyDeploy = effects.runIf (branch == "main") (effects.netlifyDeploy { - content = config.flake.packages.x86_64-linux.websitePackage; + content = config.flake.packages.x86_64-linux.siteContent; secretName = "default-netlify"; siteId = "29a153b1-3698-433c-bc73-62415efb8117"; productionDeployment = true; diff --git a/dev/flake.lock b/dev/flake.lock index 1165ae2..2dcc47f 100644 --- a/dev/flake.lock +++ b/dev/flake.lock @@ -51,15 +51,16 @@ }, "nixpkgs_2": { "locked": { - "lastModified": 1653465299, - "narHash": "sha256-+1jyM4dsppYFgiJf+VkAAS/l5iF0y5J7D2l1fLzT8DA=", - "owner": "NixOS", + "lastModified": 1653476104, + "narHash": "sha256-oVuWUnGQX+fRn/cFoNfbLEUGtsyyXuMLDQFEZ2OxP3k=", + "owner": "hercules-ci", "repo": "nixpkgs", - "rev": "5862243e1ab8c0a19cb448f523c27c167dcd826b", + "rev": "612e22e67eb6f8d5bfb6288abe515e9da3b96103", "type": "github" }, "original": { - "owner": "NixOS", + "owner": "hercules-ci", + "ref": "module-docs-update", "repo": "nixpkgs", "type": "github" } diff --git a/dev/flake.nix b/dev/flake.nix index 41ac8a4..1b1d4e1 100644 --- a/dev/flake.nix +++ b/dev/flake.nix @@ -4,7 +4,10 @@ inputs = { # Flakes don't give us a good way to depend on .., so we don't. # This has drastic consequences of course. - nixpkgs.url = "github:NixOS/nixpkgs"; + + # https://github.com/NixOS/nixpkgs/pull/174460 + # https://github.com/NixOS/nixpkgs/pull/174470 + nixpkgs.url = "github:hercules-ci/nixpkgs/module-docs-update"; pre-commit-hooks-nix.url = "github:hercules-ci/pre-commit-hooks.nix/flakeModule"; pre-commit-hooks-nix.inputs.nixpkgs.follows = "nixpkgs"; diff --git a/site/flake-module.nix b/site/flake-module.nix index 827488c..3543cb4 100644 --- a/site/flake-module.nix +++ b/site/flake-module.nix @@ -1,22 +1,74 @@ { ... }: { - perSystem = system: { config, self', inputs', pkgs, lib, ... }: { - packages.websitePackage = pkgs.stdenvNoCC.mkDerivation { - name = "site"; - nativeBuildInputs = [ pkgs.pandoc ]; - src = lib.cleanSourceWith { - filter = path: type: - path == ./. - || baseNameOf path == "index.html"; - src = ./.; + perSystem = system: { config, self', inputs', pkgs, lib, ... }: + let + inherit (lib) filter any hasPrefix concatMap removePrefix; + + libNix = import ../lib.nix { inherit lib; }; + eval = libNix.evalFlakeModule { self = { }; } { }; + opts = eval.options; + + filterTransformOptions = { sourceName, sourcePath, baseUrl }: + let sourcePathStr = toString sourcePath; + in + opt: + let declarations = concatMap + (decl: + if hasPrefix sourcePathStr (toString decl) + then + let subpath = removePrefix sourcePathStr (toString decl); + in [{ url = baseUrl + subpath; name = sourceName + subpath; }] + else [ ] + ) + opt.declarations; + in + if declarations == [ ] + then opt // { visible = false; } + else opt // { inherit declarations; }; + + optionsDoc = { sourceName, baseUrl, sourcePath, title }: pkgs.runCommand "${sourceName}-doc" + { + nativeBuildInputs = [ pkgs.libxslt.bin ]; + inputDoc = (pkgs.nixosOptionsDoc { + options = opts; + documentType = "none"; + transformOptions = filterTransformOptions { + inherit sourceName baseUrl sourcePath; + }; + }).optionsDocBook; + inherit title; + } '' + xsltproc --stringparam title "$title" \ + -o $out ${./options.xsl} \ + "$inputDoc" + ''; + in + { + + packages = { + + siteContent = pkgs.stdenvNoCC.mkDerivation { + name = "site"; + nativeBuildInputs = [ pkgs.pandoc pkgs.libxslt.bin ]; + src = lib.cleanSourceWith { + filter = path: type: + path == ./. + || baseNameOf path == "index.html"; + src = ./.; + }; + coreOptions = optionsDoc { + title = "Core Options"; + sourceName = "flake-modules-core"; + baseUrl = "https://github.com/hercules-ci/flake-modules-core/blob/main"; + sourcePath = ../.; + }; + buildPhase = '' + pandoc --verbose --from docbook --to html5 $coreOptions >options.html + ''; + installPhase = '' + mkdir -p $out + cp *.html $out/ + ''; + }; }; - buildPhase = '' - pandoc --from docbook --to html5 \ - ${config.packages.optionsDocBook} >options.html - ''; - installPhase = '' - mkdir -p $out - cp *.html $out/ - ''; }; - }; } diff --git a/site/options.xsl b/site/options.xsl new file mode 100644 index 0000000..70f725d --- /dev/null +++ b/site/options.xsl @@ -0,0 +1,53 @@ + + + + + + + + + <xsl:value-of select="$title"/> + + + + + +
+ + + + + <xsl:copy-of select="db:term/db:option"/> + + +
+
+ + + + + + + + + + + + + + + + + + + + + + +
\ No newline at end of file