git: change extraConfig from lines to attrs

This commit is contained in:
Nikita Uvarov 2017-09-21 14:45:20 +02:00
parent 82c5aa82d2
commit ee5f07bbea
No known key found for this signature in database
GPG key ID: F7A5FB3A7C10EF96
2 changed files with 63 additions and 18 deletions

View file

@ -192,6 +192,34 @@ in
A new service is available: 'services.screen-locker'. A new service is available: 'services.screen-locker'.
''; '';
} }
{
time = "2017-09-22T12:09:01+00:00";
condition = isString config.programs.git.extraConfig;
message = ''
The 'programs.git.extraConfig' parameter is now
accepting attributes instead of strings which allows more
flexible configuration.
The string parameter type will be deprecated in the future,
please change your configuration file accordingly.
For example, if your configuration includes
programs.git.extraConfig = '''
[core]
editor = vim
''';
then you can now change it to
programs.git.extraConfig = {
core = {
editor = "vim";
};
};
'';
}
]; ];
}; };
} }

View file

@ -65,34 +65,51 @@ in
}; };
extraConfig = mkOption { extraConfig = mkOption {
type = types.lines; type = types.either types.attrs types.lines;
default = ""; default = {};
description = "Additional configuration to add."; description = "Additional configuration to add.";
}; };
iniContent = mkOption {
type = types.attrsOf types.attrs;
internal = true;
};
}; };
}; };
config = mkIf cfg.enable ( config = mkIf cfg.enable (
let mkMerge [
ini = {
user = {
name = cfg.userName;
email = cfg.userEmail;
} // optionalAttrs (cfg.signing != null) {
signingKey = cfg.signing.key;
};
} // optionalAttrs (cfg.signing != null) {
commit.gpgSign = cfg.signing.signByDefault;
gpg.program = cfg.signing.gpgPath;
} // optionalAttrs (cfg.aliases != {}) {
alias = cfg.aliases;
};
in
{ {
home.packages = [ cfg.package ]; home.packages = [ cfg.package ];
programs.git.iniContent.user = {
name = cfg.userName;
email = cfg.userEmail;
};
home.file.".gitconfig".text = home.file.".gitconfig".text =
generators.toINI {} ini + "\n" + cfg.extraConfig; generators.toINI {} cfg.iniContent;
} }
(mkIf (cfg.signing != null) {
programs.git.iniContent = {
user.signingKey = cfg.signing.key;
commit.gpgSign = cfg.signing.signByDefault;
gpg.program = cfg.signing.gpgPath;
};
})
(mkIf (cfg.aliases != {}) {
programs.git.iniContent.alias = cfg.aliases;
})
(mkIf (lib.isAttrs cfg.extraConfig) {
programs.git.iniContent = cfg.extraConfig;
})
(mkIf (lib.isString cfg.extraConfig) {
home.file.".gitconfig".text = cfg.extraConfig;
})
]
); );
} }