# HG changeset patch # User Alexis S. L. Carvalho # Date 2006-11-18 21:44:42 # Node ID 6990e499d71a0c609e184a269efcb42497dc5fa2 # Parent 9103dab960932c5b1337dc6dad361437ce9a84e9 Revert almost all of 5be434785317; add a test Because of file copies, we should update the manifest dict only after committing all files. diff --git a/mercurial/localrepo.py b/mercurial/localrepo.py --- a/mercurial/localrepo.py +++ b/mercurial/localrepo.py @@ -646,15 +646,14 @@ class localrepository(repo.repository): tr = self.transaction() # check in files - new = [] + new = {} linkrev = self.changelog.count() commit.sort() for f in commit: self.ui.note(f + "\n") try: - m1[f] = self.filecommit(f, m1, m2, linkrev, tr, changed) + new[f] = self.filecommit(f, m1, m2, linkrev, tr, changed) m1.set(f, util.is_exec(self.wjoin(f), m1.execf(f))) - new.append(f) except IOError: if use_dirstate: self.ui.warn(_("trouble committing %s!\n") % f) @@ -663,6 +662,7 @@ class localrepository(repo.repository): remove.append(f) # update manifest + m1.update(new) remove.sort() for f in remove: @@ -671,6 +671,9 @@ class localrepository(repo.repository): mn = self.manifest.add(m1, tr, linkrev, c1[0], c2[0], (new, remove)) # add changeset + new = new.keys() + new.sort() + user = user or self.ui.username() if not text or force_editor: edittext = [] diff --git a/tests/test-commit-copy b/tests/test-commit-copy new file mode 100755 --- /dev/null +++ b/tests/test-commit-copy @@ -0,0 +1,14 @@ +#!/bin/sh + +hg init dir +cd dir +echo bleh > bar +hg add bar +hg ci -m 'add bar' + +hg cp bar foo +echo >> bar +hg ci -m 'cp bar foo; change bar' + +hg debugrename foo +hg debugindex .hg/data/bar.i diff --git a/tests/test-commit-copy.out b/tests/test-commit-copy.out new file mode 100644 --- /dev/null +++ b/tests/test-commit-copy.out @@ -0,0 +1,4 @@ +foo renamed from bar:26d3ca0dfd18e44d796b564e38dd173c9668d3a9 + rev offset length base linkrev nodeid p1 p2 + 0 0 6 0 0 26d3ca0dfd18 000000000000 000000000000 + 1 6 7 1 1 d267bddd54f7 26d3ca0dfd18 000000000000