mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2024-11-12 21:39:48 +01:00
8eb31a6f9a
also allow multiple arguments for ggp and ggl aliases
215 lines
6 KiB
Bash
215 lines
6 KiB
Bash
# Query/use custom command for `git`.
|
|
zstyle -s ":vcs_info:git:*:-all-" "command" _omz_git_git_cmd
|
|
: ${_omz_git_git_cmd:=git}
|
|
|
|
#
|
|
# Functions
|
|
#
|
|
|
|
# The current branch name
|
|
# Usage example: git pull origin $(current_branch)
|
|
# Using '--quiet' with 'symbolic-ref' will not cause a fatal error (128) if
|
|
# it's not a symbolic ref, but in a Git repo.
|
|
function current_branch() {
|
|
local ref
|
|
ref=$($_omz_git_git_cmd symbolic-ref --quiet HEAD 2> /dev/null)
|
|
local ret=$?
|
|
if [[ $ret != 0 ]]; then
|
|
[[ $ret == 128 ]] && return # no git repo.
|
|
ref=$($_omz_git_git_cmd rev-parse --short HEAD 2> /dev/null) || return
|
|
fi
|
|
echo ${ref#refs/heads/}
|
|
}
|
|
# The list of remotes
|
|
function current_repository() {
|
|
if ! $_omz_git_git_cmd rev-parse --is-inside-work-tree &> /dev/null; then
|
|
return
|
|
fi
|
|
echo $($_omz_git_git_cmd 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 gb='git branch'
|
|
alias gba='git branch -a'
|
|
alias gbda='git branch --merged | command grep -vE "^(\*|\s*master\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 gca='git commit -v -a'
|
|
alias gca!='git commit -v -a --amend'
|
|
alias gcan!='git commit -v -a -s --no-edit --amend'
|
|
alias gcb='git checkout -b'
|
|
alias gcf='git config --list'
|
|
alias gcl='git clone --recursive'
|
|
alias gclean='git reset --hard && git clean -dfx'
|
|
alias gcm='git checkout master'
|
|
alias gcmsg='git commit -m'
|
|
alias gco='git checkout'
|
|
alias gcount='git shortlog -sn'
|
|
compdef gcount=git
|
|
alias gcp='git cherry-pick'
|
|
alias gcs='git commit -S'
|
|
|
|
alias gd='git diff'
|
|
alias gdc='git diff --cached'
|
|
alias gdt='git diff-tree --no-commit-id --name-only -r'
|
|
gdv() { git diff -w "$@" | view - }
|
|
compdef _git gdv=git-diff
|
|
alias gdw='git diff --word-diff'
|
|
|
|
alias gf='git fetch'
|
|
alias gfa='git fetch --all --prune'
|
|
function gfg() { git ls-files | grep $@ }
|
|
compdef gfg=grep
|
|
alias gfo='git fetch origin'
|
|
|
|
alias gg='git gui citool'
|
|
alias gga='git gui citool --amend'
|
|
ggf() {
|
|
[[ "$#" != 1 ]] && local b="$(current_branch)"
|
|
git push --force origin "${b:=$1}"
|
|
}
|
|
compdef _git ggf=git-checkout
|
|
ggl() {
|
|
[[ "$#" == 0 ]] && local b="$(current_branch)"
|
|
git pull origin "${b:=$1}" "${*[2,-1]}"
|
|
}
|
|
compdef _git ggl=git-checkout
|
|
alias ggpull='ggl'
|
|
compdef _git ggpull=git-checkout
|
|
ggp() {
|
|
if [[ "$#" != 0 ]] && [[ "$#" != 1 ]]; then
|
|
git push origin "${*}"
|
|
else
|
|
[[ "$#" == 0 ]] && local b="$(current_branch)"
|
|
git push origin "${b:=$1}"
|
|
fi
|
|
}
|
|
compdef _git ggp=git-checkout
|
|
alias ggpush='ggp'
|
|
compdef _git ggpush=git-checkout
|
|
ggpnp() {
|
|
if [[ "$#" == 0 ]]; then
|
|
ggl && ggp
|
|
else
|
|
ggl "${*}" && ggp "${*}"
|
|
fi
|
|
}
|
|
compdef _git ggpnp=git-checkout
|
|
alias ggsup='git branch --set-upstream-to=origin/$(current_branch)'
|
|
ggu() {
|
|
[[ "$#" != 1 ]] && local b="$(current_branch)"
|
|
git pull --rebase origin "${b:=$1}"
|
|
}
|
|
compdef _git ggu=git-checkout
|
|
alias ggpur='ggu'
|
|
compdef _git ggpur=git-checkout
|
|
|
|
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'
|
|
compdef git-svn-dcommit-push=git
|
|
|
|
alias gk='\gitk --all --branches'
|
|
compdef _git gk='gitk'
|
|
alias gke='\gitk --all $(git log -g --pretty=format:%h)'
|
|
compdef _git gke='gitk'
|
|
|
|
alias gl='git pull'
|
|
alias glg='git log --stat --color'
|
|
alias glgp='git log --stat --color -p'
|
|
alias glgg='git log --graph --color'
|
|
alias glgga='git log --graph --decorate --all'
|
|
alias glgm='git log --graph --max-count=10'
|
|
alias glo='git log --oneline --decorate --color'
|
|
alias glol="git log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
|
|
alias glola="git log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit --all"
|
|
alias glog='git log --oneline --decorate --color --graph'
|
|
alias glp="_git_log_prettily"
|
|
compdef _git glp=git-log
|
|
|
|
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'
|
|
compdef _git gpoat=git-push
|
|
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'
|
|
alias gstaa='git stash apply'
|
|
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 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 gvt='git verify-tag'
|
|
|
|
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 -m "--wip--"'
|