102
101
class RemoteBranch(Branch):
103
def __init__(self, baseurl, find_root=True, lock_mode='r'):
102
def __init__(self, baseurl, find_root=True):
104
103
"""Create new proxy for a remote branch."""
105
if lock_mode not in ('', 'r'):
106
raise BzrError('lock mode %r is not supported for remote branches'
110
105
self.baseurl = _find_remote_root(baseurl)
112
107
self.baseurl = baseurl
113
108
self._check_format()
110
self.inventory_store = RemoteStore(baseurl + '/.bzr/inventory-store/')
111
self.text_store = RemoteStore(baseurl + '/.bzr/text-store/')
112
self.revision_store = RemoteStore(baseurl + '/.bzr/revision-store/')
115
114
def __str__(self):
116
return '%s(%r)' % (self.__class__.__name__, self.baseurl)
115
b = getattr(self, 'baseurl', 'undefined')
116
return '%s(%r)' % (self.__class__.__name__, b)
118
118
__repr__ = __str__
122
122
raise BzrError("file mode %r not supported for remote branches" % mode)
123
123
return get_url(self.baseurl + '/.bzr/' + filename, False)
125
def _need_readlock(self):
126
# remote branch always safe for read
129
def _need_writelock(self):
130
raise BzrError("cannot get write lock on HTTP remote branch")
127
# no locking for remote branches yet
130
def lock_write(self):
131
from errors import LockError
132
raise LockError("write lock not supported for remote branch %s"
132
139
def relpath(self, path):
133
140
if not path.startswith(self.baseurl):
136
143
pl = len(self.baseurl)
137
144
return path[pl:].lstrip('/')
139
147
def get_revision(self, revision_id):
140
from revision import Revision
141
revf = get_url(self.baseurl + '/.bzr/revision-store/' + revision_id,
143
r = Revision.read_xml(revf)
148
from bzrlib.revision import Revision
149
from bzrlib.xml import unpack_xml
150
revf = self.revision_store[revision_id]
151
r = unpack_xml(Revision, revf)
144
152
if r.revision_id != revision_id:
145
153
raise BzrCheckError('revision stored as {%s} actually contains {%s}'
146
154
% (revision_id, r.revision_id))
158
class RemoteStore(object):
159
def __init__(self, baseurl):
160
self._baseurl = baseurl
163
def _path(self, name):
165
raise ValueError('invalid store id', name)
166
return self._baseurl + '/' + name
168
def __getitem__(self, fileid):
169
p = self._path(fileid)
170
return get_url(p, compressed=True)
150
173
def simple_walk():
151
from revision import Revision
152
from branch import Branch
153
from inventory import Inventory
174
"""For experimental purposes, traverse many parts of a remote branch"""
175
from bzrlib.revision import Revision
176
from bzrlib.branch import Branch
177
from bzrlib.inventory import Inventory
178
from bzrlib.xml import unpack_xml
158
183
print 'read history'
159
184
history = get_url('/.bzr/revision-history').readlines()
168
193
rev_f = get_url('/.bzr/revision-store/%s' % rev_id,
171
rev = Revision.read_xml(rev_f)
196
rev = unpack_xml(Revision, rev_f)
172
197
print rev.message
173
198
inv_id = rev.inventory_id
174
199
if inv_id not in got_invs:
187
212
print ' fetch %s text {%s}' % (path, text_id)
188
213
text_f = get_url('/.bzr/text-store/%s' % text_id,
190
got_texts.add(text_id)
215
got_texts[text_id] = True
217
got_invs.add[inv_id] = True