Mercurial > hg-stable
changeset 40145:21261fc0fb2b
perf: extract result formatting in its own function
This will make it easier to reuse in another changesets.
author | Boris Feld <boris.feld@octobus.net> |
---|---|
date | Wed, 03 Oct 2018 10:46:56 +0200 |
parents | acf560bc9b56 |
children | adfe4bb53a47 |
files | contrib/perf.py |
diffstat | 1 files changed, 14 insertions(+), 7 deletions(-) [+] |
line wrap: on
line diff
--- a/contrib/perf.py Tue Oct 02 18:54:06 2018 +0200 +++ b/contrib/perf.py Wed Oct 03 10:46:56 2018 +0200 @@ -301,12 +301,19 @@ if cstop - begin > 10 and count >= 3: break + formatone(fm, results, title=title, result=r, + displayall=displayall) + +def formatone(fm, timings, title=None, result=None, displayall=False): + + count = len(timings) + fm.startitem() if title: fm.write(b'title', b'! %s\n', title) - if r: - fm.write(b'result', b'! result: %s\n', r) + if result: + fm.write(b'result', b'! result: %s\n', result) def display(role, entry): prefix = b'' if role != b'best': @@ -318,15 +325,15 @@ fm.write(prefix + b'sys', b' sys %f', entry[2]) fm.write(prefix + b'count', b' (%s of %%d)' % role, count) fm.plain(b'\n') - results.sort() - min_val = results[0] + timings.sort() + min_val = timings[0] display(b'best', min_val) if displayall: - max_val = results[-1] + max_val = timings[-1] display(b'max', max_val) - avg = tuple([sum(x) / count for x in zip(*results)]) + avg = tuple([sum(x) / count for x in zip(*timings)]) display(b'avg', avg) - median = results[len(results) // 2] + median = timings[len(timings) // 2] display(b'median', median) # utilities for historical portability