2001-11-17 23:54:29 +03:00
|
|
|
# Post processor for timeline output
|
|
|
|
# Does a diff betn consecutive timeline outputs looking for
|
|
|
|
# big % differences
|
|
|
|
|
|
|
|
my $percent = 1; # anything over 1% of total is of interest to us
|
|
|
|
my $ignoreDllLoads = 0; # by default dont ignore dll timings
|
|
|
|
|
|
|
|
# Read in log to memory
|
|
|
|
my @lines = <>;
|
|
|
|
|
|
|
|
my $total = 0;
|
|
|
|
# Look for main1's timing
|
|
|
|
foreach (@lines) {
|
|
|
|
if (/^([0-9\.]*): \.\.\.main1/) {
|
|
|
|
$total = $1 + 0;
|
|
|
|
print "Found main1 time: $total\n";
|
|
|
|
last;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
my $prev = 0;
|
|
|
|
my $t = $total * $percent / 100;
|
|
|
|
foreach (@lines) {
|
|
|
|
/^([0-9\.]*):/;
|
|
|
|
$cur = $1;
|
2001-11-19 20:33:51 +03:00
|
|
|
printdiff($cur, $prev, $_);
|
2001-11-20 21:03:16 +03:00
|
|
|
if (/total: ([0-9\.]*)/) {
|
|
|
|
# print how much % this was
|
|
|
|
printf "%4.2f%%", $1/$total*100;
|
|
|
|
}
|
2001-11-17 23:54:29 +03:00
|
|
|
print "\t$_";
|
|
|
|
$prev = $cur;
|
|
|
|
}
|
2001-11-19 20:33:51 +03:00
|
|
|
|
|
|
|
|
|
|
|
sub printdiff() {
|
|
|
|
my $cur = shift;
|
|
|
|
my $prev = shift;
|
|
|
|
my $line = shift;
|
|
|
|
my $diff = $cur - $prev;
|
|
|
|
|
|
|
|
# Make sure we have a considerable difference
|
|
|
|
if ($diff < $t) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
# If we are ignoring dlls and this is a dll line, return
|
|
|
|
if ($ignoreDllLoads && $line =~ /PR_LoadLibrary/) {
|
2001-11-20 21:03:16 +03:00
|
|
|
return 0;
|
2001-11-19 20:33:51 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
# if significant time elapsed print it
|
|
|
|
printf "%4.2f%% %5.3f\n", $diff/$total*100, $diff;
|
2001-11-20 21:03:16 +03:00
|
|
|
|
|
|
|
return 1;
|
2001-11-19 20:33:51 +03:00
|
|
|
}
|