2021-09-24 17:20:23 +00:00
|
|
|
{ config, pkgs, lib, ... }:
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.documentation.man.man-db;
|
|
|
|
in
|
|
|
|
|
|
|
|
{
|
|
|
|
options = {
|
|
|
|
documentation.man.man-db = {
|
2022-08-28 19:18:44 +00:00
|
|
|
enable = lib.mkEnableOption (lib.mdDoc "man-db as the default man page viewer") // {
|
2021-09-24 17:20:23 +00:00
|
|
|
default = config.documentation.man.enable;
|
|
|
|
defaultText = lib.literalExpression "config.documentation.man.enable";
|
|
|
|
example = false;
|
|
|
|
};
|
|
|
|
|
2023-01-09 20:36:28 +00:00
|
|
|
skipPackages = lib.mkOption {
|
|
|
|
type = lib.types.listOf lib.types.package;
|
|
|
|
default = [];
|
|
|
|
internal = true;
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
Packages to *not* include in the man-db.
|
|
|
|
This can be useful to avoid unnecessary rebuilds due to packages that change frequently, like nixos-version.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2021-09-24 17:20:23 +00:00
|
|
|
manualPages = lib.mkOption {
|
|
|
|
type = lib.types.path;
|
|
|
|
default = pkgs.buildEnv {
|
|
|
|
name = "man-paths";
|
2023-01-09 20:36:28 +00:00
|
|
|
paths = lib.subtractLists cfg.skipPackages config.environment.systemPackages;
|
2021-09-24 17:20:23 +00:00
|
|
|
pathsToLink = [ "/share/man" ];
|
|
|
|
extraOutputsToInstall = [ "man" ]
|
|
|
|
++ lib.optionals config.documentation.dev.enable [ "devman" ];
|
|
|
|
ignoreCollisions = true;
|
|
|
|
};
|
2022-06-03 19:47:57 +00:00
|
|
|
defaultText = lib.literalMD "all man pages in {option}`config.environment.systemPackages`";
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
The manual pages to generate caches for if {option}`documentation.man.generateCaches`
|
2021-09-24 17:20:23 +00:00
|
|
|
is enabled. Must be a path to a directory with man pages under
|
2022-06-03 19:47:57 +00:00
|
|
|
`/share/man`; see the source for an example.
|
2021-09-24 17:20:23 +00:00
|
|
|
Advanced users can make this a content-addressed derivation to save a few rebuilds.
|
|
|
|
'';
|
|
|
|
};
|
2021-10-02 13:26:54 +00:00
|
|
|
|
|
|
|
package = lib.mkOption {
|
|
|
|
type = lib.types.package;
|
|
|
|
default = pkgs.man-db;
|
|
|
|
defaultText = lib.literalExpression "pkgs.man-db";
|
2022-07-20 10:32:04 +00:00
|
|
|
description = lib.mdDoc ''
|
|
|
|
The `man-db` derivation to use. Useful to override
|
2021-10-02 13:26:54 +00:00
|
|
|
configuration options used for the package.
|
|
|
|
'';
|
|
|
|
};
|
2021-09-24 17:20:23 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
imports = [
|
|
|
|
(lib.mkRenamedOptionModule [ "documentation" "man" "manualPages" ] [ "documentation" "man" "man-db" "manualPages" ])
|
|
|
|
];
|
|
|
|
|
|
|
|
config = lib.mkIf cfg.enable {
|
2021-10-02 13:26:54 +00:00
|
|
|
environment.systemPackages = [ cfg.package ];
|
2021-09-24 17:20:23 +00:00
|
|
|
environment.etc."man_db.conf".text =
|
|
|
|
let
|
2022-12-18 13:19:36 +00:00
|
|
|
manualCache = pkgs.runCommand "man-cache" {
|
|
|
|
nativeBuildInputs = [ cfg.package ];
|
|
|
|
} ''
|
2021-09-24 17:20:23 +00:00
|
|
|
echo "MANDB_MAP ${cfg.manualPages}/share/man $out" > man.conf
|
2022-12-18 13:19:36 +00:00
|
|
|
mandb -C man.conf -psc >/dev/null 2>&1
|
2021-09-24 17:20:23 +00:00
|
|
|
'';
|
|
|
|
in
|
|
|
|
''
|
|
|
|
# Manual pages paths for NixOS
|
|
|
|
MANPATH_MAP /run/current-system/sw/bin /run/current-system/sw/share/man
|
|
|
|
MANPATH_MAP /run/wrappers/bin /run/current-system/sw/share/man
|
|
|
|
|
|
|
|
${lib.optionalString config.documentation.man.generateCaches ''
|
|
|
|
# Generated manual pages cache for NixOS (immutable)
|
|
|
|
MANDB_MAP /run/current-system/sw/share/man ${manualCache}
|
|
|
|
''}
|
|
|
|
# Manual pages caches for NixOS
|
|
|
|
MANDB_MAP /run/current-system/sw/share/man /var/cache/man/nixos
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
}
|