giti rework for detailed prompt output

This commit is contained in:
Dirk Alders 2023-09-30 09:17:25 +02:00
parent d611d918b8
commit feedffe752

134
giti
View File

@ -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)" # git information storage
# #
if [ -z "$git_status" ]; then git_status="$(LANGUAGE='en_US.UTF-8 git' git status 2> /dev/null)"
git_diff="$(git status --porcelain 2> /dev/null)"
#
# decision for git output (path is repository)
#
if [ -z "$git_status" ]; then
# No GIT repository # No GIT repository
exit exit
fi fi
if [[ $SHORT ]]; then
if [[ ! $git_status =~ "working tree clean" ]] && [[ ! $git_status =~ "working directory clean" ]]; then #
# 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_color="$COLOR_RED"
git_status_text="local changes" git_status_text="local changes"
elif [[ $git_status =~ "Your branch is behind" ]]; then elif [[ $git_status =~ "Your branch is behind" ]]; then
git_status_color="$COLOR_YELLOW" git_status_color="$COLOR_YELLOW"
git_status_text="pull required" git_status_text="pull required"
elif [[ $git_status =~ "Your branch is ahead of" ]]; then elif [[ $git_status =~ "Your branch is ahead of" ]]; then
git_status_color="$COLOR_YELLOW" git_status_color="$COLOR_YELLOW"
git_status_text="push required" git_status_text="push required"
elif [[ $git_status =~ "nothing to commit" ]]; then elif [[ $git_status =~ "nothing to commit" ]]; then
git_status_color="$COLOR_DARKGREEN" git_status_color="$COLOR_DARKGREEN"
git_status_text="clean " git_status_text="clean "
else else
git_status_color="$COLOR_OCHRE" git_status_color="$COLOR_OCHRE"
git_status_text="unknown " git_status_text="unknown "
fi 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')" # Start of console output
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" ## STATUS AND INFO ######
git_status_text="local changes" if [[ $PROMPT ]]; then
elif [[ $git_status =~ "Your branch is behind" ]]; then # print status
git_status_color="$COLOR_YELLOW" echo -e "$git_status_color├──$COLOR_GREEN($git_branch)$git_status_color - $git_status_text - $COLOR_CYAN$git_url$COLOR_WHITE"
git_status_text="pull required" else
elif [[ $git_status =~ "Your branch is ahead of" ]]; then # print status and
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┌───┤ $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" echo -e "$git_status_color│ $COLOR_GREEN($git_branch) $COLOR_CYAN$git_url"
if [[ ! $git_diff == "" ]]; then if [[ ! $git_diff == "" ]]; then
# echo -e "$git_status_color╠════════════════════════════════════════════════════════════════════════════════════"
echo -e "$git_status_color├────────────────────────────────────────────────────────────────────────────────────" echo -e "$git_status_color├────────────────────────────────────────────────────────────────────────────────────"
else
echo -e "$git_status_color└────────────────────────────────────────────────────────────────────────────────────$COLOR_WHITE\n \b"
fi
fi
## FILE INFO ############
if [[ ! $git_diff == "" ]]; then
if [[ ! $PROMPT || "$GIT_PROMPT_DETAILS" == "on" ]]; then
IFS=$'\n' IFS=$'\n'
for ENTRY in $git_diff; do for ENTRY in $git_diff; do
if [[ $ENTRY = "D "* ]] || [[ $ENTRY = "A "* ]] || [[ $ENTRY = "M "* ]] || [[ $ENTRY = "R "* ]]; then 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" echo -e "$git_status_color│ $COLOR_DARKYELLOW$ENTRY"
else else
# echo -e "$git_status_color║ $COLOR_YELLOW$ENTRY"
echo -e "$git_status_color│ $COLOR_YELLOW$ENTRY" echo -e "$git_status_color│ $COLOR_YELLOW$ENTRY"
fi fi
done done
fi fi
# echo -e "$git_status_color╚════════════════════════════════════════════════════════════════════════════════════$COLOR_WHITE\n \b" fi
echo -e "$git_status_color└────────────────────────────────────────────────────────────────────────────────────$COLOR_WHITE\n \b"
fi ## CLOSING ##############
fi if [[ $PROMPT ]]; then
echo -e " \b"
else
echo -e "$git_status_color└────────────────────────────────────────────────────────────────────────────────────$COLOR_WHITE\n \b"
fi fi