| Line | |
|---|
| 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 "$@"
|
|---|
Note:
See
TracBrowser
for help on using the repository browser.