# HG changeset patch # User Pierre-Yves David # Date 1720002681 -7200 # Node ID c0e30a019ce14dedf4cee41146ee85a7e82e8c9b # Parent d6c895e4adc4fdd756337446954e370eddc79ff9 mmap: only use mmap to read rev-branch-cache data if it is safe Cf `is_mmap_safe` docstring. diff -r d6c895e4adc4 -r c0e30a019ce1 mercurial/branchmap.py --- a/mercurial/branchmap.py Wed Jul 03 12:26:57 2024 +0200 +++ b/mercurial/branchmap.py Wed Jul 03 12:31:21 2024 +0200 @@ -1213,11 +1213,12 @@ if self._names: try: - if repo.ui.configbool(b'storage', b'revbranchcache.mmap'): - with repo.cachevfs(_rbcrevs) as fp: + usemmap = repo.ui.configbool(b'storage', b'revbranchcache.mmap') + with repo.cachevfs(_rbcrevs) as fp: + if usemmap and repo.cachevfs.is_mmap_safe(_rbcrevs): data = util.buffer(util.mmapread(fp)) - else: - data = repo.cachevfs.read(_rbcrevs) + else: + data = fp.read() self._rbcrevs = rbcrevs(data) except (IOError, OSError) as inst: repo.ui.debug(