summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2014-08-27 14:56:25 +0100
committerRichard Purdie <richard.purdie@linuxfoundation.org>2014-08-27 14:58:43 +0100
commit93d155f4766e27e7b004d13569aa03961fe89e3b (patch)
treee13d8f34d553de040d72672e217c1821cefda4d9
parent303e6256947f4df4f283b75b7ccfdffa72864d67 (diff)
downloadbitbake-93d155f4766e27e7b004d13569aa03961fe89e3b.tar.gz
utils: Improve profile log processing
This stream redirection of stdout is horrible. pstats takes a stream argument so lets use that instead. Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r--lib/bb/utils.py7
1 files changed, 1 insertions, 6 deletions
diff --git a/lib/bb/utils.py b/lib/bb/utils.py
index 7d37a745a..670e592fe 100644
--- a/lib/bb/utils.py
+++ b/lib/bb/utils.py
@@ -862,21 +862,16 @@ def nonblockingfd(fd):
fcntl.fcntl(fd, fcntl.F_SETFL, fcntl.fcntl(fd, fcntl.F_GETFL) | os.O_NONBLOCK)
def process_profilelog(fn):
- # Redirect stdout to capture profile information
pout = open(fn + '.processed', 'w')
- so = sys.stdout.fileno()
- orig_so = os.dup(sys.stdout.fileno())
- os.dup2(pout.fileno(), so)
import pstats
- p = pstats.Stats(fn)
+ p = pstats.Stats(fn, stream=pout)
p.sort_stats('time')
p.print_stats()
p.print_callers()
p.sort_stats('cumulative')
p.print_stats()
- os.dup2(orig_so, so)
pout.flush()
pout.close()