Mercurial > hg-stable
changeset 4862:cba10652a901
mq: improve qclone error handling when patch directory is not a repository.
author | Brendan Cully <brendan@kublai.com> |
---|---|
date | Tue, 10 Jul 2007 09:52:32 -0700 |
parents | 01ba62729c60 |
children | 6dc0094c0827 |
files | hgext/mq.py tests/test-mq tests/test-mq.out |
diffstat | 3 files changed, 19 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- a/hgext/mq.py Mon Jul 09 22:35:10 2007 -0700 +++ b/hgext/mq.py Tue Jul 10 09:52:32 2007 -0700 @@ -1478,11 +1478,20 @@ Source patch repository is looked for in <src>/.hg/patches by default. Use -p <url> to change. + + The patch directory must be a nested mercurial repository, as + would be created by qinit -c. ''' cmdutil.setremoteconfig(ui, opts) if dest is None: dest = hg.defaultdest(source) sr = hg.repository(ui, ui.expandpath(source)) + patchdir = opts['patches'] or (sr.url() + '/.hg/patches') + try: + pr = hg.repository(ui, patchdir) + except hg.RepoError: + raise util.Abort(_('versioned patch repository not found' + ' (see qinit -c)')) qbase, destrev = None, None if sr.local(): if sr.mq.applied:
--- a/tests/test-mq Mon Jul 09 22:35:10 2007 -0700 +++ b/tests/test-mq Tue Jul 10 09:52:32 2007 -0700 @@ -368,10 +368,17 @@ echo foo > foo hg add foo hg ci -m 'add foo' -hg qinit -c +hg qinit hg qnew patch1 echo bar >> foo hg qrefresh -m 'change foo' +cd .. + +# repo with unversioned patch dir +hg qclone qclonesource failure + +cd qclonesource +hg qinit -c hg qci -m checkpoint qlog cd ..