Show More
@@ -1555,10 +1555,10 class localrepository(repo.repository): | |||
|
1555 | 1555 | if remotephases and not publishing: |
|
1556 | 1556 | # remote is new and unpublishing |
|
1557 | 1557 | subset = common + added |
|
1558 |
|
|
|
1558 | pheads, _dr = phases.analyzeremotephases(self, subset, | |
|
1559 | 1559 |
|
|
1560 |
|
|
|
1561 |
|
|
|
1560 | phases.advanceboundary(self, phases.public, pheads) | |
|
1561 | phases.advanceboundary(self, phases.draft, common + added) | |
|
1562 | 1562 | else: |
|
1563 | 1563 | # Remote is old or publishing all common changesets |
|
1564 | 1564 | # should be seen as public |
@@ -1627,72 +1627,32 class localrepository(repo.repository): | |||
|
1627 | 1627 | # don't push any phase data as there is nothing to push |
|
1628 | 1628 | else: |
|
1629 | 1629 | ana = phases.analyzeremotephases(self, fut, remotephases) |
|
1630 |
|
|
|
1630 | pheads, droots = ana | |
|
1631 | 1631 | ### Apply remote phase on local |
|
1632 | 1632 | if remotephases.get('publishing', False): |
|
1633 | 1633 | phases.advanceboundary(self, phases.public, fut) |
|
1634 | 1634 | else: # publish = False |
|
1635 | for phase, rpheads in enumerate(rheads): | |
|
1636 |
|
|
|
1635 | phases.advanceboundary(self, phases.public, pheads) | |
|
1636 | phases.advanceboundary(self, phases.draft, fut) | |
|
1637 | 1637 | ### Apply local phase on remote |
|
1638 | 1638 | # |
|
1639 | 1639 | # XXX If push failed we should use strict common and not |
|
1640 |
# future to avoi |
|
|
1640 | # future to avoid pushing phase data on unknown changeset. | |
|
1641 | 1641 | # This is to done later. |
|
1642 | 1642 | |
|
1643 | # element we want to push | |
|
1644 | topush = [] | |
|
1645 | ||
|
1646 | # store details of known remote phase of several revision | |
|
1647 | # /!\ set of index I holds rev where: I <= rev.phase() | |
|
1648 | # /!\ public phase (index 0) is ignored | |
|
1649 | remdetails = [set() for i in xrange(len(phases.allphases))] | |
|
1650 | _revs = set() | |
|
1651 | for relremphase in phases.trackedphases[::-1]: | |
|
1652 | # we iterate backward because the list alway grows | |
|
1653 | # when filled in this direction. | |
|
1654 | _revs.update(self.revs('%ln::%ln', | |
|
1655 | rroots[relremphase], fut)) | |
|
1656 | remdetails[relremphase].update(_revs) | |
|
1657 | ||
|
1658 | for phase in phases.allphases[:-1]: | |
|
1659 | # We don't need the last phase as we will never want to | |
|
1660 | # move anything to it while moving phase backward. | |
|
1661 | ||
|
1662 | # Get the list of all revs on remote which are in a | |
|
1663 | # phase higher than currently processed phase. | |
|
1664 | relremrev = remdetails[phase + 1] | |
|
1665 | ||
|
1666 | if not relremrev: | |
|
1667 | # no candidate to remote push anymore | |
|
1668 | # break before any expensive revset | |
|
1669 | break | |
|
1670 | ||
|
1671 | #dynamical inject appropriate phase symbol | |
|
1672 | phasename = phases.phasenames[phase] | |
|
1673 | odrevset = 'heads(%%ld and %s())' % phasename | |
|
1674 | outdated = self.set(odrevset, relremrev) | |
|
1675 | for od in outdated: | |
|
1676 | candstart = len(remdetails) - 1 | |
|
1677 | candstop = phase + 1 | |
|
1678 | candidateold = xrange(candstart, candstop, -1) | |
|
1679 | for oldphase in candidateold: | |
|
1680 | if od.rev() in remdetails[oldphase]: | |
|
1681 | break | |
|
1682 | else: # last one: no need to search | |
|
1683 | oldphase = phase + 1 | |
|
1684 | topush.append((oldphase, phase, od)) | |
|
1685 | ||
|
1686 | # push every needed data | |
|
1687 | for oldphase, newphase, newremotehead in topush: | |
|
1643 | # Get the list of all revs draft on remote by public here. | |
|
1644 | # XXX Beware that revset break if droots is not strictly | |
|
1645 | # XXX root we may want to ensure it is but it is costly | |
|
1646 | outdated = self.set('heads((%ln::%ln) and public())', | |
|
1647 | droots, fut) | |
|
1648 | for newremotehead in outdated: | |
|
1688 | 1649 | r = remote.pushkey('phases', |
|
1689 | 1650 | newremotehead.hex(), |
|
1690 |
str( |
|
|
1651 | str(phases.draft), | |
|
1652 | str(phases.public)) | |
|
1691 | 1653 | if not r: |
|
1692 |
self.ui.warn(_('updating |
|
|
1693 |
|
|
|
1694 | % (newremotehead, newphase, | |
|
1695 | oldphase)) | |
|
1654 | self.ui.warn(_('updating %s to public failed!\n') | |
|
1655 | % newremotehead) | |
|
1696 | 1656 | finally: |
|
1697 | 1657 | locallock.release() |
|
1698 | 1658 | finally: |
@@ -203,9 +203,10 def retractboundary(repo, targetphase, n | |||
|
203 | 203 | def listphases(repo): |
|
204 | 204 | """List phases root for serialisation over pushkey""" |
|
205 | 205 | keys = {} |
|
206 | for phase in trackedphases: | |
|
207 |
|
|
|
208 |
|
|
|
206 | value = '%i' % draft | |
|
207 | for root in repo._phaseroots[draft]: | |
|
208 | keys[hex(root)] = value | |
|
209 | ||
|
209 | 210 | if repo.ui.configbool('phases', 'publish', True): |
|
210 | 211 | # Add an extra data to let remote know we are a publishing repo. |
|
211 | 212 | # Publishing repo can't just pretend they are old repo. When pushing to |
@@ -264,20 +265,26 def analyzeremotephases(repo, subset, ro | |||
|
264 | 265 | Accept unknown element input |
|
265 | 266 | """ |
|
266 | 267 | # build list from dictionary |
|
267 | phaseroots = [[] for p in allphases] | |
|
268 | draftroots = [] | |
|
269 | nm = repo.changelog.nodemap # to filter unknown node | |
|
268 | 270 | for nhex, phase in roots.iteritems(): |
|
269 | 271 | if nhex == 'publishing': # ignore data related to publish option |
|
270 | 272 | continue |
|
271 | 273 | node = bin(nhex) |
|
272 | 274 | phase = int(phase) |
|
273 |
if |
|
|
274 | phaseroots[phase].append(node) | |
|
275 | if phase == 0: | |
|
276 | if node != nullid: | |
|
277 | msg = _('ignoring inconsistense public root from remote: %s') | |
|
278 | repo.ui.warn(msg, nhex) | |
|
279 | elif phase == 1: | |
|
280 | if node in nm: | |
|
281 | draftroots.append(node) | |
|
282 | else: | |
|
283 | msg = _('ignoring unexpected root from remote: %i %s') | |
|
284 | repo.ui.warn(msg, phase, nhex) | |
|
275 | 285 | # compute heads |
|
276 | phaseheads = [[] for p in allphases] | |
|
277 | for phase in allphases[:-1]: | |
|
278 | toproof = phaseroots[phase + 1] | |
|
279 | 286 |
|
|
280 |
|
|
|
281 |
|
|
|
282 |
return p |
|
|
287 | subset, draftroots, draftroots, subset) | |
|
288 | publicheads = [c.node() for c in revset] | |
|
289 | return publicheads, draftroots | |
|
283 | 290 |
General Comments 0
You need to be logged in to leave comments.
Login now