[Updated] D12093: persistent-nodemap: properly delete all nodemap files on downgrade
marmoute (Pierre-Yves David)
phabricator at mercurial-scm.org
Thu Feb 3 16:54:06 UTC 2022
Closed by commit rHGd55c4472bbb6: persistent-nodemap: properly delete all nodemap files on downgrade (authored by marmoute).
This revision was automatically updated to reflect the committed changes.
REPOSITORY
rHG Mercurial
CHANGES SINCE LAST UPDATE
https://phab.mercurial-scm.org/D12093?vs=31989&id=32048
CHANGES SINCE LAST ACTION
https://phab.mercurial-scm.org/D12093/new/
REVISION DETAIL
https://phab.mercurial-scm.org/D12093
AFFECTED FILES
mercurial/revlogutils/nodemap.py
tests/test-persistent-nodemap.t
CHANGE DETAILS
diff --git a/tests/test-persistent-nodemap.t b/tests/test-persistent-nodemap.t
--- a/tests/test-persistent-nodemap.t
+++ b/tests/test-persistent-nodemap.t
@@ -809,8 +809,6 @@
- manifest
$ ls -1 .hg/store/ | egrep '00(changelog|manifest)(\.n|-.*\.nd)'
- 00changelog-*.nd (glob)
- 00manifest-*.nd (glob)
undo.backup.00changelog.n
undo.backup.00manifest.n
$ hg debugnodemap --metadata
diff --git a/mercurial/revlogutils/nodemap.py b/mercurial/revlogutils/nodemap.py
--- a/mercurial/revlogutils/nodemap.py
+++ b/mercurial/revlogutils/nodemap.py
@@ -144,10 +144,12 @@
def delete_nodemap(tr, repo, revlog):
"""Delete nodemap data on disk for a given revlog"""
- if revlog._nodemap_file is None:
- msg = "calling persist nodemap on a revlog without the feature enabled"
- raise error.ProgrammingError(msg)
- repo.svfs.tryunlink(revlog._nodemap_file)
+ prefix = revlog.radix
+ pattern = re.compile(br"(^|/)%s(-[0-9a-f]+\.nd|\.n(\.a)?)$" % prefix)
+ dirpath = revlog.opener.dirname(revlog._indexfile)
+ for f in revlog.opener.listdir(dirpath):
+ if pattern.match(f):
+ repo.svfs.tryunlink(f)
def persist_nodemap(tr, revlog, pending=False, force=False):
To: marmoute, #hg-reviewers, Alphare
Cc: mercurial-patches
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.mercurial-scm.org/pipermail/mercurial-patches/attachments/20220203/05294d11/attachment-0002.html>
More information about the Mercurial-patches
mailing list