Merge commit '102aefadaba271a48a74f13953dd88067f9862c6'

pull/778/head
romkatv 4 years ago
commit ee68d4db4b

@ -236,9 +236,9 @@ END
local fetch local fetch
if command -v curl >/dev/null 2>&1; then if command -v curl >/dev/null 2>&1; then
fetch="command curl -fsSLo" fetch="command curl -fsSL --"
elif command -v wget >/dev/null 2>&1; then elif command -v wget >/dev/null 2>&1; then
fetch="command wget -O" fetch="command wget -O- --"
else else
>&2 echo "[gitstatus] error: please install curl or wget" >&2 echo "[gitstatus] error: please install curl or wget"
exit 1 exit 1
@ -276,15 +276,29 @@ END
if [ "$1" != 1 ] && command -v sleep >/dev/null 2>/dev/null; then if [ "$1" != 1 ] && command -v sleep >/dev/null 2>/dev/null; then
sleep "$1" sleep "$1"
fi fi
$fetch "$1".tar.gz -- "$2" 2>/dev/null & local part=0 url ret pid die
local pid=$! while true; do
local die="trap - $sig; kill -- $pid 2>/dev/null; exit 1" if [ "$part" = 3 ]; then
ret=1
break
elif [ "$part" = 0 ]; then
url="$2"
else
url="$2"."$part"
fi
$fetch "$url" >>"$1".tar.gz 2>/dev/null &
pid=$!
die="trap - $sig; kill -- $pid 2>/dev/null; exit 1"
trap "$die" $sig trap "$die" $sig
[ -z "$trapped" ] || eval "$die" [ -z "$trapped" ] || eval "$die"
wait -- "$pid" 2>/dev/null && check_sha256 "$1" wait -- "$pid" 2>/dev/null
local ret="$?" ret="$?"
echo -n >"$1".status
trap - $sig trap - $sig
[ "$ret" = 0 ] || break
check_sha256 "$1" && break
part=$((part+1))
done
echo -n >"$1".status
return "$ret" return "$ret"
} }

Loading…
Cancel
Save