~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/remotebranch.py

  • Committer: Martin Pool
  • Date: 2005-05-11 06:20:05 UTC
  • Revision ID: mbp@sourcefrog.net-20050511062005-297af3451635dae0
- Don't lose first line of command help!

Show diffs side-by-side

added added

removed removed

Lines of Context:
25
25
 
26
26
 
27
27
import gzip
 
28
from sets import Set
28
29
from cStringIO import StringIO
29
30
import urllib2
30
31
 
99
100
 
100
101
 
101
102
class RemoteBranch(Branch):
102
 
    def __init__(self, baseurl, find_root=True):
 
103
    def __init__(self, baseurl, find_root=True, lock_mode='r'):
103
104
        """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'
 
107
                           % lock_mode)
 
108
 
104
109
        if find_root:
105
110
            self.baseurl = _find_remote_root(baseurl)
106
111
        else:
107
112
            self.baseurl = baseurl
108
113
            self._check_format()
109
114
 
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/')
113
 
 
114
115
    def __str__(self):
115
 
        b = getattr(self, 'baseurl', 'undefined')
116
 
        return '%s(%r)' % (self.__class__.__name__, b)
 
116
        return '%s(%r)' % (self.__class__.__name__, self.baseurl)
117
117
 
118
118
    __repr__ = __str__
119
119
 
122
122
            raise BzrError("file mode %r not supported for remote branches" % mode)
123
123
        return get_url(self.baseurl + '/.bzr/' + filename, False)
124
124
 
125
 
 
126
 
    def lock_read(self):
127
 
        # no locking for remote branches yet
128
 
        pass
129
 
 
130
 
    def lock_write(self):
131
 
        from errors import LockError
132
 
        raise LockError("write lock not supported for remote branch %s"
133
 
                        % self.baseurl)
134
 
 
135
 
    def unlock(self):
136
 
        pass
137
 
    
 
125
    def _need_readlock(self):
 
126
        # remote branch always safe for read
 
127
        pass
 
128
 
 
129
    def _need_writelock(self):
 
130
        raise BzrError("cannot get write lock on HTTP remote branch")
138
131
 
139
132
    def relpath(self, path):
140
133
        if not path.startswith(self.baseurl):
152
145
            raise BzrCheckError('revision stored as {%s} actually contains {%s}'
153
146
                                % (revision_id, r.revision_id))
154
147
        return r
155
 
 
156
 
 
157
 
class RemoteStore(object):
158
 
    def __init__(self, baseurl):
159
 
        self._baseurl = baseurl
160
 
        
161
 
 
162
 
    def _path(self, name):
163
 
        if '/' in name:
164
 
            raise ValueError('invalid store id', name)
165
 
        return self._baseurl + '/' + name
166
 
        
167
 
    def __getitem__(self, fileid):
168
 
        p = self._path(fileid)
169
 
        return get_url(p, compressed=True)
170
148
    
171
149
 
172
150
def simple_walk():
173
 
    """For experimental purposes, traverse many parts of a remote branch"""
174
151
    from revision import Revision
175
152
    from branch import Branch
176
153
    from inventory import Inventory
177
154
 
178
 
    got_invs = {}
179
 
    got_texts = {}
 
155
    got_invs = Set()
 
156
    got_texts = Set()
180
157
 
181
158
    print 'read history'
182
159
    history = get_url('/.bzr/revision-history').readlines()
210
187
                print '  fetch %s text {%s}' % (path, text_id)
211
188
                text_f = get_url('/.bzr/text-store/%s' % text_id,
212
189
                                 compressed=True)
213
 
                got_texts[text_id] = True
 
190
                got_texts.add(text_id)
214
191
 
215
 
            got_invs.add[inv_id] = True
 
192
            got_invs.add(inv_id)
216
193
 
217
194
        print '----'
218
195