filelog: add a comment explaining a fast path in filerevisioncopied()
authorSimon Sapin <simon.sapin@octobus.net>
Thu, 06 Jan 2022 12:46:10 +0100
changeset 48574 5026a0d37526
parent 48573 faa243f345cc
child 48575 e91aa800ae5b
filelog: add a comment explaining a fast path in filerevisioncopied() Differential Revision: https://phab.mercurial-scm.org/D11964
mercurial/utils/storageutil.py
--- a/mercurial/utils/storageutil.py	Tue Dec 21 21:26:14 2021 +0100
+++ b/mercurial/utils/storageutil.py	Thu Jan 06 12:46:10 2022 +0100
@@ -112,6 +112,13 @@
     2-tuple of the source filename and node.
     """
     if store.parents(node)[0] != sha1nodeconstants.nullid:
+        # When creating a copy or move we set filelog parents to null,
+        # because contents are probably unrelated and making a delta
+        # would not be useful.
+        # Conversely, if filelog p1 is non-null we know
+        # there is no copy metadata.
+        # In the presence of merges, this reasoning becomes invalid
+        # if we reorder parents. See tests/test-issue6528.t.
         return False
 
     meta = parsemeta(store.revision(node))[0]