2009-07-14 17:27:46 +01:00
|
|
|
# This module includes the NixOS man-pages in the system environment,
|
|
|
|
# and optionally starts a browser that shows the NixOS manual on one
|
|
|
|
# of the virtual consoles. The latter is useful for the installation
|
|
|
|
# CD.
|
2009-01-08 23:30:23 +00:00
|
|
|
|
2009-10-12 17:36:19 +01:00
|
|
|
{ config, pkgs, options, ... }:
|
2009-01-08 23:30:23 +00:00
|
|
|
|
2009-10-12 17:36:19 +01:00
|
|
|
with pkgs.lib;
|
2009-04-14 13:31:08 +01:00
|
|
|
|
2009-10-12 17:36:19 +01:00
|
|
|
let
|
2009-01-08 23:30:23 +00:00
|
|
|
|
2009-07-14 17:27:46 +01:00
|
|
|
cfg = config.services.nixosManual;
|
2009-01-08 23:30:23 +00:00
|
|
|
|
2009-09-18 16:27:10 +01:00
|
|
|
manual = import ../../../doc/manual {
|
|
|
|
inherit (cfg) revision;
|
|
|
|
inherit pkgs options;
|
|
|
|
};
|
2009-07-14 17:27:46 +01:00
|
|
|
|
|
|
|
in
|
2009-04-14 13:31:08 +01:00
|
|
|
|
2009-07-14 17:27:46 +01:00
|
|
|
{
|
2009-04-14 13:31:08 +01:00
|
|
|
|
2009-07-14 17:27:46 +01:00
|
|
|
options = {
|
2009-01-08 23:30:23 +00:00
|
|
|
|
2009-07-14 17:27:46 +01:00
|
|
|
services.nixosManual.enable = mkOption {
|
|
|
|
default = true;
|
|
|
|
description = ''
|
|
|
|
Whether to build the NixOS manual pages.
|
|
|
|
'';
|
|
|
|
};
|
2009-04-14 13:31:08 +01:00
|
|
|
|
2009-07-14 17:27:46 +01:00
|
|
|
services.nixosManual.showManual = mkOption {
|
|
|
|
default = false;
|
|
|
|
description = ''
|
|
|
|
Whether to show the NixOS manual on one of the virtual
|
|
|
|
consoles.
|
2009-01-08 23:30:23 +00:00
|
|
|
'';
|
2009-07-14 17:27:46 +01:00
|
|
|
};
|
2009-04-14 13:31:08 +01:00
|
|
|
|
2009-07-14 17:27:46 +01:00
|
|
|
services.nixosManual.ttyNumber = mkOption {
|
|
|
|
default = "8";
|
|
|
|
description = ''
|
|
|
|
Virtual console on which to show the manual.
|
|
|
|
'';
|
2009-01-08 23:30:23 +00:00
|
|
|
};
|
2009-04-14 13:31:08 +01:00
|
|
|
|
2009-07-14 17:27:46 +01:00
|
|
|
services.nixosManual.browser = mkOption {
|
|
|
|
default = "${pkgs.w3m}/bin/w3m";
|
|
|
|
description = ''
|
|
|
|
Browser used to show the manual.
|
|
|
|
'';
|
2009-01-08 23:30:23 +00:00
|
|
|
};
|
2009-04-14 13:31:08 +01:00
|
|
|
|
2009-09-18 16:27:10 +01:00
|
|
|
services.nixosManual.revision = mkOption {
|
|
|
|
default = "local";
|
|
|
|
type = types.uniq types.string;
|
|
|
|
description = ''
|
|
|
|
Revision of the targeted source file. This value can either be
|
2009-09-18 16:47:02 +01:00
|
|
|
<literal>"local"</literal>, <literal>"HEAD"</literal> or any
|
2009-09-18 16:27:10 +01:00
|
|
|
revision number embedded in a string.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2009-01-08 23:30:23 +00:00
|
|
|
};
|
2009-07-14 17:27:46 +01:00
|
|
|
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
|
2009-10-05 14:55:33 +01:00
|
|
|
system.build.manual = manual;
|
|
|
|
|
2009-07-14 17:27:46 +01:00
|
|
|
environment.systemPackages = [manual];
|
|
|
|
|
2009-10-15 15:35:10 +01:00
|
|
|
boot.extraTTYs = mkIf cfg.showManual ["tty${cfg.ttyNumber}"];
|
2009-07-14 17:27:46 +01:00
|
|
|
|
2009-10-12 19:09:34 +01:00
|
|
|
jobs = mkIf cfg.showManual
|
2009-10-12 17:36:19 +01:00
|
|
|
{ nixosManual =
|
|
|
|
{ name = "nixos-manual";
|
|
|
|
|
|
|
|
description = "NixOS manual";
|
2009-07-14 17:27:46 +01:00
|
|
|
|
2009-10-12 17:36:19 +01:00
|
|
|
startOn = "udev";
|
|
|
|
stopOn = "shutdown";
|
2009-07-14 17:27:46 +01:00
|
|
|
|
2009-10-12 17:36:19 +01:00
|
|
|
exec =
|
|
|
|
''
|
|
|
|
${cfg.browser} ${manual}/share/doc/nixos/manual.html \
|
|
|
|
< /dev/tty${toString cfg.ttyNumber} > /dev/tty${toString cfg.ttyNumber} 2>&1
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
2009-07-14 17:27:46 +01:00
|
|
|
|
|
|
|
services.ttyBackgrounds.specificThemes = mkIf cfg.showManual
|
2009-10-15 15:35:10 +01:00
|
|
|
[ { tty = "tty${cfg.ttyNumber}";
|
2009-07-14 17:27:46 +01:00
|
|
|
theme = pkgs.themes "green";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
|
|
|
services.mingetty.helpLine = mkIf cfg.showManual
|
|
|
|
"\nPress <Alt-F${toString cfg.ttyNumber}> for the NixOS manual.";
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2009-01-08 23:30:23 +00:00
|
|
|
}
|