forked from pub-solar/os
eab0bf074c
Also format all files and add a flake.lock for lib for a folder thats meant to work on other flakes theres never a reason it should need to refer to itself, only other flakes. So "self" and "inputs" are better namings for these variables. The userFlake* is redundant and confusing, when trying to call the functions its hard to figure out how to use them when there are now two lines of arguments to figure out.
34 lines
728 B
Nix
34 lines
728 B
Nix
{ pkgs, lib, ... }:
|
|
let
|
|
singleDoc = name: value: ''
|
|
## ${name}
|
|
${value.description}
|
|
${lib.optionalString (value ? type) ''
|
|
*_Type_*:
|
|
${value.type}
|
|
''}
|
|
${lib.optionalString (value ? default) ''
|
|
*_Default_*
|
|
```
|
|
${builtins.toJSON value.default}
|
|
```
|
|
''}
|
|
${lib.optionalString (value ? example) ''
|
|
*_Example_*
|
|
```
|
|
${value.example}
|
|
```
|
|
''}
|
|
'';
|
|
|
|
options = (
|
|
lib.mkFlake.evalArgs { nixos = "nixos"; args = { }; }
|
|
).options;
|
|
|
|
processedOptions = (pkgs.nixosOptionsDoc { inherit options; }).optionsNix;
|
|
|
|
fullDoc = lib.concatStringsSep "" (lib.mapAttrsToList singleDoc processedOptions);
|
|
in
|
|
pkgs.writeText "devosOptions.md" fullDoc
|
|
|