-
Notifications
You must be signed in to change notification settings - Fork 0
/
dot_gitconfig.tmpl
123 lines (103 loc) · 2.93 KB
/
dot_gitconfig.tmpl
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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
[user]
name = Rohit Bhanot
{{- if (and (eq .chezmoi.os "linux") (eq "mariner" .chezmoi.osRelease.id) (contains "rdev" (env "RDEV_ID")) (eq "coder" .chezmoi.username)) }}
email = [email protected]
{{- else }}
email = [email protected]
{{- end }}
[alias]
a = add
# Checkout shortcuts
co = checkout
cb = checkout -b
com = checkout master
# commit commands
cm = commit -a
cma = commit --amend
# branching
b = branch
bl = branch -l
ba = branch -a
# rebase
rb = rebase
rbm = rebase master
rbi = rebase -i
rbc = rebase --continue
rba = rebase --abort
# reset/revert
res= restore
rst = reset
# push/pull
ps = push
pl = pull
st = status
d = diff
df = diff --name-status
cp = cherry-pick
rc = review create
dc = review dcommit
ru = review update
fc = diff --name-only --diff-filter=U
# log/reflog
lg = log --pretty=format:'%C(auto)%h%d%Creset %s %C(cyan) [%aN] %Creset %C(green)(%ci)%Creset'
lga = log --pretty=format:'%C(auto)%h%d%Creset %s %C(cyan) [%aN] %Creset %C(green)(%ci)%Creset' --graph --all
rf = reflog
rfp = reflog --date=local
whatadded = log --diff-filter=A
find = "!f() { git ls-files |grep $1; }; f"
count-lines = "! git log --author=\"$1\" --pretty=tformat: --numstat | awk '{ add += $1; subs += $2; loc += $1 - $2 } END { printf \"added lines: %s, removed lines: %s, total lines: %s\\n\", add, subs, loc }' #"
[pull]
rebase = true
[core]
excludesfile = ~/.global_gitignore
editor = nvim
{{- if (and (eq .chezmoi.os "linux") (eq "mariner" .chezmoi.osRelease.id) (contains "rdev" (env "RDEV_ID")) (eq "coder" .chezmoi.username)) }}
{{- else }}
sshCommand = "ssh -i ~/.ssh/personal_gh_key"
{{- end }}
[pager]
diff = delta
log = delta
reflog = delta
show = delta
[interactive]
diffFilter = delta --color-only
[include]
path = ~/delta-themes
[delta]
; features = woolly-mammoth
plus-style = "syntax #012800"
minus-style = "syntax #340001"
syntax-theme = Monokai Extended
navigate = true # use n and N to move between diff sections
line-numbers = true
; side-by-side = true
; line-numbers-left-format = ""
; line-numbers-right-format = "│ "
# delta detects terminal colors automatically; set one of these to disable auto-detection
# dark = true
# light = true
[merge]
conflictstyle = diff3
[diff]
colorMoved = default
[merge]
tool = "nvim"
[mergetool]
keepBackup = false
prompt = false
[mergetool "nvim"]
cmd = "nvim -d -c \"wincmd l\" -c \"norm ]c\" \"$LOCAL\" \"$MERGED\" \"$REMOTE\""
[filter "lfs"]
clean = git-lfs clean -- %f
smudge = git-lfs smudge -- %f
process = git-lfs filter-process
required = true
[rerere]
enabled = true
[push]
autoSetupRemote = true
[sequence]
# work config
[includeIf "gitdir/i:~/development/work/"]
path= ~/.work-gitconfig