~vcs-imports/kupfer/master-new

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
"""
Debugging routines. To use this, simply import this module
"""

import atexit

def mem_stats():
	import gc
	print "DEBUG: OBJ STATS"

	print "enabled:", gc.isenabled()
	print "objs", len(gc.get_objects())
	print "collected (now)", gc.collect()

	# after collection
	hist = {}
	for obj in gc.get_objects():
		key = str(type(obj))
		if key not in hist:
			hist[key] =1
		else:
			hist[key] += 1
	
	best = hist.items()
	best.sort(key=lambda x:x[1], reverse=True)
	print "\n".join("%s: %d" % (k,v) for k,v in best[:10])

	our = []
	gtk = []
	for item in best:
		if "objects." in item[0] or "kupfer." in item[0]:
			our.append(item)
		if "gtk" in item[0]:
			gtk.append(item)
	
	print "---just gtk (top)"
	print "\n".join("%s: %d" % (k,v) for k,v in gtk[:10])
	print "---Just our objects (all)"
	print "\n".join("%s: %d" % (k,v) for k,v in our)

def make_histogram(vect, nbins=7):
	"""make a histogram out of @vect"""
	mi,ma = 0, max(vect)
	bins = [0]*nbins
	bin_size = ma/nbins + 1
	def brange(i):
		return xrange(i*bin_size, (i+1)*bin_size)
	for acc in vect:
		for i in xrange(nbins):
			if acc in brange(i):
				bins[i] += 1
				break
	# headers
	print " ".join("%10s" % ("[%2d, %2d)" % (min(brange(i)), max(brange(i))),) for i in xrange(nbins))
	print " ".join("%10d" % bins[i] for i in xrange(nbins))
	

def icon_stats():
	from kupfer.icons import icon_cache
	print "DEBUG: ICON STATS"

	c = 0
	tot_acc = 0
	tot_pix = 0
	acc_vect = []
	for k in icon_cache:
		rec = icon_cache[k]
		acc = rec["accesses"]
		acc_vect.append(acc)
		if not acc:
			c += 1
		tot_acc += acc
		icon = rec["icon"]
		tot_pix += icon.get_height() * icon.get_width()
	print "Cached icons:",  len(icon_cache)
	print "Unused cache entries", c
	print "Total accesses", tot_acc
	print make_histogram(acc_vect)
	print "Sum pixels", tot_pix
	print "Cached icon keys:"
	for k in sorted(icon_cache, key=lambda k: icon_cache[k]["accesses"]):
		print k, icon_cache[k]["accesses"]

atexit.register(mem_stats)
atexit.register(icon_stats)