comparison mercurial/revlog.py @ 40625:39369475445c

revlog: use single file handle when de-inlining revlog _getsegmentforrevs() will eventually call into _datareadfp() to resolve a file handle to read revision data. If no file handle is passed into _getsegmentforrevs(), it opens a new one. Explicit is better than implicit. This commit changes _enforceinlinesize() to open a file handle explicitly when converting inline revlogs to split revlogs and to pass this file handle into _getsegmentforrevs(). I haven't measured, but this change should improve performance, as we no longer reopen the revlog for reading for every revision in the revlog when it is converted from inline to split. Instead, we open it at most once and use it for the duration of the operation. That being said, I /think/ the chunk cache may mitigate the number of file opens required. Differential Revision: https://phab.mercurial-scm.org/D5265
author Gregory Szorc <gregory.szorc@gmail.com>
date Tue, 30 Oct 2018 16:50:05 -0700
parents 4fe63b573791
children 87a872555e90
comparison
equal deleted inserted replaced
40624:66adfd58cb77 40625:39369475445c
1730 1730
1731 if fp: 1731 if fp:
1732 fp.flush() 1732 fp.flush()
1733 fp.close() 1733 fp.close()
1734 1734
1735 with self._datafp('w') as df: 1735 with self._indexfp('r') as ifh, self._datafp('w') as dfh:
1736 for r in self: 1736 for r in self:
1737 df.write(self._getsegmentforrevs(r, r)[1]) 1737 dfh.write(self._getsegmentforrevs(r, r, df=ifh)[1])
1738 1738
1739 with self._indexfp('w') as fp: 1739 with self._indexfp('w') as fp:
1740 self.version &= ~FLAG_INLINE_DATA 1740 self.version &= ~FLAG_INLINE_DATA
1741 self._inline = False 1741 self._inline = False
1742 io = self._io 1742 io = self._io