# HG changeset patch # User mpm@selenic.com # Date 1117831396 28800 # Node ID ccbcc4d76f81c038e8d7801b6df8b2cd9fe72ec0 # Parent 1aaa49039a6b109d589db95cd64cd24cef3e4d05 fix bad assumption about uniqueness of file versions -----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 fix bad assumption about uniqueness of file versions Mercurial had assumed that a given file hash could show up in only one changeset, and thus that the mapping from file revision to changeset was 1-to-1. But if two people perform the same edit with the same parents, we can get an identical hash in different changesets. So we've got to loosen up our uniqueness checks in addgroup and in verify. manifest hash: 5462003241e7d071ffa1741b87a59f646c9988ed -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.0 (GNU/Linux) iD8DBQFCoMDkywK+sNU5EO8RAg9PAJ9YWSknfFBoeYve/+Z5DDGGvytDkwCgoMwj kT01PcjNzGPr1/Oe5WRvulE= =HC4t -----END PGP SIGNATURE----- diff -r 1aaa49039a6b -r ccbcc4d76f81 hg --- a/hg Fri Jun 03 12:40:32 2005 -0800 +++ b/hg Fri Jun 03 12:43:16 2005 -0800 @@ -417,7 +417,6 @@ manifestchangeset[changes[0]] = n for f in changes[3]: - revisions += 1 filelinkrevs.setdefault(f, []).append(i) ui.status("checking manifests\n") @@ -468,6 +467,7 @@ fl = repo.file(f) nodes = { hg.nullid: 1 } for i in range(fl.count()): + revisions += 1 n = fl.node(i) if n not in filenodes[f]: @@ -505,10 +505,6 @@ nodes[n] = 1 # cross-check - for flr in filelinkrevs[f]: - ui.warn("changeset rev %d not in %s\n" % (flr, f)) - errors += 1 - for node in filenodes[f]: ui.warn("node %s in manifests not in %s\n" % (hg.hex(n), f)) errors += 1 diff -r 1aaa49039a6b -r ccbcc4d76f81 mercurial/hg.py --- a/mercurial/hg.py Fri Jun 03 12:40:32 2005 -0800 +++ b/mercurial/hg.py Fri Jun 03 12:43:16 2005 -0800 @@ -814,7 +814,7 @@ # pull off the changeset group self.ui.status("adding changesets\n") co = self.changelog.tip() - cn = self.changelog.addgroup(getgroup(), csmap, tr) + cn = self.changelog.addgroup(getgroup(), csmap, tr, 1) # unique changesets = self.changelog.rev(cn) - self.changelog.rev(co) # pull off the manifest group diff -r 1aaa49039a6b -r ccbcc4d76f81 mercurial/revlog.py --- a/mercurial/revlog.py Fri Jun 03 12:40:32 2005 -0800 +++ b/mercurial/revlog.py Fri Jun 03 12:43:16 2005 -0800 @@ -433,7 +433,7 @@ yield struct.pack(">l", 0) - def addgroup(self, revs, linkmapper, transaction): + def addgroup(self, revs, linkmapper, transaction, unique = 0): # given a set of deltas, add them to the revision log. the # first delta is against its parent, which should be in our # log, the rest are against the previous delta. @@ -463,7 +463,10 @@ node, p1, p2, cs = struct.unpack("20s20s20s20s", chunk[:80]) link = linkmapper(cs) if node in self.nodemap: - raise "already have %s" % hex(node[:4]) + # this can happen if two branches make the same change + if unique: + raise "already have %s" % hex(node[:4]) + continue delta = chunk[80:] if not chain: