Comments
Patch
@@ -4766,6 +4766,7 @@
"""
if opts.get('bookmark'):
+ ui.setconfig('bookmarks', 'pushing', opts['bookmark'])
for b in opts['bookmark']:
# translate -B options to -r so changesets get pushed
if b in repo._bookmarks:
@@ -219,7 +219,8 @@
unsynced = inc and set([None]) or set()
return {None: (oldheads, newheads, unsynced)}
-def checkheads(repo, remote, outgoing, remoteheads, newbranch=False, inc=False):
+def checkheads(repo, remote, outgoing, remoteheads, newbranch=False, inc=False,
+ newbookmarks=[]):
"""Check that a push won't add any outgoing head
raise Abort error and display ui message as needed.
@@ -259,6 +260,9 @@
lctx, rctx = repo[bm], repo[rnode]
if bookmarks.validdest(repo, rctx, lctx):
bookmarkedheads.add(lctx.node())
+ else:
+ if bm in newbookmarks:
+ bookmarkedheads.add(repo[bm].node())
# 3. Check for new heads.
# If there are more heads after the push than before, a suitable
@@ -1806,9 +1806,10 @@
raise util.Abort(_(mst)
% (ctx.troubles()[0],
ctx))
+ newbm = self.ui.configlist('bookmarks', 'pushing')
discovery.checkheads(unfi, remote, outgoing,
remoteheads, newbranch,
- bool(inc))
+ bool(inc), newbm)
# create a changegroup from local
if revs is None and not outgoing.excluded:
@@ -392,4 +392,23 @@
updating bookmark @ failed!
exporting bookmark add-foo
+pushing a new bookmark on a new head does not require -f if -B is specified
+
+ $ hg up -q X
+ $ hg book W
+ $ echo c5 > f2
+ $ hg ci -Am5
+ created new head
+ $ hg push -B W
+ pushing to http://localhost:$HGPORT/
+ searching for changes
+ remote: adding changesets
+ remote: adding manifests
+ remote: adding file changes
+ remote: added 1 changesets with 1 changes to 1 files (+1 heads)
+ updating bookmark @ failed!
+ exporting bookmark W
+ $ hg -R ../b id -r W
+ cc978a373a53 tip W
+
$ cd ..