bin/giti

94 lines
3.9 KiB
Bash
Executable File

#!/bin/bash
#
usage="Usage: $0 [-n | no details] [-r | repeat]"
while getopts "hnrs" options; do
case $options in
n ) NO_DETAILS="True";;
r ) REPEAT="True";;
s ) SHORT="True";;
h ) echo $usage
exit 0
;;
\? ) echo $usage
exit 1
;;
esac
done
if [[ $REPEAT == "True" ]]; then
watch -n 1 -c "clear && $0 -s"
else
COLOR_WHITE="\033[00m"
COLOR_CYAN="\033[1;36m"
COLOR_RED="\033[1;31m"
COLOR_YELLOW="\033[1;33m"
COLOR_DARKYELLOW="\033[0;33m"
COLOR_GREEN="\033[1;32m"
COLOR_DARKGREEN="\033[0;32m"
COLOR_OCHRE="\033[38;5;95m"
#
git_status="$(LANGUAGE='en_US.UTF-8 git' git status 2> /dev/null)"
git_diff="$(git status --porcelain 2> /dev/null)"
#
if [ -z "$git_status" ]; then
# No GIT repository
exit
fi
if [[ $SHORT ]]; then
if [[ ! $git_status =~ "working tree clean" ]] && [[ ! $git_status =~ "working directory clean" ]]; then
git_status_color="$COLOR_RED"
git_status_text="local changes"
elif [[ $git_status =~ "Your branch is behind" ]]; then
git_status_color="$COLOR_YELLOW"
git_status_text="pull required"
elif [[ $git_status =~ "Your branch is ahead of" ]]; then
git_status_color="$COLOR_YELLOW"
git_status_text="push required"
elif [[ $git_status =~ "nothing to commit" ]]; then
git_status_color="$COLOR_DARKGREEN"
git_status_text="clean "
else
git_status_color="$COLOR_OCHRE"
git_status_text="unknown "
fi
echo -ne "$git_status_color$git_status_text$COLOR_WHITE"
else
if [[ ! $git_status = "" ]]; then
git_branch="$(git branch 2> /dev/null | sed --quiet 's/* \(.*\)/\1/p')"
git_url="$(git config --get remote.origin.url 2> /dev/null)"
if [[ ! $git_status =~ "working tree clean" ]] && [[ ! $git_status =~ "working directory clean" ]]; then
git_status_color="$COLOR_RED"
git_status_text="╡ local changes ╞"
elif [[ $git_status =~ "Your branch is behind" ]]; then
git_status_color="$COLOR_YELLOW"
git_status_text="╡ pull required ╞"
elif [[ $git_status =~ "Your branch is ahead of" ]]; then
git_status_color="$COLOR_YELLOW"
git_status_text="╡ push required ╞"
elif [[ $git_status =~ "nothing to commit" ]]; then
git_status_color="$COLOR_DARKGREEN"
git_status_text="╡ clean ╞════════"
else
git_status_color="$COLOR_OCHRE"
git_status_text="╡ unknown ╞══════"
fi
fi
echo -e "$git_status_color╔═══$git_status_text════════════════════════════════════════════════════════════════"
echo -e "$git_status_color$COLOR_GREEN($git_branch) $COLOR_CYAN$git_url"
if [[ ! $git_diff == "" && $NO_DETAILS != "True" ]]; then
echo -e "$git_status_color╠════════════════════════════════════════════════════════════════════════════════════"
IFS=$'\n'
for ENTRY in $git_diff; do
if [[ $ENTRY = "D "* ]] || [[ $ENTRY = "A "* ]] || [[ $ENTRY = "M "* ]] || [[ $ENTRY = "R "* ]]; then
echo -e "$git_status_color$COLOR_DARKYELLOW$ENTRY"
else
echo -e "$git_status_color$COLOR_YELLOW$ENTRY"
fi
done
fi
echo -e "$git_status_color╚════════════════════════════════════════════════════════════════════════════════════$COLOR_WHITE\n \b"
fi
fi