- Got rid of newmodule.c
[python/dscho.git] / Lib / hotshot / __init__.py
bloba23b2ee652664cee5e5f9153a3bf76b5a1541bce
1 """High-perfomance logging profiler, mostly written in C."""
3 import _hotshot
5 from _hotshot import ProfilerError
8 class Profile:
9 def __init__(self, logfn, lineevents=0, linetimings=1):
10 self.lineevents = lineevents and 1 or 0
11 self.linetimings = (linetimings and lineevents) and 1 or 0
12 self._prof = p = _hotshot.profiler(
13 logfn, self.lineevents, self.linetimings)
15 # Attempt to avoid confusing results caused by the presence of
16 # Python wrappers around these functions, but only if we can
17 # be sure the methods have not been overridden or extended.
18 if self.__class__ is Profile:
19 self.close = p.close
20 self.start = p.start
21 self.stop = p.stop
22 self.addinfo = p.addinfo
24 def close(self):
25 """Close the logfile and terminate the profiler."""
26 self._prof.close()
28 def start(self):
29 """Start the profiler."""
30 self._prof.start()
32 def stop(self):
33 """Stop the profiler."""
34 self._prof.stop()
36 def addinfo(self, key, value):
37 """Add an arbitrary labelled value to the profile log."""
38 self._prof.addinfo(key, value)
40 # These methods offer the same interface as the profile.Profile class,
41 # but delegate most of the work to the C implementation underneath.
43 def run(self, cmd):
44 """Profile an exec-compatible string in the script
45 environment.
47 The globals from the __main__ module are used as both the
48 globals and locals for the script.
49 """
50 import __main__
51 dict = __main__.__dict__
52 return self.runctx(cmd, dict, dict)
54 def runctx(self, cmd, globals, locals):
55 """Evaluate an exec-compatible string in a specific
56 environment.
58 The string is compiled before profiling begins.
59 """
60 code = compile(cmd, "<string>", "exec")
61 self._prof.runcode(code, globals, locals)
62 return self
64 def runcall(self, func, *args, **kw):
65 """Profile a single call of a callable.
67 Additional positional and keyword arguments may be passed
68 along; the result of the call is returned, and exceptions are
69 allowed to propogate cleanly, while ensuring that profiling is
70 disabled on the way out.
71 """
72 return self._prof.runcall(func, args, kw)