python3Packages.orjson: Disable failing tests on 32 bit
[NixPkgs.git] / nixos / modules / programs / less.nix
bloba1134e774364ac7d338106f7104d8022bf5c143f
1 { config, lib, pkgs, ... }:
3 with lib;
5 let
7   cfg = config.programs.less;
9   configText = if (cfg.configFile != null) then (builtins.readFile cfg.configFile) else ''
10     #command
11     ${concatStringsSep "\n"
12       (mapAttrsToList (command: action: "${command} ${action}") cfg.commands)
13     }
14     ${if cfg.clearDefaultCommands then "#stop" else ""}
16     #line-edit
17     ${concatStringsSep "\n"
18       (mapAttrsToList (command: action: "${command} ${action}") cfg.lineEditingKeys)
19     }
21     #env
22     ${concatStringsSep "\n"
23       (mapAttrsToList (variable: values: "${variable}=${values}") cfg.envVariables)
24     }
25   '';
27   lessKey = pkgs.writeText "lessconfig" configText;
32   options = {
34     programs.less = {
36       # note that environment.nix sets PAGER=less, and
37       # therefore also enables this module
38       enable = mkEnableOption (lib.mdDoc "less");
40       configFile = mkOption {
41         type = types.nullOr types.path;
42         default = null;
43         example = literalExpression ''"''${pkgs.my-configs}/lesskey"'';
44         description = lib.mdDoc ''
45           Path to lesskey configuration file.
47           {option}`configFile` takes precedence over {option}`commands`,
48           {option}`clearDefaultCommands`, {option}`lineEditingKeys`, and
49           {option}`envVariables`.
50         '';
51       };
53       commands = mkOption {
54         type = types.attrsOf types.str;
55         default = {};
56         example = {
57           h = "noaction 5\\e(";
58           l = "noaction 5\\e)";
59         };
60         description = lib.mdDoc "Defines new command keys.";
61       };
63       clearDefaultCommands = mkOption {
64         type = types.bool;
65         default = false;
66         description = lib.mdDoc ''
67           Clear all default commands.
68           You should remember to set the quit key.
69           Otherwise you will not be able to leave less without killing it.
70         '';
71       };
73       lineEditingKeys = mkOption {
74         type = types.attrsOf types.str;
75         default = {};
76         example = {
77           e = "abort";
78         };
79         description = lib.mdDoc "Defines new line-editing keys.";
80       };
82       envVariables = mkOption {
83         type = types.attrsOf types.str;
84         default = {
85           LESS = "-R";
86         };
87         example = {
88           LESS = "--quit-if-one-screen";
89         };
90         description = lib.mdDoc "Defines environment variables.";
91       };
93       lessopen = mkOption {
94         type = types.nullOr types.str;
95         default = "|${pkgs.lesspipe}/bin/lesspipe.sh %s";
96         defaultText = literalExpression ''"|''${pkgs.lesspipe}/bin/lesspipe.sh %s"'';
97         description = lib.mdDoc ''
98           Before less opens a file, it first gives your input preprocessor a chance to modify the way the contents of the file are displayed.
99         '';
100       };
102       lessclose = mkOption {
103         type = types.nullOr types.str;
104         default = null;
105         description = lib.mdDoc ''
106           When less closes a file opened in such a way, it will call another program, called the input postprocessor,
107           which may perform any desired clean-up action (such as deleting the replacement file created by LESSOPEN).
108         '';
109       };
110     };
111   };
113   config = mkIf cfg.enable {
115     environment.systemPackages = [ pkgs.less ];
117     environment.variables = {
118       LESSKEYIN_SYSTEM = toString lessKey;
119     } // optionalAttrs (cfg.lessopen != null) {
120       LESSOPEN = cfg.lessopen;
121     } // optionalAttrs (cfg.lessclose != null) {
122       LESSCLOSE = cfg.lessclose;
123     };
125     warnings = optional (
126       cfg.clearDefaultCommands && (all (x: x != "quit") (attrValues cfg.commands))
127     ) ''
128       config.programs.less.clearDefaultCommands clears all default commands of less but there is no alternative binding for exiting.
129       Consider adding a binding for 'quit'.
130     '';
131   };
133   meta.maintainers = with maintainers; [ johnazoidberg ];