# HG changeset patch # User Pierre-Yves David # Date 2024-07-03 10:32:57 # Node ID 21442f87f7fab25437a3ac8fe4687a4277970078 # Parent 8e24f4f86ba87db6cb462e24f285321fb474b41d mmap: only use mmap to read revlog persistent nodemap if it is safe Cf `is_mmap_safe` docstring. diff --git a/mercurial/revlogutils/nodemap.py b/mercurial/revlogutils/nodemap.py --- a/mercurial/revlogutils/nodemap.py +++ b/mercurial/revlogutils/nodemap.py @@ -74,7 +74,7 @@ def persisted_data(revlog): test_race_hook_1() try: with revlog.opener(filename) as fd: - if use_mmap: + if use_mmap and revlog.opener.is_mmap_safe(filename): try: data = util.buffer(util.mmapread(fd, data_length)) except ValueError: @@ -205,7 +205,7 @@ def persist_nodemap(tr, revlog, pending= fd.seek(target_docket.data_length) fd.write(data) if feed_data: - if use_mmap: + if use_mmap and revlog.opener.is_mmap_safe(datafile): fd.flush() new_data = util.buffer(util.mmapread(fd, new_length)) else: @@ -238,7 +238,7 @@ def persist_nodemap(tr, revlog, pending= with revlog.opener(datafile, b'w+') as fd: fd.write(data) if feed_data: - if use_mmap: + if use_mmap and revlog.opener.is_mmap_safe(datafile): fd.flush() new_data = util.buffer(util.mmapread(fd, len(data))) else: