whitespace
[automated-distro-installer] / fai / config / files / boot / bash-trace / DEFAULT
1 # meant to be sourced. copy/pasted from https://iankelling.org/git/?p=errhandle;a=summary
2
3 bash-trace() {
4 local -i argc_index=0 arg frame i start=${1:-1} max_indent=8 indent
5 local source
6 local extdebug=false
7 if [[ $(shopt -p extdebug) == *-s* ]]; then
8 extdebug=true
9 fi
10
11 for ((frame=0; frame < ${#FUNCNAME[@]}-1; frame++)); do
12 argc=${BASH_ARGC[frame]}
13 argc_index+=$argc
14 ((frame < start)) && continue
15 if (( ${#BASH_SOURCE[@]} > 1 )); then
16 source="${BASH_SOURCE[frame+1]}:${BASH_LINENO[frame]}:"
17 fi
18 indent=$((frame-start+1))
19 indent=$((indent < max_indent ? indent : max_indent))
20 printf "%${indent}s↳%sin \`%s" '' "$source" "${FUNCNAME[frame]}"
21 if $extdebug; then
22 for ((i=argc_index-1; i >= argc_index-argc; i--)); do
23 printf " %s" "${BASH_ARGV[i]}"
24 done
25 fi
26 echo \'
27 done
28 }
29
30
31 errcatch() {
32 set -E; shopt -s extdebug
33 _err-trap() {
34 err=$?
35 exec >&2
36 set +x
37 echo "${BASH_SOURCE[1]}:${BASH_LINENO[0]}:in \`$BASH_COMMAND' returned $err"
38 bash-trace 2
39 set -e
40 "${_errcatch_cleanup[@]}"
41 echo "$0: exiting with code $err"
42 exit $err
43 }
44 trap _err-trap ERR
45 set -o pipefail
46 }
47
48 errcatch