
Format all Nix files using the officially approved formatter,
making the CI check introduced in the previous commit succeed:
nix-build ci -A fmt.check
This is the next step of the of the [implementation](https://github.com/NixOS/nixfmt/issues/153)
of the accepted [RFC 166](https://github.com/NixOS/rfcs/pull/166).
This commit will lead to merge conflicts for a number of PRs,
up to an estimated ~1100 (~33%) among the PRs with activity in the past 2
months, but that should be lower than what it would be without the previous
[partial treewide format](https://github.com/NixOS/nixpkgs/pull/322537).
Merge conflicts caused by this commit can now automatically be resolved while rebasing using the
[auto-rebase script](8616af08d9/maintainers/scripts/auto-rebase
).
If you run into any problems regarding any of this, please reach out to the
[formatting team](https://nixos.org/community/teams/formatting/) by
pinging @NixOS/nix-formatting.
120 lines
3.5 KiB
Nix
120 lines
3.5 KiB
Nix
{
|
|
config,
|
|
lib,
|
|
pkgs,
|
|
...
|
|
}:
|
|
|
|
let
|
|
cfg = config.programs.git;
|
|
in
|
|
|
|
{
|
|
options = {
|
|
programs.git = {
|
|
enable = lib.mkEnableOption "git, a distributed version control system";
|
|
|
|
package = lib.mkPackageOption pkgs "git" {
|
|
example = "gitFull";
|
|
};
|
|
|
|
config = lib.mkOption {
|
|
type =
|
|
with lib.types;
|
|
let
|
|
gitini = attrsOf (attrsOf anything);
|
|
in
|
|
either gitini (listOf gitini)
|
|
// {
|
|
merge =
|
|
loc: defs:
|
|
let
|
|
config =
|
|
builtins.foldl'
|
|
(
|
|
acc:
|
|
{ value, ... }@x:
|
|
acc
|
|
// (
|
|
if builtins.isList value then
|
|
{
|
|
ordered = acc.ordered ++ value;
|
|
}
|
|
else
|
|
{
|
|
unordered = acc.unordered ++ [ x ];
|
|
}
|
|
)
|
|
)
|
|
{
|
|
ordered = [ ];
|
|
unordered = [ ];
|
|
}
|
|
defs;
|
|
in
|
|
[ (gitini.merge loc config.unordered) ] ++ config.ordered;
|
|
};
|
|
default = [ ];
|
|
example = {
|
|
init.defaultBranch = "main";
|
|
url."https://github.com/".insteadOf = [
|
|
"gh:"
|
|
"github:"
|
|
];
|
|
};
|
|
description = ''
|
|
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 {manpage}`git-config(1)` for
|
|
more information.
|
|
'';
|
|
};
|
|
|
|
prompt = {
|
|
enable = lib.mkEnableOption "automatically sourcing git-prompt.sh. This does not change $PS1; it simply provides relevant utility functions";
|
|
};
|
|
|
|
lfs = {
|
|
enable = lib.mkEnableOption "git-lfs (Large File Storage)";
|
|
|
|
package = lib.mkPackageOption pkgs "git-lfs" { };
|
|
|
|
enablePureSSHTransfer = lib.mkEnableOption "Enable pure SSH transfer in server side by adding git-lfs-transfer to environment.systemPackages";
|
|
};
|
|
};
|
|
};
|
|
|
|
config = lib.mkMerge [
|
|
(lib.mkIf cfg.enable {
|
|
environment.systemPackages = [ cfg.package ];
|
|
environment.etc.gitconfig = lib.mkIf (cfg.config != [ ]) {
|
|
text = lib.concatMapStringsSep "\n" lib.generators.toGitINI cfg.config;
|
|
};
|
|
})
|
|
(lib.mkIf (cfg.enable && cfg.lfs.enable) {
|
|
environment.systemPackages = lib.mkMerge [
|
|
[ cfg.lfs.package ]
|
|
(lib.mkIf cfg.lfs.enablePureSSHTransfer [ pkgs.git-lfs-transfer ])
|
|
];
|
|
programs.git.config = {
|
|
filter.lfs = {
|
|
clean = "git-lfs clean -- %f";
|
|
smudge = "git-lfs smudge -- %f";
|
|
process = "git-lfs filter-process";
|
|
required = true;
|
|
};
|
|
};
|
|
})
|
|
(lib.mkIf (cfg.enable && cfg.prompt.enable) {
|
|
environment.interactiveShellInit = ''
|
|
source ${cfg.package}/share/bash-completion/completions/git-prompt.sh
|
|
'';
|
|
})
|
|
];
|
|
|
|
meta.maintainers = with lib.maintainers; [ figsoda ];
|
|
}
|