2019-11-03 01:22:48 +00:00
|
|
|
from direct.showbase.Job import Job
|
|
|
|
import gc
|
|
|
|
|
|
|
|
class ObjectCount(Job):
|
|
|
|
""" logs a count of the number of each type of object found in gc.get_objects() """
|
|
|
|
def __init__(self, name, immediate=False, doneCallback=None):
|
|
|
|
Job.__init__(self, name)
|
|
|
|
self._doneCallback = doneCallback
|
|
|
|
jobMgr.add(self)
|
|
|
|
if immediate:
|
|
|
|
jobMgr.finish(self)
|
|
|
|
|
|
|
|
def destroy(self):
|
|
|
|
self._doneCallback = None
|
|
|
|
Job.destroy(self)
|
|
|
|
|
|
|
|
def finished(self):
|
|
|
|
if self._doneCallback:
|
|
|
|
self._doneCallback(self)
|
|
|
|
self.destroy()
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
objs = gc.get_objects()
|
|
|
|
yield None
|
|
|
|
type2count = {}
|
|
|
|
for obj in objs:
|
|
|
|
tn = safeTypeName(obj)
|
|
|
|
type2count.setdefault(tn, 0)
|
|
|
|
type2count[tn] += 1
|
|
|
|
yield None
|
|
|
|
# prevent garbage cycle
|
|
|
|
del objs
|
|
|
|
yield None
|
|
|
|
count2type = invertDictLossless(type2count)
|
|
|
|
yield None
|
2019-12-30 06:00:16 +00:00
|
|
|
counts = list(count2type.keys())
|
2019-11-03 01:22:48 +00:00
|
|
|
yield None
|
|
|
|
counts.sort()
|
|
|
|
yield None
|
|
|
|
counts.reverse()
|
|
|
|
yield None
|
2019-12-30 06:00:16 +00:00
|
|
|
print('===== ObjectCount: \'%s\' =====' % (self.getJobName()))
|
2019-11-03 01:22:48 +00:00
|
|
|
for count in counts:
|
|
|
|
types = count2type[count]
|
|
|
|
for type in types:
|
2019-12-30 06:00:16 +00:00
|
|
|
print('%s: %s' % (count, type))
|
2019-11-03 01:22:48 +00:00
|
|
|
yield None
|
|
|
|
yield Job.Done
|