Mercurial > hg-stable
changeset 15920:885e0c71db9b
mq: turn changeset draft on qfinish (except if qparent is secret)
As mq automatically sets changesets as secret, it should make them draft when he
is done with it. We do not move them automatically to draft when we detect that
something else have also set them as secret through their parents.
author | Pierre-Yves David <pierre-yves.david@logilab.fr> |
---|---|
date | Wed, 18 Jan 2012 17:06:59 +0100 |
parents | 69e792cf7851 |
children | 92e455f2866c |
files | hgext/mq.py |
diffstat | 1 files changed, 17 insertions(+), 5 deletions(-) [+] |
line wrap: on
line diff
--- a/hgext/mq.py Wed Jan 18 16:52:26 2012 +0100 +++ b/hgext/mq.py Wed Jan 18 17:06:59 2012 +0100 @@ -46,7 +46,7 @@ from mercurial.node import bin, hex, short, nullid, nullrev from mercurial.lock import release from mercurial import commands, cmdutil, hg, scmutil, util, revset -from mercurial import repair, extensions, url, error +from mercurial import repair, extensions, url, error, phases from mercurial import patch as patchmod import os, re, errno, shutil @@ -750,6 +750,7 @@ for p in patches: os.unlink(self.join(p)) + qfinished = [] if numrevs: qfinished = self.applied[:numrevs] del self.applied[:numrevs] @@ -776,6 +777,7 @@ self.parseseries() self.seriesdirty = True + return [entry.node for entry in qfinished] def _revpatches(self, repo, revs): firstrev = repo[self.applied[0].node].rev() @@ -803,7 +805,11 @@ def finish(self, repo, revs): patches = self._revpatches(repo, sorted(revs)) - self._cleanup(patches, len(patches)) + qfinished = self._cleanup(patches, len(patches)) + if qfinished: + oldqbase = repo[qfinished[0]] + if oldqbase.p1().phase() < phases.secret: + phases.advanceboundary(repo, phases.draft, [oldqbase.node()]) def delete(self, repo, patches, opts): if not patches and not opts.get('rev'): @@ -2918,9 +2924,15 @@ revs = scmutil.revrange(repo, revrange) if repo['.'].rev() in revs and repo[None].files(): ui.warn(_('warning: uncommitted changes in the working directory\n')) - - q.finish(repo, revs) - q.savedirty() + # queue.finish may changes phases but leave the responsability to lock the + # repo to the caller to avoid deadlock with wlock. This command code is + # responsability for this locking. + lock = repo.lock() + try: + q.finish(repo, revs) + q.savedirty() + finally: + lock.release() return 0 @command("qqueue",