mbligh | 95494ab | 2007-07-29 23:28:17 +0000 | [diff] [blame] | 1 | #!/usr/bin/python |
| 2 | # Copyright Martin J. Bligh (mbligh@google.com) |
| 3 | # Released under the GPL, v2 |
mbligh | e075c51 | 2006-12-14 23:21:17 +0000 | [diff] [blame] | 4 | |
mbligh | 95494ab | 2007-07-29 23:28:17 +0000 | [diff] [blame] | 5 | import os, sys, re |
mbligh | e075c51 | 2006-12-14 23:21:17 +0000 | [diff] [blame] | 6 | |
mbligh | 95494ab | 2007-07-29 23:28:17 +0000 | [diff] [blame] | 7 | results_per_sign = 10 |
mbligh | e075c51 | 2006-12-14 23:21:17 +0000 | [diff] [blame] | 8 | |
mbligh | 95494ab | 2007-07-29 23:28:17 +0000 | [diff] [blame] | 9 | def parse_lines(filename): |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 10 | 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 |
mbligh | e075c51 | 2006-12-14 23:21:17 +0000 | [diff] [blame] | 24 | |
mbligh | 95494ab | 2007-07-29 23:28:17 +0000 | [diff] [blame] | 25 | |
| 26 | # Firstly, suck in both files. |
| 27 | orig = {} |
| 28 | new = {} |
| 29 | diff = {} |
| 30 | |
| 31 | for (key, count) in parse_lines(sys.argv[1]): |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 32 | # 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 |
mbligh | 95494ab | 2007-07-29 23:28:17 +0000 | [diff] [blame] | 41 | |
| 42 | for (key, count) in parse_lines(sys.argv[2]): |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 43 | 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 |
mbligh | 95494ab | 2007-07-29 23:28:17 +0000 | [diff] [blame] | 51 | |
| 52 | if len(orig) < 2* results_per_sign or len(new) < 2 * results_per_sign: |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 53 | sys.exit(1) # one of the files was blank? |
mbligh | 95494ab | 2007-07-29 23:28:17 +0000 | [diff] [blame] | 54 | |
| 55 | # Now sort and print the diffs. |
| 56 | def print_key(key): |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 57 | 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) |
mbligh | 95494ab | 2007-07-29 23:28:17 +0000 | [diff] [blame] | 62 | |
| 63 | keys = sorted(diff.keys(), key=lambda x : diff[x], reverse = True) |
| 64 | |
| 65 | for key in keys[:results_per_sign]: |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 66 | print_key(key) |
mbligh | 95494ab | 2007-07-29 23:28:17 +0000 | [diff] [blame] | 67 | |
| 68 | print "\n...\n" |
| 69 | |
| 70 | for key in keys[len(keys)-results_per_sign:]: |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 71 | print_key(key) |