##// END OF EJS Templates
merge: don't try to merge subrepos twice (issue4988)...
Siddharth Agarwal -
r27951:6bce6d92 stable
parent child Browse files
Show More
@@ -1464,6 +1464,34 def update(repo, node, branchmerge, forc
1464 actionbyfile, diverge, renamedelete = calculateupdates(
1464 actionbyfile, diverge, renamedelete = calculateupdates(
1465 repo, wc, p2, pas, branchmerge, force, mergeancestor,
1465 repo, wc, p2, pas, branchmerge, force, mergeancestor,
1466 followcopies, matcher=matcher)
1466 followcopies, matcher=matcher)
1467
1468 # Prompt and create actions. Most of this is in the resolve phase
1469 # already, but we can't handle .hgsubstate in filemerge or
1470 # subrepo.submerge yet so we have to keep prompting for it.
1471 if '.hgsubstate' in actionbyfile:
1472 f = '.hgsubstate'
1473 m, args, msg = actionbyfile[f]
1474 if m == 'cd':
1475 if repo.ui.promptchoice(
1476 _("local changed %s which remote deleted\n"
1477 "use (c)hanged version or (d)elete?"
1478 "$$ &Changed $$ &Delete") % f, 0):
1479 actionbyfile[f] = ('r', None, "prompt delete")
1480 elif f in p1:
1481 actionbyfile[f] = ('am', None, "prompt keep")
1482 else:
1483 actionbyfile[f] = ('a', None, "prompt keep")
1484 elif m == 'dc':
1485 f1, f2, fa, move, anc = args
1486 flags = p2[f2].flags()
1487 if repo.ui.promptchoice(
1488 _("remote changed %s which local deleted\n"
1489 "use (c)hanged version or leave (d)eleted?"
1490 "$$ &Changed $$ &Deleted") % f, 0) == 0:
1491 actionbyfile[f] = ('g', (flags, False), "prompt recreating")
1492 else:
1493 del actionbyfile[f]
1494
1467 # Convert to dictionary-of-lists format
1495 # Convert to dictionary-of-lists format
1468 actions = dict((m, []) for m in 'a am f g cd dc r dm dg m e k'.split())
1496 actions = dict((m, []) for m in 'a am f g cd dc r dm dg m e k'.split())
1469 for f, (m, args, msg) in actionbyfile.iteritems():
1497 for f, (m, args, msg) in actionbyfile.iteritems():
@@ -1479,33 +1507,6 def update(repo, node, branchmerge, forc
1479 else:
1507 else:
1480 _checkcollision(repo, wc.manifest(), actions)
1508 _checkcollision(repo, wc.manifest(), actions)
1481
1509
1482 # Prompt and create actions. Most of this is in the resolve phase
1483 # already, but we can't handle .hgsubstate in filemerge or
1484 # subrepo.submerge yet so we have to keep prompting for it.
1485 for f, args, msg in sorted(actions['cd']):
1486 if f != '.hgsubstate':
1487 continue
1488 if repo.ui.promptchoice(
1489 _("local changed %s which remote deleted\n"
1490 "use (c)hanged version or (d)elete?"
1491 "$$ &Changed $$ &Delete") % f, 0):
1492 actions['r'].append((f, None, "prompt delete"))
1493 elif f in p1:
1494 actions['am'].append((f, None, "prompt keep"))
1495 else:
1496 actions['a'].append((f, None, "prompt keep"))
1497
1498 for f, args, msg in sorted(actions['dc']):
1499 if f != '.hgsubstate':
1500 continue
1501 f1, f2, fa, move, anc = args
1502 flags = p2[f2].flags()
1503 if repo.ui.promptchoice(
1504 _("remote changed %s which local deleted\n"
1505 "use (c)hanged version or leave (d)eleted?"
1506 "$$ &Changed $$ &Deleted") % f, 0) == 0:
1507 actions['g'].append((f, (flags, False), "prompt recreating"))
1508
1509 # divergent renames
1510 # divergent renames
1510 for f, fl in sorted(diverge.iteritems()):
1511 for f, fl in sorted(diverge.iteritems()):
1511 repo.ui.warn(_("note: possible conflict - %s was renamed "
1512 repo.ui.warn(_("note: possible conflict - %s was renamed "
General Comments 0
You need to be logged in to leave comments. Login now