# HG changeset patch # User Siddharth Agarwal # Date 2013-09-06 23:31:35 # Node ID c2e27e57d250703aa386c3d638087da1f17169d2 # Parent 79e5de2bfa8cd18e81e71fbba1a62eee15b5e354 revlog: add a fast method for getting a list of chunks This moves _chunkraw into the loop. Doing that improves revlog decompression -- in particular, manifest decompression -- significantly. For a 20 MB manifest which is the result of a > 40k delta chain, hg perfmanifest improves from 0.55 seconds to 0.49 seconds. diff --git a/mercurial/revlog.py b/mercurial/revlog.py --- a/mercurial/revlog.py +++ b/mercurial/revlog.py @@ -853,6 +853,28 @@ class revlog(object): def _chunk(self, rev): return decompress(self._chunkraw(rev, rev)) + def _chunks(self, revs): + '''faster version of [self._chunk(rev) for rev in revs] + + Assumes that revs is in ascending order.''' + start = self.start + length = self.length + inline = self._inline + iosize = self._io.size + getchunk = self._getchunk + + l = [] + ladd = l.append + + for rev in revs: + chunkstart = start(rev) + if inline: + chunkstart += (rev + 1) * iosize + chunklength = length(rev) + ladd(decompress(getchunk(chunkstart, chunklength))) + + return l + def _chunkbase(self, rev): return self._chunk(rev) @@ -933,7 +955,7 @@ class revlog(object): if text is None: text = str(self._chunkbase(base)) - bins = [self._chunk(r) for r in chain] + bins = self._chunks(chain) text = mdiff.patches(text, bins) text = self._checkhash(text, node, rev)