2021-09-18 10:52:07 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.programs.git;
|
|
|
|
in
|
|
|
|
|
|
|
|
{
|
|
|
|
options = {
|
|
|
|
programs.git = {
|
2022-09-09 14:08:57 +00:00
|
|
|
enable = mkEnableOption (lib.mdDoc "git");
|
2021-09-18 10:52:07 +00:00
|
|
|
|
2024-01-02 11:29:13 +00:00
|
|
|
package = mkPackageOption pkgs "git" {
|
|
|
|
example = "gitFull";
|
2021-09-18 10:52:07 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
config = mkOption {
|
2022-12-28 21:21:41 +00:00
|
|
|
type =
|
|
|
|
with types;
|
|
|
|
let
|
|
|
|
gitini = attrsOf (attrsOf anything);
|
|
|
|
in
|
|
|
|
either gitini (listOf gitini) // {
|
|
|
|
merge = loc: defs:
|
|
|
|
let
|
|
|
|
config = foldl'
|
|
|
|
(acc: { value, ... }@x: acc // (if isList value then {
|
|
|
|
ordered = acc.ordered ++ value;
|
|
|
|
} else {
|
|
|
|
unordered = acc.unordered ++ [ x ];
|
|
|
|
}))
|
|
|
|
{
|
|
|
|
ordered = [ ];
|
|
|
|
unordered = [ ];
|
|
|
|
}
|
|
|
|
defs;
|
|
|
|
in
|
|
|
|
[ (gitini.merge loc config.unordered) ] ++ config.ordered;
|
|
|
|
};
|
|
|
|
default = [ ];
|
2021-09-18 10:52:07 +00:00
|
|
|
example = {
|
|
|
|
init.defaultBranch = "main";
|
|
|
|
url."https://github.com/".insteadOf = [ "gh:" "github:" ];
|
|
|
|
};
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2022-12-28 21:21:41 +00:00
|
|
|
Configuration to write to /etc/gitconfig. A list can also be
|
|
|
|
specified to keep the configuration in order. For example, setting
|
|
|
|
`config` to `[ { foo.x = 42; } { bar.y = 42; }]` will put the `foo`
|
|
|
|
section before the `bar` section unlike the default alphabetical
|
|
|
|
order, which can be helpful for sections such as `include` and
|
|
|
|
`includeIf`. See the CONFIGURATION FILE section of git-config(1) for
|
|
|
|
more information.
|
2021-09-18 10:52:07 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-01-02 11:29:13 +00:00
|
|
|
prompt = {
|
|
|
|
enable = mkEnableOption "automatically sourcing git-prompt.sh. This does not change $PS1; it simply provides relevant utility functions";
|
|
|
|
};
|
|
|
|
|
2021-10-11 16:52:03 +00:00
|
|
|
lfs = {
|
2022-09-09 14:08:57 +00:00
|
|
|
enable = mkEnableOption (lib.mdDoc "git-lfs");
|
2021-10-11 16:52:03 +00:00
|
|
|
|
2024-01-02 11:29:13 +00:00
|
|
|
package = mkPackageOption pkgs "git-lfs" { };
|
2021-10-11 16:52:03 +00:00
|
|
|
};
|
2021-09-18 10:52:07 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2021-10-11 16:52:03 +00:00
|
|
|
config = mkMerge [
|
|
|
|
(mkIf cfg.enable {
|
|
|
|
environment.systemPackages = [ cfg.package ];
|
2022-12-28 21:21:41 +00:00
|
|
|
environment.etc.gitconfig = mkIf (cfg.config != [ ]) {
|
|
|
|
text = concatMapStringsSep "\n" generators.toGitINI cfg.config;
|
2021-10-11 16:52:03 +00:00
|
|
|
};
|
|
|
|
})
|
|
|
|
(mkIf (cfg.enable && cfg.lfs.enable) {
|
|
|
|
environment.systemPackages = [ cfg.lfs.package ];
|
|
|
|
programs.git.config = {
|
|
|
|
filter.lfs = {
|
|
|
|
clean = "git-lfs clean -- %f";
|
|
|
|
smudge = "git-lfs smudge -- %f";
|
|
|
|
process = "git-lfs filter-process";
|
|
|
|
required = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
})
|
2024-01-02 11:29:13 +00:00
|
|
|
(mkIf (cfg.enable && cfg.prompt.enable) {
|
|
|
|
environment.interactiveShellInit = ''
|
|
|
|
source ${cfg.package}/share/bash-completion/completions/git-prompt.sh
|
|
|
|
'';
|
|
|
|
})
|
2021-10-11 16:52:03 +00:00
|
|
|
];
|
|
|
|
|
2021-09-18 10:52:07 +00:00
|
|
|
meta.maintainers = with maintainers; [ figsoda ];
|
|
|
|
}
|