-
Notifications
You must be signed in to change notification settings - Fork 2.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Noah Gorny
committed
Feb 6, 2021
1 parent
fe9ef1e
commit 53894cd
Showing
2 changed files
with
317 additions
and
0 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,316 @@ | ||
# shellcheck shell=bash | ||
cite 'about-alias' | ||
about-alias 'git aliases from oh-my-zsh' | ||
|
||
# We are not vendoring this, as we need to adapt it to bash :( | ||
|
||
# MIT License | ||
|
||
# Copyright (c) 2009-2021 Robby Russell and contributors (https://github.com/ohmyzsh/ohmyzsh/contributors) | ||
|
||
# Permission is hereby granted, free of charge, to any person obtaining a copy | ||
# of this software and associated documentation files (the "Software"), to deal | ||
# in the Software without restriction, including without limitation the rights | ||
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
# copies of the Software, and to permit persons to whom the Software is | ||
# furnished to do so, subject to the following conditions: | ||
|
||
# The above copyright notice and this permission notice shall be included in all | ||
# copies or substantial portions of the Software. | ||
|
||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
# SOFTWARE. | ||
|
||
# Load after regular git aliases | ||
# BASH_IT_LOAD_PRIORITY: 160 | ||
|
||
# | ||
# Functions | ||
# | ||
|
||
# The name of the current branch | ||
function git_current_branch() { | ||
_git-branch | ||
} | ||
|
||
# Pretty log messages | ||
function _git_log_prettily() { | ||
if [ -n "$1" ]; then | ||
git log --pretty="$1" | ||
fi | ||
} | ||
|
||
# Warn if the current branch is a WIP | ||
function work_in_progress() { | ||
exists=$(git log -n 1 2> /dev/null | grep -q -c "\-\-wip\-\-") | ||
if $exists; then | ||
echo "WIP!!" | ||
fi | ||
} | ||
|
||
# Check if main exists and use instead of master | ||
function git_main_branch() { | ||
command git rev-parse --git-dir &> /dev/null || return | ||
local branch | ||
for branch in main trunk; do | ||
if command git show-ref -q --verify refs/heads/$branch; then | ||
echo $branch | ||
return | ||
fi | ||
done | ||
echo master | ||
} | ||
|
||
# | ||
# 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 gav='git add --verbose' | ||
alias gap='git apply' | ||
alias gapt='git apply --3way' | ||
|
||
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*($(git_main_branch)|development|develop|devel|dev)\s*$)" | command xargs -n 1 git branch -d' | ||
alias gbD='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 --recurse-submodules' | ||
alias gclean='git clean -id' | ||
alias gpristine='git reset --hard && git clean -dffx' | ||
alias gcm='git checkout $(git_main_branch)' | ||
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 gdcw='git diff --cached --word-diff' | ||
alias gdct='git describe --tags $(git rev-list --tags --max-count=1)' | ||
alias gds='git diff --staged' | ||
alias gdt='git diff-tree --no-commit-id --name-only -r' | ||
alias gdw='git diff --word-diff' | ||
|
||
function gdnolock() { | ||
git diff "$@" ":(exclude)package-lock.json" ":(exclude)*.lock" | ||
} | ||
|
||
alias gf='git fetch' | ||
# --jobs=<n> was added in git 2.8 | ||
alias gfa='git fetch --all --prune --jobs=10' | ||
alias gfo='git fetch origin' | ||
|
||
alias 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 ggfl() { | ||
[[ "$#" != 1 ]] && local b="$(git_current_branch)" | ||
git push --force-with-lease 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 $(git_main_branch):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(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset'" | ||
alias glols="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --stat" | ||
alias glod="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset'" | ||
alias glods="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short" | ||
alias glola="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --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/$(git_main_branch)' | ||
alias gmt='git mergetool --no-prompt' | ||
alias gmtvim='git mergetool --no-prompt --tool=vimdiff' | ||
alias gmum='git merge upstream/$(git_main_branch)' | ||
alias gma='git merge --abort' | ||
|
||
alias gp='git push' | ||
alias gpd='git push --dry-run' | ||
alias gpf='git push --force-with-lease' | ||
alias gpf!='git push --force' | ||
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 grbd='git rebase develop' | ||
alias grbi='git rebase -i' | ||
alias grbm='git rebase $(git_main_branch)' | ||
alias grbs='git rebase --skip' | ||
alias grev='git revert' | ||
alias grh='git reset' | ||
alias grhh='git reset --hard' | ||
alias groh='git reset origin/$(git_current_branch) --hard' | ||
alias grm='git rm' | ||
alias grmc='git rm --cached' | ||
alias grmv='git remote rename' | ||
alias grrm='git remote remove' | ||
alias grs='git restore' | ||
alias grset='git remote set-url' | ||
alias grss='git restore --source' | ||
alias grst='git restore --staged' | ||
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 gsh='git show' | ||
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' | ||
|
||
# use the default stash push on git 2.13 and newer | ||
alias gsta='git stash push' | ||
|
||
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 gstu='git stash --include-untracked' | ||
alias gstall='git stash --all' | ||
alias gsu='git submodule update' | ||
alias gsw='git switch' | ||
alias gswc='git switch -c' | ||
|
||
alias gts='git tag -s' | ||
alias gtv='git tag | sort -V' | ||
function gtl() { | ||
git tag --sort=-v:refname -n -l "${1}*" | ||
} | ||
|
||
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 gupa='git pull --rebase --autostash' | ||
alias gupav='git pull --rebase --autostash -v' | ||
alias glum='git pull upstream $(git_main_branch)' | ||
|
||
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 --no-gpg-sign -m "--wip-- [skip ci]"' | ||
|
||
alias gam='git am' | ||
alias gamc='git am --continue' | ||
alias gams='git am --skip' | ||
alias gama='git am --abort' | ||
alias gamscp='git am --show-current-patch' | ||
|
||
function grename() { | ||
if [[ -z "$1" || -z "$2" ]]; then | ||
echo "Usage: $0 old_branch new_branch" | ||
return 1 | ||
fi | ||
|
||
# Rename branch locally | ||
git branch -m "$1" "$2" | ||
# Rename branch in origin remote | ||
if git push origin :"$1"; then | ||
git push --set-upstream origin "$2" | ||
fi | ||
} |
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