dotfiles/.config/git/config.aliases
punkfairie 5af5389117
feat(git): Move git aliases to git
Also fixed the wrongly named .gitconfig -> config, and standardized
naming among all subfiles.

All git aliases are managed by git now - to allow wrappers to access the
same aliases (e.g. dotfiles).
2024-02-27 20:54:41 -08:00

137 lines
4.3 KiB
Text

# vim:set ft=gitconfig :
[alias]
# Staging - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
a = add
aa = add --all
# Interactively stage parts of a file.
apa = add --patch
da = diff
das = diff --staged
daw = diff --word-diff # show diff by word
dasw = diff --staged --word-diff
d = "!f() { git diff "$@" ":(exclude)package-lock.json" ":(exclude)*.lock"; }; f"
ds = "!f() { git diff --staged "$@" ":(exclude)package-lock.json" ":(exclude)*.lock"; }; f"
dw = "!f() { git diff --word-diff "$@" ":(exclude)package-lock.json" ":(exclude)*.lock"; }; f"
dsw = "!f() { git diff --staged --word-diff "$@" ":(exclude)package-lock.json" ":(exclude)*.lock"; }; f"
st = status --short --branch
stu = status --short --branch -u
stl = status
# Committing - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
c = commit
ce = commit --amend
cen = commit --amend --no-edit
ca = "!git add --all && git commit"
cae = "!git add --all && git commit --amend"
caen = "!git add --all && git commit --amend --no-edit"
cfu = commit --fixup
rev = revert
# Working Dir & Index Manipulation - - - - - - - - - - - - - - - - - - - - - -
co = checkout
rt = reset
# rt <commit> -- [<path>] - undo <commit> but keep changes in working dir.
rts = reset --soft # undo commits and stage their changes
rs = restore --worktree # revert local changes
rst = restore --staged # unstage things
rsa = restore --worktree --staged
rss = restore --worktree --source # specify a commit to revert to
rsts = restore --staged --source
rsas = restore --worktree --staged --source
rmc = rm --cached # leave worktree copy alone
sta = stash push
stam = stash push --message
staa = stash push --include-untracked
staam = stash push --include-untracked --message
stap = stash pop
stal = stash list
stas = stash show --text
cl = clean -f # remove untracked & unignored files
cldr = clean --dry-run
# Branches - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
b = branch
cb = checkout -b
cm = "!git checkout $(git_main_branch)"
cd = "!git checkout $(git_develop_branch)"
m = merge
mtl = mergetool --no-prompt
ma = merge --abort
# History Manipulation - - - - - - - - - - - - - - - - - - - - - - - - - - - -
p = push
pv = push -v
pdr = push --dry-run
pf = push --force-with-lease --force-if-includes
pfv = push -v --force-with-lease --force-if-includes
pff = push --force
pffv = push -v --force
f = fetch
fa = fetch --all --prune
pl = pull
plr = pull --rebase
# Logs - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
# Current branch.
l = log --pretty=lc --graph
lo = log --pretty=lo --graph --date=human
ls = log --pretty=lo --graph --date=human --simplify-by-decoration
lf = log --pretty=lf --graph
ld = log --pretty=lf --graph --cc --stat
lp = log --pretty=lf --graph --cc --patch
# All branches on all remotes.
la = log --pretty=lc --graph --all
lao = log --pretty=lo --graph --all --date=human
las = log --pretty=lo --graph --all --date=human --simplify-by-decoration
laf = log --pretty=lf --graph --all
lad = log --pretty=lf --graph --all --cc --stat
lap = log --pretty=lf --graph --all --cc --patch
# Shortcuts - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
nevermind = "!git reset --hard HEAD && git clean -df"
# Notes - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
# A note on reset, restore, and revert, paraphrased from `man git`, plus myown
# own on `rm`:
#
# revert - make a new commit that reverts a previous commit.
# restore - undo uncommitted changes in the working tree.
# reset - update the branch and change commit history.
# rm - same as system rm; remove files, either from git's knowledge, the
# working directory, or both.
#
# These are not a description of the *possible* uses, rather a narrowing of
# the *intended* uses.
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
# PATH VALUES:
# :/ - all files within the root of the working tree, so all files in the
# repo, a la git add's --all option.