Created
December 9, 2017 02:10
-
-
Save ChaosLeung/92e6dce64b111541db970bbcf64e1dfa to your computer and use it in GitHub Desktop.
For linux
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/bin/sh | |
# | |
# Functions | |
# | |
# The name of the current branch | |
# Back-compatibility wrapper for when this function was defined here in | |
# the plugin, before being pulled in to core lib/git.zsh as git_current_branch() | |
# to fix the core -> git plugin dependency. | |
function git_current_branch() { | |
local ref | |
ref=$(command git symbolic-ref --quiet HEAD 2> /dev/null) | |
local ret=$? | |
if [[ $ret != 0 ]]; then | |
[[ $ret == 128 ]] && return # no git repo. | |
ref=$(command git rev-parse --short HEAD 2> /dev/null) || return | |
fi | |
echo ${ref#refs/heads/} | |
} | |
function current_branch() { | |
git_current_branch | |
} | |
# The list of remotes | |
function current_repository() { | |
if ! git rev-parse --is-inside-work-tree &> /dev/null; then | |
return | |
fi | |
echo $(command git remote -v | cut -d':' -f 2) | |
} | |
# Pretty log messages | |
function _git_log_prettily() { | |
if ! [ -z $1 ]; then | |
git log --pretty=$1 | |
fi | |
} | |
# Warn if the current branch is a WIP | |
function work_in_progress() { | |
if $(git log -n 1 2>/dev/null | grep -q -c "\-\-wip\-\-"); then | |
echo "WIP!!" | |
fi | |
} | |
# | |
# Aliases | |
# (sorted alphabetically) | |
# | |
alias g='git' | |
alias ga='git add' | |
alias gaa='git add --all' | |
alias gapa='git add --patch' | |
alias gau='git add --update' | |
alias gb='git branch' | |
alias gba='git branch -a' | |
alias gbd='git branch -d' | |
alias gbda='git branch --no-color --merged | command grep -vE "^(\*|\s*(master|develop|dev)\s*$)" | command xargs -n 1 git branch -d' | |
alias gbl='git blame -b -w' | |
alias gbnm='git branch --no-merged' | |
alias gbr='git branch --remote' | |
alias gbs='git bisect' | |
alias gbsb='git bisect bad' | |
alias gbsg='git bisect good' | |
alias gbsr='git bisect reset' | |
alias gbss='git bisect start' | |
alias gc='git commit -v' | |
alias gc!='git commit -v --amend' | |
alias gcn!='git commit -v --no-edit --amend' | |
alias gca='git commit -v -a' | |
alias gca!='git commit -v -a --amend' | |
alias gcan!='git commit -v -a --no-edit --amend' | |
alias gcans!='git commit -v -a -s --no-edit --amend' | |
alias gcam='git commit -a -m' | |
alias gcsm='git commit -s -m' | |
alias gcb='git checkout -b' | |
alias gcf='git config --list' | |
alias gcl='git clone --recursive' | |
alias gclean='git clean -fd' | |
alias gpristine='git reset --hard && git clean -dfx' | |
alias gcm='git checkout master' | |
alias gcd='git checkout develop' | |
alias gcmsg='git commit -m' | |
alias gco='git checkout' | |
alias gcount='git shortlog -sn' | |
alias gcp='git cherry-pick' | |
alias gcpa='git cherry-pick --abort' | |
alias gcpc='git cherry-pick --continue' | |
alias gcs='git commit -S' | |
alias gd='git diff' | |
alias gdca='git diff --cached' | |
alias gdct='git describe --tags `git rev-list --tags --max-count=1`' | |
alias gdt='git diff-tree --no-commit-id --name-only -r' | |
alias gdw='git diff --word-diff' | |
#function gdv() { git diff -w "$@" | view - } | |
alias gf='git fetch' | |
alias gfa='git fetch --all --prune' | |
alias gfo='git fetch origin' | |
#function gfg() { git ls-files | grep $@ } | |
alias gg='git gui citool' | |
alias gga='git gui citool --amend' | |
# function ggf() { | |
# [[ "$#" != 1 ]] && local b="$(git_current_branch)" | |
# git push --force origin "${b:=$1}" | |
# } | |
# function ggl() { | |
# if [[ "$#" != 0 ]] && [[ "$#" != 1 ]]; then | |
# git pull origin "${*}" | |
# else | |
# [[ "$#" == 0 ]] && local b="$(git_current_branch)" | |
# git pull origin "${b:=$1}" | |
# fi | |
# } | |
# function ggp() { | |
# if [[ "$#" != 0 ]] && [[ "$#" != 1 ]]; then | |
# git push origin "${*}" | |
# else | |
# [[ "$#" == 0 ]] && local b="$(git_current_branch)" | |
# git push origin "${b:=$1}" | |
# fi | |
# } | |
# function ggpnp() { | |
# if [[ "$#" == 0 ]]; then | |
# ggl && ggp | |
# else | |
# ggl "${*}" && ggp "${*}" | |
# fi | |
# } | |
# function ggu() { | |
# [[ "$#" != 1 ]] && local b="$(git_current_branch)" | |
# git pull --rebase origin "${b:=$1}" | |
# } | |
# alias ggpur='ggu' | |
alias ggpull='git pull origin $(git_current_branch)' | |
alias ggpush='git push origin $(git_current_branch)' | |
alias ggsup='git branch --set-upstream-to=origin/$(git_current_branch)' | |
alias gpsup='git push --set-upstream origin $(git_current_branch)' | |
alias ghh='git help' | |
alias gignore='git update-index --assume-unchanged' | |
alias gignored='git ls-files -v | grep "^[[:lower:]]"' | |
# alias git-svn-dcommit-push='git svn dcommit && git push github master:svntrunk' | |
alias gk='\gitk --all --branches' | |
alias gke='\gitk --all $(git log -g --pretty=%h)' | |
alias gl='git pull' | |
alias glg='git log --stat' | |
alias glgp='git log --stat -p' | |
alias glgg='git log --graph' | |
alias glgga='git log --graph --decorate --all' | |
alias glgm='git log --graph --max-count=10' | |
alias glo='git log --oneline --decorate' | |
alias glol="git log --graph --pretty='%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit" | |
alias glola="git log --graph --pretty='%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit --all" | |
alias glog='git log --oneline --decorate --graph' | |
alias gloga='git log --oneline --decorate --graph --all' | |
alias glp="_git_log_prettily" | |
alias gm='git merge' | |
alias gmom='git merge origin/master' | |
alias gmt='git mergetool --no-prompt' | |
alias gmtvim='git mergetool --no-prompt --tool=vimdiff' | |
alias gmum='git merge upstream/master' | |
alias gp='git push' | |
alias gpd='git push --dry-run' | |
alias gpoat='git push origin --all && git push origin --tags' | |
alias gpu='git push upstream' | |
alias gpv='git push -v' | |
alias gr='git remote' | |
alias gra='git remote add' | |
alias grb='git rebase' | |
alias grba='git rebase --abort' | |
alias grbc='git rebase --continue' | |
alias grbi='git rebase -i' | |
alias grbm='git rebase master' | |
alias grbs='git rebase --skip' | |
alias grh='git reset HEAD' | |
alias grhh='git reset HEAD --hard' | |
alias grmv='git remote rename' | |
alias grrm='git remote remove' | |
alias grset='git remote set-url' | |
alias grt='cd $(git rev-parse --show-toplevel || echo ".")' | |
alias gru='git reset --' | |
alias grup='git remote update' | |
alias grv='git remote -v' | |
alias gsb='git status -sb' | |
alias gsd='git svn dcommit' | |
alias gsi='git submodule init' | |
alias gsps='git show --pretty=short --show-signature' | |
alias gsr='git svn rebase' | |
alias gss='git status -s' | |
alias gst='git status' | |
alias gsta='git stash save' | |
alias gstaa='git stash apply' | |
alias gstc='git stash clear' | |
alias gstd='git stash drop' | |
alias gstl='git stash list' | |
alias gstp='git stash pop' | |
alias gsts='git stash show --text' | |
alias gsu='git submodule update' | |
alias gts='git tag -s' | |
alias gtv='git tag | sort -V' | |
alias gunignore='git update-index --no-assume-unchanged' | |
alias gunwip='git log -n 1 | grep -q -c "\-\-wip\-\-" && git reset HEAD~1' | |
alias gup='git pull --rebase' | |
alias gupv='git pull --rebase -v' | |
alias glum='git pull upstream master' | |
alias gwch='git whatchanged -p --abbrev-commit --pretty=medium' | |
alias gwip='git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify -m "--wip-- [skip ci]"' |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment