~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/remote.py

  • Committer: Andrew Bennetts
  • Date: 2011-02-25 04:44:53 UTC
  • mto: This revision was merged to the branch mainline in revision 5695.
  • Revision ID: andrew.bennetts@canonical.com-20110225044453-2ig5en0bi0uukre6
Fix final bzr-loom test by adding RemoteBranch.heads_to_fetch that can ask the remote branch for the heads to fetch (but uses the cheaper default logic if it knows the remote format has an identical heads_to_fetch as Branch.heads_to_fetch).

Show diffs side-by-side

added added

removed removed

Lines of Context:
2194
2194
        self._ensure_real()
2195
2195
        return self._custom_format.supports_set_append_revisions_only()
2196
2196
 
 
2197
    def _native_heads_to_fetch(self):
 
2198
        # If the branch format is a metadir format *and* its heads_to_fetch
 
2199
        # implementation is not overridden vs the base class, we can use the
 
2200
        # base class logic rather than use the heads_to_fetch RPC.  This is
 
2201
        # usually free in terms of net round trips, as the last-revision and
 
2202
        # tags info fetched is cached and would be fetched anyway.
 
2203
        self._ensure_real()
 
2204
        if isinstance(self._custom_format, branch.BranchFormatMetadir):
 
2205
            branch_class = self._custom_format._branch_class()
 
2206
            heads_to_fetch_impl = branch_class.heads_to_fetch.im_func
 
2207
            if heads_to_fetch_impl is branch.Branch.heads_to_fetch.im_func:
 
2208
                return True
 
2209
        return False
2197
2210
 
2198
2211
class RemoteBranch(branch.Branch, _RpcHelper, lock._RelockDebugMixin):
2199
2212
    """Branch stored on a server accessed by HPSS RPC.
2781
2794
        self._ensure_real()
2782
2795
        return self._real_branch.set_push_location(location)
2783
2796
 
 
2797
    def heads_to_fetch(self):
 
2798
        if self._format._native_heads_to_fetch():
 
2799
            return branch.Branch.heads_to_fetch(self)
 
2800
        medium = self._client._medium
 
2801
        if medium._is_remote_before((2, 4)):
 
2802
            return self._vfs_heads_to_fetch()
 
2803
        try:
 
2804
            return self._rpc_heads_to_fetch()
 
2805
        except errors.UnknownSmartMethod:
 
2806
            medium._remember_remote_is_before((2, 4))
 
2807
            return self._vfs_heads_to_fetch()
 
2808
 
 
2809
    def _rpc_heads_to_fetch(self):
 
2810
        response = self._call('Branch.heads_to_fetch', self._remote_path())
 
2811
        if len(response) != 2:
 
2812
            raise errors.UnexpectedSmartServerResponse(response)
 
2813
        must_fetch, if_present_fetch = response
 
2814
        return set(must_fetch), set(if_present_fetch)
 
2815
 
 
2816
    def _vfs_heads_to_fetch(self):
 
2817
        self._ensure_real()
 
2818
        return self._real_branch.heads_to_fetch()
 
2819
 
2784
2820
 
2785
2821
class RemoteConfig(object):
2786
2822
    """A Config that reads and writes from smart verbs.