2023-06-02 15:59:12 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
2023-06-03 13:54:33 +00:00
|
|
|
let
|
|
|
|
cfg = config.programs.ripgrep;
|
|
|
|
configPath = "${config.xdg.configHome}/ripgrep/ripgreprc";
|
2023-06-02 15:59:12 +00:00
|
|
|
in {
|
|
|
|
meta.maintainers = [ hm.maintainers.pedorich-n ];
|
|
|
|
|
|
|
|
options = {
|
|
|
|
programs.ripgrep = {
|
|
|
|
enable = mkEnableOption "Ripgrep";
|
|
|
|
|
|
|
|
package = mkPackageOption pkgs "ripgrep" { };
|
|
|
|
|
|
|
|
arguments = mkOption {
|
|
|
|
type = with types; listOf str;
|
|
|
|
default = [ ];
|
|
|
|
example = [ "--max-columns-preview" "--colors=line:style:bold" ];
|
|
|
|
description = ''
|
2023-06-03 13:54:33 +00:00
|
|
|
List of arguments to pass to ripgrep. Each item is given to ripgrep as
|
|
|
|
a single command line argument verbatim.
|
|
|
|
</para><para>
|
2023-06-02 15:59:12 +00:00
|
|
|
See <link xlink:href="https://github.com/BurntSushi/ripgrep/blob/master/GUIDE.md#configuration-file"/>
|
|
|
|
for an example configuration.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
home = {
|
|
|
|
packages = [ cfg.package ];
|
|
|
|
|
2023-06-03 13:54:33 +00:00
|
|
|
file."${configPath}" =
|
2023-06-02 15:59:12 +00:00
|
|
|
mkIf (cfg.arguments != [ ]) { text = lib.concatLines cfg.arguments; };
|
|
|
|
|
2023-06-03 13:54:33 +00:00
|
|
|
sessionVariables = { "RIPGREP_CONFIG_PATH" = configPath; };
|
2023-06-02 15:59:12 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|