chore(modules): factor out option doc generation (#152)
* chore(modules): factor out option doc generation * ci: only validate sources on pushes to main
This commit is contained in:
parent
2983ec9796
commit
5b5648c10e
6 changed files with 40 additions and 44 deletions
8
.github/workflows/ci.yml
vendored
8
.github/workflows/ci.yml
vendored
|
@ -14,9 +14,6 @@ jobs:
|
|||
name: Check formatting
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
permissions:
|
||||
contents: read
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
|
||||
|
@ -34,9 +31,6 @@ jobs:
|
|||
name: Test Modules
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
permissions:
|
||||
contents: read
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
|
||||
|
@ -48,4 +42,4 @@ jobs:
|
|||
|
||||
- name: Run VM
|
||||
run: |
|
||||
nix build -L --show-trace ./dev#checks.x86_64-linux.module-vm-test
|
||||
nix build --print-build-logs --show-trace ./dev#checks.x86_64-linux.module-vm-test
|
||||
|
|
2
.github/workflows/update-docs.yml
vendored
2
.github/workflows/update-docs.yml
vendored
|
@ -36,7 +36,7 @@ jobs:
|
|||
- name: Build & update docs
|
||||
run: |
|
||||
for module in "nixos" "home-manager"; do
|
||||
nix build -L --show-trace ./dev#"$module"-doc
|
||||
nix build --print-build-logs --show-trace ./dev#"$module"-doc
|
||||
cat result > docs/"$module"-options.md
|
||||
rm result
|
||||
done
|
||||
|
|
1
.github/workflows/validate-sources.yml
vendored
1
.github/workflows/validate-sources.yml
vendored
|
@ -7,6 +7,7 @@ on:
|
|||
paths:
|
||||
- '_sources/**'
|
||||
- 'nvfetcher.toml'
|
||||
branches: [main]
|
||||
pull_request:
|
||||
paths:
|
||||
- '_sources/**'
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
};
|
||||
};
|
||||
|
||||
outputs = { self, nixpkgs, ... }@inputs:
|
||||
outputs = { self, nixpkgs, home-manager }:
|
||||
let
|
||||
systems = [
|
||||
"x86_64-linux"
|
||||
|
@ -19,43 +19,28 @@
|
|||
"aarch64-darwin"
|
||||
];
|
||||
|
||||
inherit (nixpkgs) lib;
|
||||
|
||||
forAllSystems = fn: lib.genAttrs systems (s: fn nixpkgs.legacyPackages.${s});
|
||||
forAllSystems = fn: nixpkgs.lib.genAttrs systems (system: fn nixpkgs.legacyPackages.${system});
|
||||
in
|
||||
{
|
||||
checks = forAllSystems (pkgs: lib.optionalAttrs pkgs.stdenv.isLinux {
|
||||
module-vm-test = pkgs.nixosTest (import ../test.nix inputs);
|
||||
checks = forAllSystems ({ lib, pkgs, ... }: lib.optionalAttrs pkgs.stdenv.isLinux {
|
||||
module-vm-test = pkgs.callPackage ../test.nix { inherit home-manager; };
|
||||
});
|
||||
|
||||
formatter = forAllSystems (pkgs: pkgs.nixpkgs-fmt);
|
||||
|
||||
packages = forAllSystems (pkgs:
|
||||
let
|
||||
eval = module: lib.evalModules {
|
||||
modules = [
|
||||
module
|
||||
version = self.shortRev or self.dirtyShortRev or "unknown";
|
||||
mkOptionDoc = args: (pkgs.callPackage ./option-doc.nix { }) args // { inherit version; };
|
||||
in
|
||||
{
|
||||
_module.check = false;
|
||||
}
|
||||
];
|
||||
nixos-doc = mkOptionDoc {
|
||||
modules = [ ../modules/nixos ];
|
||||
};
|
||||
|
||||
mkDoc = name: module:
|
||||
let
|
||||
doc = pkgs.nixosOptionsDoc {
|
||||
options = lib.filterAttrs (n: _: n != "_module") (eval module).options;
|
||||
documentType = "none";
|
||||
revision = builtins.substring 0 8 self.rev or "dirty";
|
||||
home-manager-doc = mkOptionDoc {
|
||||
modules = [ ../modules/home-manager ];
|
||||
};
|
||||
in
|
||||
pkgs.runCommand "${name}-module-doc.md" { } ''
|
||||
cat ${doc.optionsCommonMark} > $out
|
||||
'';
|
||||
in
|
||||
{
|
||||
nixos-doc = mkDoc "nixos" ../modules/nixos;
|
||||
home-manager-doc = mkDoc "home-manager" ../modules/home-manager;
|
||||
|
||||
default = self.packages.${pkgs.system}.home-manager-doc;
|
||||
});
|
||||
|
|
19
dev/option-doc.nix
Normal file
19
dev/option-doc.nix
Normal file
|
@ -0,0 +1,19 @@
|
|||
{ lib
|
||||
, nixosOptionsDoc
|
||||
,
|
||||
}: { version
|
||||
, modules
|
||||
,
|
||||
}:
|
||||
let
|
||||
eval = lib.evalModules {
|
||||
modules = modules ++ [{ _module.check = false; }];
|
||||
};
|
||||
|
||||
doc = nixosOptionsDoc {
|
||||
options = lib.filterAttrs (n: _: n != "_module") eval.options;
|
||||
documentType = "none";
|
||||
revision = version;
|
||||
};
|
||||
in
|
||||
doc.optionsCommonMark
|
13
test.nix
13
test.nix
|
@ -1,21 +1,18 @@
|
|||
inputs:
|
||||
{ testers, home-manager }:
|
||||
let
|
||||
common = {
|
||||
catppuccin = {
|
||||
enable = true;
|
||||
flavour = "mocha";
|
||||
};
|
||||
catppuccin.enable = true;
|
||||
};
|
||||
|
||||
# shorthand enable
|
||||
# shorthand for enabling a module
|
||||
enable = { enable = true; };
|
||||
in
|
||||
{
|
||||
testers.runNixOSTest {
|
||||
name = "module-test";
|
||||
|
||||
nodes.machine = { lib, ... }: {
|
||||
imports = [
|
||||
inputs.home-manager.nixosModules.default
|
||||
home-manager.nixosModules.default
|
||||
./modules/nixos
|
||||
common
|
||||
];
|
||||
|
|
Loading…
Reference in a new issue