diff --git a/doc/manpage-urls.json b/doc/manpage-urls.json index e878caf042a45..ba18e98376f4f 100644 --- a/doc/manpage-urls.json +++ b/doc/manpage-urls.json @@ -322,5 +322,6 @@ "nix-shell(1)": "https://nixos.org/manual/nix/stable/command-ref/nix-shell.html", "mksquashfs(1)": "https://man.archlinux.org/man/extra/squashfs-tools/mksquashfs.1.en", "curl(1)": "https://curl.se/docs/manpage.html", - "netrc(5)": "https://man.cx/netrc" + "netrc(5)": "https://man.cx/netrc", + "cat(1)": "https://www.gnu.org/software/coreutils/manual/html_node/cat-invocation.html" } diff --git a/nixos/doc/manual/release-notes/rl-2505.section.md b/nixos/doc/manual/release-notes/rl-2505.section.md index 8f378acb3c3a1..3586d5788c79a 100644 --- a/nixos/doc/manual/release-notes/rl-2505.section.md +++ b/nixos/doc/manual/release-notes/rl-2505.section.md @@ -24,6 +24,8 @@ - [Amazon CloudWatch Agent](https://github.com/aws/amazon-cloudwatch-agent), the official telemetry collector for AWS CloudWatch and AWS X-Ray. Available as [services.amazon-cloudwatch-agent](options.html#opt-services.amazon-cloudwatch-agent.enable). +- [Bat](https://github.com/sharkdp/bat), a {manpage}`cat(1)` clone with wings. Available as [programs.bat](options.html#opt-programs.bat). + - [agorakit](https://github.com/agorakit/agorakit), an organization tool for citizens' collectives. Available with [services.agorakit](options.html#opt-services.agorakit.enable). - [mqtt-exporter](https://github.com/kpetremann/mqtt-exporter/), a Prometheus exporter for exposing messages from MQTT. Available as [services.prometheus.exporters.mqtt](#opt-services.prometheus.exporters.mqtt.enable). diff --git a/nixos/modules/module-list.nix b/nixos/modules/module-list.nix index b12da3f575fb3..31d370ef6ccfb 100644 --- a/nixos/modules/module-list.nix +++ b/nixos/modules/module-list.nix @@ -161,6 +161,7 @@ ./programs/bash/ls-colors.nix ./programs/bash/undistract-me.nix ./programs/bazecor.nix + ./programs/bat.nix ./programs/bcc.nix ./programs/benchexec.nix ./programs/browserpass.nix diff --git a/nixos/modules/programs/bat.nix b/nixos/modules/programs/bat.nix new file mode 100644 index 0000000000000..5ccc87baf2c46 --- /dev/null +++ b/nixos/modules/programs/bat.nix @@ -0,0 +1,122 @@ +{ + pkgs, + config, + lib, + ... +}: +let + inherit (builtins) isList elem; + inherit (lib) + getExe + literalExpression + maintainers + mapAttrs' + mkEnableOption + mkIf + mkOption + mkPackageOption + nameValuePair + optionalString + types + ; + inherit (types) listOf package; + + cfg = config.programs.bat; + + settingsFormat = pkgs.formats.keyValue { listsAsDuplicateKeys = true; }; + inherit (settingsFormat) generate type; + + initScript = + { + program, + shell, + flags ? [ ], + }: + if (shell != "fish") then + '' + eval "$(${getExe program} ${toString flags})" + '' + else + '' + ${getExe program} ${toString flags} | source + ''; + + shellInit = + shell: + optionalString (elem pkgs.bat-extras.batpipe cfg.extraPackages) (initScript { + program = pkgs.bat-extras.batpipe; + inherit shell; + }) + + optionalString (elem pkgs.bat-extras.batman cfg.extraPackages) (initScript { + program = pkgs.bat-extras.batman; + inherit shell; + flags = [ "--export-env" ]; + }); +in +{ + options.programs.bat = { + enable = mkEnableOption "`bat`, a {manpage}`cat(1)` clone with wings"; + + package = mkPackageOption pkgs "bat" { }; + + extraPackages = mkOption { + default = [ ]; + example = literalExpression '' + with pkgs.bat-extras; [ + batdiff + batman + prettybat + ]; + ''; + description = '' + Extra `bat` scripts to be added to the system configuration. + ''; + type = listOf package; + }; + + settings = mkOption { + default = { }; + example = { + theme = "TwoDark"; + italic-text = "always"; + paging = "never"; + pager = "less --RAW-CONTROL-CHARS --quit-if-one-screen --mouse"; + map-syntax = [ + "*.ino:C++" + ".ignore:Git Ignore" + ]; + }; + description = '' + Parameters to be written to the system-wide `bat` configuration file. + ''; + inherit type; + }; + }; + + config = mkIf cfg.enable { + environment = { + systemPackages = [ cfg.package ] ++ cfg.extraPackages; + etc."bat/config".source = generate "bat-config" ( + mapAttrs' ( + name: value: + nameValuePair ("--" + name) ( + if (isList value) then map (str: "\"${str}\"") value else "\"${value}\"" + ) + ) cfg.settings + ); + }; + + programs = { + bash = mkIf (!config.programs.fish.enable) { + interactiveShellInit = shellInit "bash"; + }; + fish = mkIf config.programs.fish.enable { + interactiveShellInit = shellInit "fish"; + }; + zsh = mkIf (!config.programs.fish.enable && config.programs.zsh.enable) { + interactiveShellInit = shellInit "zsh"; + }; + }; + }; + meta.maintainers = with maintainers; [ sigmasquadron ]; +}