# HG changeset patch # User Vadim Gelfer # Date 2006-08-08 23:40:08 # Node ID 0496cfb052432a5877d7c23456b92509b717ef26 # Parent f362222cb8f84aa0d2e1a168fffedf02044ce12f fetch: lock repo across pull and commit diff --git a/hgext/fetch.py b/hgext/fetch.py --- a/hgext/fetch.py +++ b/hgext/fetch.py @@ -46,7 +46,7 @@ def fetch(ui, repo, source='default', ** message = (commands.logmessage(opts) or (_('Automated merge with %s') % other.url())) n = repo.commit(mod + add + rem, message, - opts['user'], opts['date'], + opts['user'], opts['date'], lock=lock, force_editor=opts.get('force_editor')) ui.status(_('new changeset %d:%s merges remote changes ' 'with local\n') % (repo.changelog.rev(n), @@ -61,7 +61,7 @@ def fetch(ui, repo, source='default', ** raise util.Abort(_("fetch -r doesn't work for remote repositories yet")) elif opts['rev']: revs = [other.lookup(rev) for rev in opts['rev']] - modheads = repo.pull(other, heads=revs) + modheads = repo.pull(other, heads=revs, lock=lock) return postincoming(other, modheads) parent, p2 = repo.dirstate.parents() @@ -76,7 +76,11 @@ def fetch(ui, repo, source='default', ** if len(repo.heads()) > 1: raise util.Abort(_('multiple heads in this repository ' '(use "hg heads" and "hg merge" to merge them)')) - return pull() + lock = repo.lock() + try: + return pull() + finally: + lock.release() cmdtable = { 'fetch':