Merge pull request #4834 from pi-hole/fix/spinner

Only execute spinner function if there is a tty
This commit is contained in:
yubiuser 2022-07-26 09:29:55 +02:00 committed by GitHub
commit f59749b1c3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 31 additions and 21 deletions

View File

@ -1346,32 +1346,42 @@ check_database_integrity() {
} }
# Show a text spinner during a long process run # Show a text spinner during a long process run
#
spinner(){ spinner(){
local PID=$! # PID of the most recent background process # Show the spinner only if there is a tty
local spin="/-\|" if tty -s; then
local start=0 # PID of the most recent background process
local elapsed=0 _PID=$!
local i=1 _spin="/-\|"
_start=0
_elapsed=0
_i=1
start=$(date +%s) # Start the counter # Start the counter
_start=$(date +%s)
tput civis > /dev/tty # Hide the cursor # Hide the cursor
trap 'tput cnorm > /dev/tty' EXIT # ensures cursor is visible again, in case of premature exit tput civis > /dev/tty
while [ -d /proc/$PID ]; do # ensures cursor is visible again, in case of premature exit
elapsed=$(( $(date +%s) - start )) trap 'tput cnorm > /dev/tty' EXIT
# print the spinner only on screen (tty) - use hours only if needed
if [ "$elapsed" -lt 3600 ]; then while [ -d /proc/$_PID ]; do
printf "\r${spin:i++%${#spin}:1} %02d:%02d" $((elapsed/60)) $((elapsed%60)) >"$(tty)" _elapsed=$(( $(date +%s) - _start ))
# use hours only if needed
if [ "$_elapsed" -lt 3600 ]; then
printf "\r${_spin:_i++%${#_spin}:1} %02d:%02d" $((_elapsed/60)) $((_elapsed%60)) >"$(tty)"
else else
printf "\r${spin:i++%${#spin}:1} %02d:%02d:%02d" $((elapsed/3600)) $(((elapsed/60)%60)) $((elapsed%60)) >"$(tty)" printf "\r${_spin:_i++%${#_spin}:1} %02d:%02d:%02d" $((_elapsed/3600)) $(((_elapsed/60)%60)) $((_elapsed%60)) >"$(tty)"
fi fi
sleep 0.25 sleep 0.25
done done
printf "\r" >"$(tty)" # Return to the begin of the line after completion (the spinner will be overwritten) # Return to the begin of the line after completion (the spinner will be overwritten)
tput cnorm > /dev/tty # Restore cursor visibility printf "\r" >"$(tty)"
# Restore cursor visibility
tput cnorm > /dev/tty
fi
} }
obfuscated_pihole_log() { obfuscated_pihole_log() {