# HG changeset patch # User Matt Mackall # Date 1286653820 18000 # Node ID 545ec17750210b31b51261092c0f010fc9376e32 # Parent 8269af351a64b186a575fdd492e19e28e9575397 merge: handle no file parent in backwards merge (issue2364) diff -r 8269af351a64 -r 545ec1775021 mercurial/merge.py --- a/mercurial/merge.py Sat Oct 09 14:52:58 2010 -0500 +++ b/mercurial/merge.py Sat Oct 09 14:50:20 2010 -0500 @@ -276,7 +276,10 @@ fcl = wctx[f] fco = mctx[f2] if mctx == actx: # backwards, use working dir parent as ancestor - fca = fcl.parents()[0] + if fcl.parents(): + fca = fcl.parents()[0] + else: + fca = repo.filectx(f, fileid=nullrev) else: fca = fcl.ancestor(fco, actx) if not fca: diff -r 8269af351a64 -r 545ec1775021 tests/test-merge1.t --- a/tests/test-merge1.t Sat Oct 09 14:52:58 2010 -0500 +++ b/tests/test-merge1.t Sat Oct 09 14:50:20 2010 -0500 @@ -166,3 +166,11 @@ +This is file b33 $ hg status M b + +Test for issue2364 + + $ hg up -qC . + $ hg rm b + $ hg ci -md + $ hg revert -r -2 b + $ hg up -q -- -2