{ config, lib, pkgs, ... }: with lib; let cfg = config.programs.jq; colorType = mkOption { type = types.str; description = lib.mdDoc "ANSI color definition"; example = "1;31"; visible = false; }; colorsType = types.submodule { options = { null = colorType; false = colorType; true = colorType; numbers = colorType; strings = colorType; arrays = colorType; objects = colorType; }; }; in { options = { programs.jq = { enable = mkEnableOption (lib.mdDoc "the jq command-line JSON processor"); package = mkOption { type = types.package; default = pkgs.jq; defaultText = literalExpression "pkgs.jq"; description = lib.mdDoc "jq package to use."; }; colors = mkOption { description = lib.mdDoc '' The colors used in colored JSON output. See the [Colors section](https://jqlang.github.io/jq/manual/#Colors) of the jq manual. ''; example = literalExpression '' { null = "1;30"; false = "0;31"; true = "0;32"; numbers = "0;36"; strings = "0;33"; arrays = "1;35"; objects = "1;37"; } ''; default = { null = "1;30"; false = "0;37"; true = "0;37"; numbers = "0;37"; strings = "0;32"; arrays = "1;37"; objects = "1;37"; }; type = colorsType; }; }; }; config = mkIf cfg.enable { home.packages = [ cfg.package ]; home.sessionVariables = let c = cfg.colors; in { JQ_COLORS = "${c.null}:${c.false}:${c.true}:${c.numbers}:${c.strings}:${c.arrays}:${c.objects}"; }; }; }