/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to remote.py

Share more code between local and remote classes, support opening remote branches.

Show diffs side-by-side

added added

removed removed

Lines of Context:
23
23
from bzrlib.trace import info
24
24
from bzrlib.transport import Transport
25
25
 
26
 
from bzrlib.plugins.git import lazy_check_versions
27
 
lazy_check_versions()
28
 
 
 
26
from bzrlib.plugins.git import git
29
27
from bzrlib.plugins.git.branch import GitBranch
30
 
from bzrlib.plugins.git.errors import NoSuchRef
31
 
from bzrlib.plugins.git.dir import GitDir
32
28
from bzrlib.plugins.git.foreign import ForeignBranch
33
29
from bzrlib.plugins.git.repository import GitFormat, GitRepository
34
30
 
35
 
import os
36
 
import tempfile
37
31
import urllib
38
32
import urlparse
39
33
 
40
 
import dulwich as git
41
 
from dulwich.pack import PackData, Pack, PackIndex
42
 
 
43
 
# Don't run any tests on GitSmartTransport as it is not intended to be 
44
 
# a full implementation of Transport
45
 
def get_test_permutations():
46
 
    return []
47
 
 
48
34
 
49
35
class GitSmartTransport(Transport):
50
36
 
54
40
        assert scheme == "git"
55
41
        hostport, self._path = urllib.splithost(loc)
56
42
        (self._host, self._port) = urllib.splitnport(hostport, git.protocol.TCP_GIT_PORT)
57
 
        self._client = _client
58
 
 
59
 
    def _get_client(self):
60
 
        if self._client is not None:
61
 
            ret = self._client
62
 
            self._client = None
63
 
            return ret
64
 
        return git.client.TCPGitClient(self._host, self._port, 
65
 
            capabilities=["multi_ack", "side-band-64k", "ofs-delta", "side-band"])
 
43
        if _client is not None:
 
44
            self._client = _client
 
45
        else:
 
46
            self._client = git.client.TCPGitClient(self._host, self._port)
66
47
 
67
48
    def fetch_pack(self, determine_wants, graph_walker, pack_data, progress=None):
68
49
        if progress is None:
69
50
            def progress(text):
70
51
                info("git: %s" % text)
71
 
        self._get_client().fetch_pack(self._path, determine_wants, 
72
 
            graph_walker, pack_data, progress)
 
52
        self._client.fetch_pack(self._path, determine_wants, graph_walker, 
 
53
                pack_data, progress)
73
54
 
74
55
    def get(self, path):
75
56
        raise NoSuchFile(path)
76
57
 
77
 
    def abspath(self, relpath):
78
 
        return urlutils.join(self.base, relpath)
79
 
 
80
58
    def clone(self, offset=None):
81
59
        """See Transport.clone()."""
82
60
        if offset is None:
87
65
        return GitSmartTransport(newurl, self._client)
88
66
 
89
67
 
90
 
class RemoteGitDir(GitDir):
 
68
class RemoteGitDir(BzrDir):
91
69
 
92
70
    def __init__(self, transport, lockfiles, format):
93
71
        self._format = format
95
73
        self.transport = transport
96
74
        self._lockfiles = lockfiles
97
75
 
 
76
    def is_supported(self):
 
77
        return True
 
78
 
98
79
    def open_repository(self):
99
80
        return RemoteGitRepository(self, self._lockfiles)
100
81
 
101
 
    def open_branch(self, _unsupported=False):
 
82
    def open_branch(self):
102
83
        repo = self.open_repository()
103
84
        # TODO: Support for multiple branches in one bzrdir in bzrlib!
104
85
        return RemoteGitBranch(self, repo, "HEAD", self._lockfiles)
106
87
    def open_workingtree(self):
107
88
        raise NotLocalUrl(self.transport.base)
108
89
 
109
 
 
110
 
class EmptyObjectStoreIterator(dict):
111
 
 
112
 
    def iterobjects(self):
113
 
        return []
114
 
 
115
 
 
116
 
class TemporaryPackIterator(Pack):
117
 
 
118
 
    def __init__(self, path, resolve_ext_ref):
119
 
        self.resolve_ext_ref = resolve_ext_ref
120
 
        super(TemporaryPackIterator, self).__init__(path)
121
 
 
122
 
    @property
123
 
    def idx(self):
124
 
        if self._idx is None:
125
 
            self._data.create_index_v2(self._idx_path, self.resolve_ext_ref)
126
 
            self._idx = PackIndex(self._idx_path)
127
 
        return self._idx
128
 
 
129
 
    def __del__(self):
130
 
        os.remove(self._data_path)
131
 
        os.remove(self._idx_path)
 
90
    def cloning_metadir(self, stacked=False):
 
91
        """Produce a metadir suitable for cloning with."""
 
92
        if stacked:
 
93
            return bzrlib.bzrdir.format_registry.make_bzrdir("1.6.1-rich-root")
 
94
        else:
 
95
            return bzrlib.bzrdir.format_registry.make_bzrdir("rich-root-pack")
132
96
 
133
97
 
134
98
class RemoteGitRepository(GitRepository):
136
100
    def __init__(self, gitdir, lockfiles):
137
101
        GitRepository.__init__(self, gitdir, lockfiles)
138
102
 
139
 
    def fetch_pack(self, determine_wants, graph_walker, pack_data, 
140
 
                   progress=None):
141
 
        self._transport.fetch_pack(determine_wants, graph_walker, pack_data, 
142
 
            progress)
143
 
 
144
 
    def fetch_objects(self, determine_wants, graph_walker, resolve_ext_ref, progress=None):
145
 
        fd, path = tempfile.mkstemp(suffix=".pack")
146
 
        self.fetch_pack(determine_wants, graph_walker, lambda x: os.write(fd, x), progress)
147
 
        os.close(fd)
148
 
        if os.path.getsize(path) == 0:
149
 
            return EmptyObjectStoreIterator()
150
 
        return TemporaryPackIterator(path[:-len(".pack")], resolve_ext_ref)
 
103
    def fetch_pack(self, determine_wants, graph_walker, pack_data):
 
104
        self._transport.fetch_pack(determine_wants, graph_walker, pack_data)
151
105
 
152
106
 
153
107
class RemoteGitBranch(GitBranch):
154
108
 
155
109
    def __init__(self, bzrdir, repository, name, lockfiles):
156
110
        def determine_wants(heads):
157
 
            if not name in heads:
158
 
                raise NoSuchRef(name)
159
111
            self._ref = heads[name]
160
112
        bzrdir.root_transport.fetch_pack(determine_wants, None, lambda x: None, 
161
113
                             lambda x: mutter("git: %s" % x))
162
114
        super(RemoteGitBranch, self).__init__(bzrdir, repository, name, self._ref, lockfiles)
163
115
 
164
116
    def last_revision(self):
165
 
        return self.mapping.revision_id_foreign_to_bzr(self._ref)
166
 
 
167
 
    def _synchronize_history(self, destination, revision_id):
168
 
        """See Branch._synchronize_history()."""
169
 
        destination.generate_revision_history(self.last_revision())
170
 
 
 
117
        return self._ref