blob: da57eb097011500fbbd150fd4651ffa905fa1421 [file] [log] [blame]
mbligh95494ab2007-07-29 23:28:17 +00001#!/usr/bin/python
2# Copyright Martin J. Bligh (mbligh@google.com)
3# Released under the GPL, v2
mblighe075c512006-12-14 23:21:17 +00004
mbligh95494ab2007-07-29 23:28:17 +00005import os, sys, re
mblighe075c512006-12-14 23:21:17 +00006
mbligh95494ab2007-07-29 23:28:17 +00007results_per_sign = 10
mblighe075c512006-12-14 23:21:17 +00008
mbligh95494ab2007-07-29 23:28:17 +00009def parse_lines(filename):
jadmanski0afbb632008-06-06 21:10:57 +000010 results = []
11 start_key = 1
12 for line in open(filename).readlines():
13 try:
14 a = line.split()
15 key = ' '.join(a[start_key:])
16 count = int(a[0])
17 results.append((key, count))
18 except: # presumably a header line
19 if re.match(r'samples\s*%\s*app name\s*symbol name', line):
20 start_key = 2
21 elif re.match(r'samples\s*%\s*image name\s*app name\s*symbol name', line):
22 start_key = 3
23 return results
mblighe075c512006-12-14 23:21:17 +000024
mbligh95494ab2007-07-29 23:28:17 +000025
26# Firstly, suck in both files.
27orig = {}
28new = {}
29diff = {}
30
31for (key, count) in parse_lines(sys.argv[1]):
jadmanski0afbb632008-06-06 21:10:57 +000032 # Oprofile seems to be ... erm ... broken. Keys can appear > once ;-(
33 if orig.has_key(key):
34 orig[key] += count
35 else:
36 orig[key] = count
37 if diff.has_key(key):
38 diff[key] -= count
39 else:
40 diff[key] = -count
mbligh95494ab2007-07-29 23:28:17 +000041
42for (key, count) in parse_lines(sys.argv[2]):
jadmanski0afbb632008-06-06 21:10:57 +000043 if new.has_key(key):
44 new[key] += count
45 else:
46 new[key] = count
47 if diff.has_key(key):
48 diff[key] += count
49 else:
50 diff[key] = count
mbligh95494ab2007-07-29 23:28:17 +000051
52if len(orig) < 2* results_per_sign or len(new) < 2 * results_per_sign:
jadmanski0afbb632008-06-06 21:10:57 +000053 sys.exit(1) # one of the files was blank?
mbligh95494ab2007-07-29 23:28:17 +000054
55# Now sort and print the diffs.
56def print_key(key):
jadmanski0afbb632008-06-06 21:10:57 +000057 if orig.has_key(key) and orig[key] > 0:
58 pct = (100 * diff[key]) / orig[key]
59 else:
60 pct = 0
61 print "%10d %6.1f%% %s" % (diff[key], pct, key)
mbligh95494ab2007-07-29 23:28:17 +000062
63keys = sorted(diff.keys(), key=lambda x : diff[x], reverse = True)
64
65for key in keys[:results_per_sign]:
jadmanski0afbb632008-06-06 21:10:57 +000066 print_key(key)
mbligh95494ab2007-07-29 23:28:17 +000067
68print "\n...\n"
69
70for key in keys[len(keys)-results_per_sign:]:
jadmanski0afbb632008-06-06 21:10:57 +000071 print_key(key)