2013-11-15 23:09:15 +08:00
|
|
|
# set your user tokens as environment variables, such as ~/.secrets
|
2012-01-25 11:43:08 +08:00
|
|
|
# See the README for examples.
|
|
|
|
[color]
|
|
|
|
ui = true
|
|
|
|
[color "branch"]
|
|
|
|
current = yellow reverse
|
|
|
|
local = yellow
|
|
|
|
remote = green
|
|
|
|
[color "diff"]
|
|
|
|
meta = yellow bold
|
|
|
|
frag = magenta bold
|
2013-11-04 11:17:04 +08:00
|
|
|
old = red
|
|
|
|
new = green
|
2012-01-25 11:43:08 +08:00
|
|
|
[alias]
|
|
|
|
# add
|
|
|
|
a = add # add
|
|
|
|
chunkyadd = add --patch # stage commits chunk by chunk
|
|
|
|
|
2013-09-18 11:38:51 +08:00
|
|
|
# via http://blog.apiaxle.com/post/handy-git-tips-to-stop-you-getting-fired/
|
|
|
|
snapshot = !git stash save "snapshot: $(date)" && git stash apply "stash@{0}"
|
|
|
|
snapshots = !git stash list --grep snapshot
|
|
|
|
|
2013-10-10 02:56:30 +08:00
|
|
|
#via http://stackoverflow.com/questions/5188320/how-can-i-get-a-list-of-git-branches-ordered-by-most-recent-commit
|
2014-09-19 02:05:10 +08:00
|
|
|
recent-branches = !git for-each-ref --count=15 --sort=-committerdate refs/heads/ --format='%(refname:short)'
|
2013-10-10 02:56:30 +08:00
|
|
|
|
2012-01-25 11:43:08 +08:00
|
|
|
# branch
|
|
|
|
b = branch -v # branch (verbose)
|
|
|
|
|
|
|
|
# commit
|
|
|
|
c = commit -m # commit with message
|
|
|
|
ca = commit -am # commit all with message
|
|
|
|
ci = commit # commit
|
|
|
|
amend = commit --amend # ammend your last commit
|
|
|
|
ammend = commit --amend # ammend your last commit
|
|
|
|
|
|
|
|
# checkout
|
|
|
|
co = checkout # checkout
|
|
|
|
nb = checkout -b # create and switch to a new branch (mnemonic: "git new branch branchname...")
|
|
|
|
|
|
|
|
# cherry-pick
|
|
|
|
cp = cherry-pick -x # grab a change from a branch
|
|
|
|
|
|
|
|
# diff
|
|
|
|
d = diff # diff unstaged changes
|
|
|
|
dc = diff --cached # diff staged changes
|
|
|
|
last = diff HEAD^ # diff last committed change
|
|
|
|
|
|
|
|
# log
|
2012-03-08 15:14:43 +08:00
|
|
|
l = log --graph --date=short
|
2012-01-25 11:43:08 +08:00
|
|
|
changes = log --pretty=format:\"%h %cr %cn %Cgreen%s%Creset\" --name-status
|
|
|
|
short = log --pretty=format:\"%h %cr %cn %Cgreen%s%Creset\"
|
2014-02-16 11:09:33 +08:00
|
|
|
simple = log --pretty=format:\" * %s\"
|
2012-01-25 11:43:08 +08:00
|
|
|
shortnocolor = log --pretty=format:\"%h %cr %cn %s\"
|
|
|
|
|
|
|
|
# pull
|
|
|
|
pl = pull # pull
|
|
|
|
|
|
|
|
# push
|
|
|
|
ps = push # push
|
|
|
|
|
|
|
|
# rebase
|
|
|
|
rc = rebase --continue # continue rebase
|
|
|
|
rs = rebase --skip # skip rebase
|
|
|
|
|
|
|
|
# remote
|
|
|
|
r = remote -v # show remotes (verbose)
|
|
|
|
|
|
|
|
# reset
|
|
|
|
unstage = reset HEAD # remove files from index (tracking)
|
|
|
|
uncommit = reset --soft HEAD^ # go back before last commit, with files in uncommitted state
|
|
|
|
filelog = log -u # show changes to a file
|
|
|
|
mt = mergetool # fire up the merge tool
|
|
|
|
|
|
|
|
# stash
|
|
|
|
ss = stash # stash changes
|
|
|
|
sl = stash list # list stashes
|
|
|
|
sa = stash apply # apply stash (restore changes)
|
|
|
|
sd = stash drop # drop stashes (destory changes)
|
|
|
|
|
|
|
|
# status
|
|
|
|
s = status # status
|
|
|
|
st = status # status
|
|
|
|
stat = status # status
|
|
|
|
|
|
|
|
# tag
|
|
|
|
t = tag -n # show tags with <n> lines of each tag message
|
|
|
|
|
|
|
|
# svn helpers
|
|
|
|
svnr = svn rebase
|
|
|
|
svnd = svn dcommit
|
|
|
|
svnl = svn log --oneline --show-commit
|
2017-03-08 17:23:32 +08:00
|
|
|
df = diff HEAD^ HEAD
|
|
|
|
caa = commit -a --amend
|
2012-01-25 11:43:08 +08:00
|
|
|
[format]
|
|
|
|
pretty = format:%C(blue)%ad%Creset %C(yellow)%h%C(green)%d%Creset %C(blue)%s %C(magenta) [%an]%Creset
|
2013-01-07 01:02:02 +08:00
|
|
|
[mergetool]
|
|
|
|
prompt = false
|
|
|
|
[mergetool "mvimdiff"]
|
|
|
|
cmd="mvim -c 'Gdiff' $MERGED" # use fugitive.vim for 3-way merge
|
|
|
|
keepbackup=false
|
2012-01-25 11:43:08 +08:00
|
|
|
[merge]
|
|
|
|
summary = true
|
|
|
|
verbosity = 1
|
2013-01-07 01:02:02 +08:00
|
|
|
tool = mvimdiff
|
2012-01-25 11:43:08 +08:00
|
|
|
[apply]
|
|
|
|
whitespace = nowarn
|
|
|
|
[branch]
|
|
|
|
autosetupmerge = true
|
|
|
|
[push]
|
|
|
|
# 'git push' will push the current branch to its tracking branch
|
|
|
|
# the usual default is to push all branches
|
2014-07-17 17:14:54 +08:00
|
|
|
default = upstream
|
2012-01-25 11:43:08 +08:00
|
|
|
[core]
|
|
|
|
autocrlf = false
|
|
|
|
editor = vim
|
2012-04-07 01:46:45 +08:00
|
|
|
excludesfile = ~/.yadr/git/gitignore
|
2012-01-25 11:43:08 +08:00
|
|
|
[advice]
|
|
|
|
statusHints = false
|
|
|
|
[diff]
|
|
|
|
# Git diff will use (i)ndex, (w)ork tree, (c)ommit and (o)bject
|
|
|
|
# instead of a/b/c/d as prefixes for patches
|
|
|
|
mnemonicprefix = true
|
2013-09-18 11:38:51 +08:00
|
|
|
algorithm = patience
|
2012-01-25 11:43:08 +08:00
|
|
|
[rerere]
|
|
|
|
# Remember my merges
|
|
|
|
# http://gitfu.wordpress.com/2008/04/20/git-rerere-rereremember-what-you-did-last-time/
|
|
|
|
enabled = true
|
2013-03-24 00:28:32 +08:00
|
|
|
[include]
|
|
|
|
path = .gitconfig.user
|