-
Notifications
You must be signed in to change notification settings - Fork 184
/
Copy pathtrace.sh
executable file
·50 lines (46 loc) · 986 Bytes
/
trace.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#!/usr/bin/env bash
# Usage: $0 [-v] [-q] <targetfile> [-s tool] tool [arguments ...]
verbose=1
if [[ "$1" == "-v" ]]; then
verbose=2
shift
fi
if [[ "$1" == "-q" ]]; then
verbose=0
shift
fi
file="${1%.*}"
if [[ "$2" == "-s" ]]; then
stage="$3"
shift 3
else
stage="$2"
shift 1
fi
report() {
status="$1"
}
tmp="$(mktemp)"
err="$(mktemp)"
trap 'rm -f "$tmp" "$err"' EXIT
set -o pipefail
if [[ "$1" == "!" ]]; then
shift
! "$@"
else
"$@"
fi > >(tee -a "$tmp") 2> >(tee -a "$tmp" | tee -a "$err" 1>&2)
status="$?"
if [[ -n "$TRACE_FILE" ]]; then
echo "$file $stage $status" >>"$TRACE_FILE"
if [[ "$status" -ne 0 ]]; then
tail -16 "$err" | while read -r line; do
echo "$file $stage $line" >>"$TRACE_FILE"
done
fi
fi
if [[ "$verbose" -eq 1 ]]; then
[[ "$status" -eq 0 ]] && res="\e[32mOK\e[0m" || res="\e[31mFAIL\e[0m"
printf "${file}: \e[35m${stage}\e[0m ... ${res}\n" 1>&2
fi
exit "$status"