]>
Commit | Line | Data |
---|---|---|
ccc6cda3 JA |
1 | #! /bin/bash |
2 | # | |
3 | # shprof - a line profiler for shell scripts | |
4 | # | |
5 | # adapted from a similar program included in `The New KornShell' by | |
6 | # Bolsky and Korn and posted to usenet by bsh20858@challenger.fhda.edu | |
7 | # | |
8 | # converted to bash v2 syntax by Chet Ramey | |
9 | # | |
10 | TMPFILE=${TMP:-/tmp}/shprof$$ | |
11 | ||
12 | trap 'rm -f $TMPFILE' EXIT | |
13 | ||
14 | errexit() | |
15 | { | |
16 | echo $0: "$@" >&2 | |
17 | exit 1 | |
18 | } | |
19 | ||
20 | # create script with profiling enabled | |
21 | cat > $TMPFILE <<- \_EOF_ | |
22 | declare -a _line | |
23 | _profend() | |
24 | { | |
25 | case "$1" in | |
26 | /*|./*) file="$1" ;; | |
27 | *) file=$(type -path "$1") ;; | |
28 | esac | |
29 | ||
30 | echo "*** line profile for $file ***" | |
31 | i=1; | |
32 | while read -r && [ $i -le $NLINE ]; do | |
33 | count=${_line[$i]} | |
34 | if [ "$count" -gt 0 ]; then | |
35 | echo "[$count] $i: $REPLY" | |
36 | fi | |
37 | i=$((i + 1)) | |
38 | done <$file | |
39 | _EOF_ | |
40 | # make the profiling script remove itself after printing line stats | |
41 | echo "rm -f $TMPFILE" >> $TMPFILE | |
42 | cat >> $TMPFILE <<- \_EOF_ | |
43 | } | |
44 | _command=$1 | |
45 | shift | |
46 | i=1 | |
47 | NLINE=$(wc -l < "$_command") | |
48 | while [ $i -le $NLINE ]; do | |
49 | _line[$i]=0 | |
50 | i=$((i + 1)) | |
51 | done | |
52 | unset i | |
53 | trap "_profend ${_command}" EXIT | |
54 | trap '_line[$LINENO]=$((${_line[$LINENO]} + 1))' DEBUG | |
55 | LINENO=0 | |
56 | _EOF_ | |
57 | ||
58 | case "$1" in | |
59 | /*|./*) file=$1 ;; | |
60 | *) file=$((type -path "$1")) ;; | |
61 | esac | |
62 | ||
63 | cat "${file-$1}" >> $TMPFILE || errexit "${1}: cannot open" | |
64 | chmod +x $TMPFILE | |
65 | ||
66 | exec -a "$file" $TMPFILE "$@" |