[PATCH 1 of 2] perf: add perfbdiff
Gregory Szorc
gregory.szorc at gmail.com
Sun Nov 6 07:42:27 UTC 2016
# HG changeset patch
# User Gregory Szorc <gregory.szorc at gmail.com>
# Date 1478414512 25200
# Sat Nov 05 23:41:52 2016 -0700
# Node ID e65ef545a3dcb46fe0f1798e76ea17f9f9323452
# Parent f01367faa792635ad2f7a6b175ae3252292b5121
perf: add perfbdiff
bdiff shows up a lot in profiling. I think it would be useful to have
a perf command that runs bdiff over and over so we can find hot spots.
diff --git a/contrib/perf.py b/contrib/perf.py
--- a/contrib/perf.py
+++ b/contrib/perf.py
@@ -25,6 +25,7 @@ import random
import sys
import time
from mercurial import (
+ bdiff,
changegroup,
cmdutil,
commands,
@@ -746,6 +747,30 @@ def perffncacheencode(ui, repo, **opts):
timer(d)
fm.end()
+ at command('perfbdiff', revlogopts + formatteropts, '-c|-m|FILE REV')
+def perfbdiff(ui, repo, file_, rev=None, **opts):
+ """benchmark a bdiff between a revision and its delta parent"""
+ if opts.get('changelog') or opts.get('manifest'):
+ file_, rev = None, file_
+ elif rev is None:
+ raise error.CommandError('perfbdiff', 'invalid arguments')
+
+ r = cmdutil.openrevlog(repo, 'perfbdiff', file_, opts)
+
+ node = r.lookup(rev)
+ rev = r.rev(node)
+ dp = r.deltaparent(rev)
+
+ text1 = r.revision(dp)
+ text2 = r.revision(node)
+
+ def d():
+ bdiff.bdiff(text1, text2)
+
+ timer, fm = gettimer(ui, opts)
+ timer(d)
+ fm.end()
+
@command('perfdiffwd', formatteropts)
def perfdiffwd(ui, repo, **opts):
"""Profile diff of working directory changes"""
diff --git a/tests/test-contrib-perf.t b/tests/test-contrib-perf.t
--- a/tests/test-contrib-perf.t
+++ b/tests/test-contrib-perf.t
@@ -50,6 +50,7 @@ perfstatus
perfancestorset
(no help text available)
perfannotate (no help text available)
+ perfbdiff benchmark a bdiff between a revision and its delta parent
perfbranchmap
benchmark the update of a branchmap
perfcca (no help text available)
@@ -112,6 +113,7 @@ perfstatus
$ hg perfancestors
$ hg perfancestorset 2
$ hg perfannotate a
+ $ hg perfbdiff -c 1
$ hg perfbranchmap
$ hg perfcca
$ hg perfchangegroupchangelog
More information about the Mercurial-devel
mailing list