Mercurial > hg
changeset 22653:d94f5bec9c8e
pull: perform the todostep inside functions handling old way of pulling
This matches what is done during push.
author | Pierre-Yves David <pierre-yves.david@fb.com> |
---|---|
date | Sat, 27 Sep 2014 01:34:02 -0700 |
parents | 15bc5ea297f5 |
children | 02e0a574bcd3 |
files | mercurial/exchange.py |
diffstat | 1 files changed, 9 insertions(+), 6 deletions(-) [+] |
line wrap: on
line diff
--- a/mercurial/exchange.py Fri Sep 26 23:04:35 2014 -0700 +++ b/mercurial/exchange.py Sat Sep 27 01:34:02 2014 -0700 @@ -852,12 +852,9 @@ if (pullop.repo.ui.configbool('experimental', 'bundle2-exp', False) and pullop.remote.capable('bundle2-exp')): _pullbundle2(pullop) - if 'changegroup' in pullop.todosteps: - _pullchangeset(pullop) - if 'phases' in pullop.todosteps: - _pullphase(pullop) - if 'obsmarkers' in pullop.todosteps: - _pullobsolete(pullop) + _pullchangeset(pullop) + _pullphase(pullop) + _pullobsolete(pullop) pullop.closetransaction() finally: pullop.releasetransaction() @@ -940,6 +937,8 @@ # We delay the open of the transaction as late as possible so we # don't open transaction for nothing or you break future useful # rollback call + if 'changegroup' not in pullop.todosteps: + return pullop.todosteps.remove('changegroup') if not pullop.fetch: pullop.repo.ui.status(_("no changes found\n")) @@ -969,6 +968,8 @@ def _pullphase(pullop): # Get remote phases data from remote + if 'phases' not in pullop.todosteps: + return remotephases = pullop.remote.listkeys('phases') _pullapplyphases(pullop, remotephases) @@ -1013,6 +1014,8 @@ a new transaction have been created (when applicable). Exists mostly to allow overriding for experimentation purpose""" + if 'obsmarkers' not in pullop.todosteps: + return pullop.todosteps.remove('obsmarkers') tr = None if obsolete._enabled: