138 lines
4.3 KiB
Text
138 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.
|