difftastic: new module
Signed-off-by: Austin Horstman <khaneliman12@gmail.com>
This commit is contained in:
parent
16cd8abad6
commit
111329b475
5 changed files with 147 additions and 122 deletions
|
|
@ -90,7 +90,6 @@ let
|
|||
);
|
||||
}
|
||||
);
|
||||
|
||||
in
|
||||
{
|
||||
meta.maintainers = with lib.maintainers; [
|
||||
|
|
@ -292,41 +291,6 @@ in
|
|||
};
|
||||
};
|
||||
|
||||
difftastic = {
|
||||
enable = mkEnableOption "" // {
|
||||
description = ''
|
||||
Enable the {command}`difftastic` syntax highlighter.
|
||||
See <https://github.com/Wilfred/difftastic>.
|
||||
'';
|
||||
};
|
||||
|
||||
package = mkPackageOption pkgs "difftastic" { };
|
||||
|
||||
enableAsDifftool = mkEnableOption "" // {
|
||||
description = ''
|
||||
Enable the {command}`difftastic` syntax highlighter as a git difftool.
|
||||
See <https://github.com/Wilfred/difftastic>.
|
||||
'';
|
||||
};
|
||||
|
||||
options = mkOption {
|
||||
type =
|
||||
with lib.types;
|
||||
attrsOf (oneOf [
|
||||
str
|
||||
number
|
||||
bool
|
||||
]);
|
||||
default = { };
|
||||
example = {
|
||||
color = "dark";
|
||||
sort-path = true;
|
||||
tab-width = 8;
|
||||
};
|
||||
description = "Configuration options for {command}`difftastic`. See {command}`difft --help`";
|
||||
};
|
||||
};
|
||||
|
||||
riff = {
|
||||
enable = mkEnableOption "" // {
|
||||
description = ''
|
||||
|
|
@ -373,26 +337,6 @@ in
|
|||
"signer"
|
||||
]
|
||||
)
|
||||
]
|
||||
++ (
|
||||
let
|
||||
mkRenamed =
|
||||
opt:
|
||||
lib.mkRenamedOptionModule
|
||||
[ "programs" "git" "difftastic" opt ]
|
||||
[ "programs" "git" "difftastic" "options" opt ];
|
||||
in
|
||||
map mkRenamed [
|
||||
"background"
|
||||
"color"
|
||||
"context"
|
||||
"display"
|
||||
]
|
||||
)
|
||||
++ [
|
||||
(lib.mkRemovedOptionModule [ "programs" "git" "difftastic" "extraArgs" ] ''
|
||||
'programs.git.difftastic.extraArgs' has been replaced by 'programs.git.difftastic.options'
|
||||
'')
|
||||
];
|
||||
|
||||
config = mkIf cfg.enable (
|
||||
|
|
@ -408,7 +352,7 @@ in
|
|||
(config.programs.delta.enable && config.programs.delta.enableGitIntegration)
|
||||
(config.programs.diff-highlight.enable && config.programs.diff-highlight.enableGitIntegration)
|
||||
(config.programs.diff-so-fancy.enable && config.programs.diff-so-fancy.enableGitIntegration)
|
||||
cfg.difftastic.enable
|
||||
(config.programs.difftastic.enable && config.programs.difftastic.git.enable)
|
||||
cfg.riff.enable
|
||||
cfg.patdiff.enable
|
||||
];
|
||||
|
|
@ -688,35 +632,6 @@ in
|
|||
};
|
||||
})
|
||||
|
||||
(
|
||||
let
|
||||
difftCommand = "${lib.getExe cfg.difftastic.package} ${
|
||||
lib.cli.toGNUCommandLineShell { } cfg.difftastic.options
|
||||
}";
|
||||
in
|
||||
(lib.mkMerge [
|
||||
(mkIf cfg.difftastic.enable {
|
||||
home.packages = [ cfg.difftastic.package ];
|
||||
programs.git.iniContent = {
|
||||
diff.external = difftCommand;
|
||||
};
|
||||
})
|
||||
(mkIf cfg.difftastic.enableAsDifftool {
|
||||
home.packages = [ cfg.difftastic.package ];
|
||||
programs.git.iniContent = {
|
||||
diff = {
|
||||
tool = lib.mkDefault "difftastic";
|
||||
};
|
||||
difftool = {
|
||||
difftastic = {
|
||||
cmd = "${difftCommand} $LOCAL $REMOTE";
|
||||
};
|
||||
};
|
||||
};
|
||||
})
|
||||
])
|
||||
)
|
||||
|
||||
(
|
||||
let
|
||||
riffExe = baseNameOf (lib.getExe cfg.riff.package);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue