giti rework for detailed prompt output
This commit is contained in:
parent
d611d918b8
commit
feedffe752
182
giti
182
giti
@ -1,11 +1,13 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
#
|
#
|
||||||
usage="Usage: $0 [-n | no details] [-r | repeat]"
|
|
||||||
while getopts "hnrs" options; do
|
#
|
||||||
|
# command line arguments
|
||||||
|
#
|
||||||
|
usage="Usage: $0 [-p | output for prompt]"
|
||||||
|
while getopts "hp" options; do
|
||||||
case $options in
|
case $options in
|
||||||
n ) NO_DETAILS="True";;
|
p ) PROMPT="True";;
|
||||||
r ) REPEAT="True";;
|
|
||||||
s ) SHORT="True";;
|
|
||||||
h ) echo $usage
|
h ) echo $usage
|
||||||
exit 0
|
exit 0
|
||||||
;;
|
;;
|
||||||
@ -15,89 +17,93 @@ while getopts "hnrs" options; do
|
|||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
if [[ $REPEAT == "True" ]]; then
|
#
|
||||||
watch -n 1 -c "clear && $0 -s"
|
# color definitions
|
||||||
else
|
#
|
||||||
COLOR_WHITE="\033[00m"
|
COLOR_WHITE="\033[00m"
|
||||||
COLOR_CYAN="\033[1;36m"
|
COLOR_CYAN="\033[1;36m"
|
||||||
COLOR_RED="\033[1;31m"
|
COLOR_RED="\033[1;31m"
|
||||||
COLOR_YELLOW="\033[1;33m"
|
COLOR_YELLOW="\033[1;33m"
|
||||||
COLOR_DARKYELLOW="\033[0;33m"
|
COLOR_DARKYELLOW="\033[0;33m"
|
||||||
COLOR_GREEN="\033[1;32m"
|
COLOR_GREEN="\033[1;32m"
|
||||||
COLOR_DARKGREEN="\033[0;32m"
|
COLOR_DARKGREEN="\033[0;32m"
|
||||||
COLOR_OCHRE="\033[38;5;95m"
|
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
|
|
||||||
if [[ $NO_DETAILS ]]; then
|
|
||||||
# echo -e "$git_status_color╠══$COLOR_GREEN($git_branch)$git_status_color - $git_status_text - $COLOR_CYAN$git_url$COLOR_WHITE\n\b"
|
|
||||||
echo -e "$git_status_color├──$COLOR_GREEN($git_branch)$git_status_color - $git_status_text - $COLOR_CYAN$git_url$COLOR_WHITE\n\b"
|
|
||||||
else
|
|
||||||
# echo -e "$git_status_color╔═══╡ $git_status_text ╞════════════════════════════════════════════════════════════════"
|
|
||||||
echo -e "$git_status_color┌───┤ $git_status_text ├────────────────────────────────────────────────────────────────"
|
|
||||||
# echo -e "$git_status_color║ $COLOR_GREEN($git_branch) $COLOR_CYAN$git_url"
|
|
||||||
echo -e "$git_status_color│ $COLOR_GREEN($git_branch) $COLOR_CYAN$git_url"
|
|
||||||
|
|
||||||
if [[ ! $git_diff == "" ]]; then
|
#
|
||||||
# echo -e "$git_status_color╠════════════════════════════════════════════════════════════════════════════════════"
|
# git information storage
|
||||||
echo -e "$git_status_color├────────────────────────────────────────────────────────────────────────────────────"
|
#
|
||||||
IFS=$'\n'
|
git_status="$(LANGUAGE='en_US.UTF-8 git' git status 2> /dev/null)"
|
||||||
for ENTRY in $git_diff; do
|
git_diff="$(git status --porcelain 2> /dev/null)"
|
||||||
if [[ $ENTRY = "D "* ]] || [[ $ENTRY = "A "* ]] || [[ $ENTRY = "M "* ]] || [[ $ENTRY = "R "* ]]; then
|
|
||||||
# echo -e "$git_status_color║ $COLOR_DARKYELLOW$ENTRY"
|
|
||||||
echo -e "$git_status_color│ $COLOR_DARKYELLOW$ENTRY"
|
#
|
||||||
else
|
# decision for git output (path is repository)
|
||||||
# echo -e "$git_status_color║ $COLOR_YELLOW$ENTRY"
|
#
|
||||||
echo -e "$git_status_color│ $COLOR_YELLOW$ENTRY"
|
if [ -z "$git_status" ]; then
|
||||||
fi
|
# No GIT repository
|
||||||
done
|
exit
|
||||||
fi
|
fi
|
||||||
# echo -e "$git_status_color╚════════════════════════════════════════════════════════════════════════════════════$COLOR_WHITE\n \b"
|
|
||||||
echo -e "$git_status_color└────────────────────────────────────────────────────────────────────────────────────$COLOR_WHITE\n \b"
|
#
|
||||||
fi
|
# git preparations
|
||||||
|
#
|
||||||
|
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
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Start of console output
|
||||||
|
#
|
||||||
|
|
||||||
|
## STATUS AND INFO ######
|
||||||
|
if [[ $PROMPT ]]; then
|
||||||
|
# print status
|
||||||
|
echo -e "$git_status_color├──$COLOR_GREEN($git_branch)$git_status_color - $git_status_text - $COLOR_CYAN$git_url$COLOR_WHITE"
|
||||||
|
else
|
||||||
|
# print status and
|
||||||
|
echo -e "$git_status_color┌───┤ $git_status_text ├────────────────────────────────────────────────────────────────"
|
||||||
|
echo -e "$git_status_color│ $COLOR_GREEN($git_branch) $COLOR_CYAN$git_url"
|
||||||
|
|
||||||
|
if [[ ! $git_diff == "" ]]; then
|
||||||
|
echo -e "$git_status_color├────────────────────────────────────────────────────────────────────────────────────"
|
||||||
|
else
|
||||||
|
echo -e "$git_status_color└────────────────────────────────────────────────────────────────────────────────────$COLOR_WHITE\n \b"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
## FILE INFO ############
|
||||||
|
if [[ ! $git_diff == "" ]]; then
|
||||||
|
if [[ ! $PROMPT || "$GIT_PROMPT_DETAILS" == "on" ]]; then
|
||||||
|
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
|
||||||
|
fi
|
||||||
|
|
||||||
|
## CLOSING ##############
|
||||||
|
if [[ $PROMPT ]]; then
|
||||||
|
echo -e " \b"
|
||||||
|
else
|
||||||
|
echo -e "$git_status_color└────────────────────────────────────────────────────────────────────────────────────$COLOR_WHITE\n \b"
|
||||||
|
fi
|
||||||
|
Loading…
x
Reference in New Issue
Block a user