Denys Vlasenko | da3657d | 2012-03-09 13:43:44 +0100 | [diff] [blame] | 1 | #!/bin/sh |
Denys Vlasenko | da3657d | 2012-03-09 13:43:44 +0100 | [diff] [blame] | 2 | |
| 3 | if test $# = 0; then |
Dmitry V. Levin | 63c5e63 | 2012-03-10 16:10:06 +0000 | [diff] [blame^] | 4 | cat >&2 <<__EOF__ |
| 5 | Usage: ${0##*/} STRACE_LOG |
| 6 | |
Denys Vlasenko | da3657d | 2012-03-09 13:43:44 +0100 | [diff] [blame] | 7 | Finds all STRACE_LOG.PID files, adds PID prefix to every line, |
| 8 | then combines and sorts them, and prints result to standard output. |
| 9 | |
| 10 | It is assumed that STRACE_LOGs were produced by strace with -tt[t] |
Dmitry V. Levin | 63c5e63 | 2012-03-10 16:10:06 +0000 | [diff] [blame^] | 11 | option which prints timestamps (otherwise sorting won't do any good). |
| 12 | __EOF__ |
| 13 | exit 1 |
Denys Vlasenko | da3657d | 2012-03-09 13:43:44 +0100 | [diff] [blame] | 14 | fi |
| 15 | |
Denys Vlasenko | da3657d | 2012-03-09 13:43:44 +0100 | [diff] [blame] | 16 | logfile=$1 |
| 17 | pfxlen=${#1} |
| 18 | |
| 19 | for file in "$logfile".*; do |
Dmitry V. Levin | 63c5e63 | 2012-03-10 16:10:06 +0000 | [diff] [blame^] | 20 | [ -f "$file" ] || continue |
Denys Vlasenko | da3657d | 2012-03-09 13:43:44 +0100 | [diff] [blame] | 21 | suffix=${file:1+$pfxlen} |
Dmitry V. Levin | 63c5e63 | 2012-03-10 16:10:06 +0000 | [diff] [blame^] | 22 | [ "$suffix" -gt 0 ] 2> /dev/null || { |
Denys Vlasenko | da3657d | 2012-03-09 13:43:44 +0100 | [diff] [blame] | 23 | echo "Skipped file '$file' (bad suffix)" >&2 |
| 24 | continue |
| 25 | } |
| 26 | pid=$(printf "%-5s" $suffix) |
Dmitry V. Levin | 63c5e63 | 2012-03-10 16:10:06 +0000 | [diff] [blame^] | 27 | # Some strace logs have last line which is not '\n' terminated, |
| 28 | # so add extra newline to every file. |
Denys Vlasenko | da3657d | 2012-03-09 13:43:44 +0100 | [diff] [blame] | 29 | # grep -v '^$' removes empty lines which may result. |
Dmitry V. Levin | 63c5e63 | 2012-03-10 16:10:06 +0000 | [diff] [blame^] | 30 | sed "s/^/$pid /" < "$file" |
| 31 | echo |
Denys Vlasenko | da3657d | 2012-03-09 13:43:44 +0100 | [diff] [blame] | 32 | done \ |
| 33 | | grep -v '^$' | sort -k2 |