blob: 9cb07dfbc4e6e799b0664c99c6665798a58e02c5 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
_inputs:
{ config, pkgs, ... }:
{
environment = {
systemPackages = with pkgs; [
unstable.git-branchless
unstable.gitoxide
watchman
];
shellAliases.git = "git-branchless wrap --";
};
programs.zsh.interactiveShellInit = ''
source ${../../dotfiles/git-branchless.zsh}
'';
home-manager.sharedModules = [
{
programs.git = {
enable = true;
package = pkgs.gitAndTools.gitFull;
userEmail = "minijackson@riseup.net";
userName = "Minijackson";
attributes = [
"*.cc diff=cpp"
"*.cpp diff=cpp"
"*.css diff=css"
"*.ex diff=elixir"
"*.exs diff=elixir"
"*.go diff=golang"
"*.html diff=html"
"*.java diff=java"
"*.md diff=markdown"
"*.php diff=php"
"*.pl diff=perl"
"*.py diff=python"
"*.rs diff=rust"
"*.tex diff=latex"
];
iniContent =
let
deltaCommand = "${pkgs.gitAndTools.delta}/bin/delta";
in
{
init.defaultBranch = "master";
core = {
whitespace = "trailing-space,space-before-tab";
pager = deltaCommand;
interactive.diffFilter = "${deltaCommand} --color-only";
untrackedCache = true;
};
diff = {
algorithm = "histogram";
colormoved = "default";
colorMovedWS = "allow-indentation-change";
};
pull.ff = "only";
rerere.enable = true;
merge = {
conflictStyle = "zdiff3";
tool = "nvimdiff";
};
"mergetool \"nvimdiff\"" = {
cmd = "nvim -d \"$LOCAL\" \"$MERGED\" \"$REMOTE\"";
};
delta = with config.theme.colors; {
line-numbers = true;
navigate = true;
whitespace-error-style = "reverse green";
minus-style = "normal red";
minus-non-emph-style = "normal red";
minus-emph-style = "normal brightred";
minus-empty-line-marker-style = "normal red";
plus-style = "reverse green";
plus-non-emph-style = "reverse green";
plus-emph-style = "reverse brightgreen";
plus-empty-line-marker-style = "reverse green";
line-numbers-minus-style = "brightred";
line-numbers-zero-style = "brightblack";
line-numbers-plus-style = "brightgreen";
file-style = "bright${dominantName}";
line-numbers-left-style = dominantName;
line-numbers-right-style = dominantName;
};
};
};
}
];
# TODO: move common to NixOS' programs.git.config
home-manager.users.minijackson.programs.git.signing = {
signByDefault = true;
key = "minijackson@riseup.net";
};
}
|