~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/errors.py

  • Committer: Martin Pool
  • Date: 2007-04-01 06:19:16 UTC
  • mfrom: (2323.5.20 0.15-integration)
  • mto: This revision was merged to the branch mainline in revision 2390.
  • Revision ID: mbp@sourcefrog.net-20070401061916-plpgsxdf8g7gll9o
Merge 0.15 final release back to trunk, including: recommend upgrades of old workingtrees, handle multiple http redirections, some dirstate fixes, 

Show diffs side-by-side

added added

removed removed

Lines of Context:
550
550
        self.bzrdir = bzrdir_format
551
551
 
552
552
 
 
553
class IncompatibleRepositories(BzrError):
 
554
 
 
555
    _fmt = "Repository %(target)s is not compatible with repository"\
 
556
        " %(source)s"
 
557
 
 
558
    def __init__(self, source, target):
 
559
        BzrError.__init__(self, target=target, source=source)
 
560
 
 
561
 
553
562
class IncompatibleRevision(BzrError):
554
563
    
555
564
    _fmt = "Revision is not compatible with %(repo_format)s"
1285
1294
        InvalidHttpResponse.__init__(self, path, msg)
1286
1295
 
1287
1296
 
 
1297
class RedirectRequested(TransportError):
 
1298
 
 
1299
    _fmt = '%(source)s is%(permanently)s redirected to %(target)s'
 
1300
 
 
1301
    def __init__(self, source, target, is_permament=False, qual_proto=None):
 
1302
        self.source = source
 
1303
        self.target = target
 
1304
        if is_permament:
 
1305
            self.permanently = ' permanently'
 
1306
        else:
 
1307
            self.permanently = ''
 
1308
        self.is_permament = is_permament
 
1309
        self._qualified_proto = qual_proto
 
1310
        TransportError.__init__(self)
 
1311
 
 
1312
    def _requalify_url(self, url):
 
1313
        """Restore the qualified proto in front of the url"""
 
1314
        # When this exception is raised, source and target are in
 
1315
        # user readable format. But some transports may use a
 
1316
        # different proto (http+urllib:// will present http:// to
 
1317
        # the user. If a qualified proto is specified, the code
 
1318
        # trapping the exception can get the qualified urls to
 
1319
        # properly handle the redirection themself (creating a
 
1320
        # new transport object from the target url for example).
 
1321
        # But checking that the scheme of the original and
 
1322
        # redirected urls are the same can be tricky. (see the
 
1323
        # FIXME in BzrDir.open_from_transport for the unique use
 
1324
        # case so far).
 
1325
        if self._qualified_proto is None:
 
1326
            return url
 
1327
 
 
1328
        # The TODO related to NotBranchError mention that doing
 
1329
        # that kind of manipulation on the urls may not be the
 
1330
        # exception object job. On the other hand, this object is
 
1331
        # the interface between the code and the user so
 
1332
        # presenting the urls in different ways is indeed its
 
1333
        # job...
 
1334
        import urlparse
 
1335
        proto, netloc, path, query, fragment = urlparse.urlsplit(url)
 
1336
        return urlparse.urlunsplit((self._qualified_proto, netloc, path,
 
1337
                                   query, fragment))
 
1338
 
 
1339
    def get_source_url(self):
 
1340
        return self._requalify_url(self.source)
 
1341
 
 
1342
    def get_target_url(self):
 
1343
        return self._requalify_url(self.target)
 
1344
 
 
1345
 
 
1346
class TooManyRedirections(TransportError):
 
1347
 
 
1348
    _fmt = "Too many redirections"
 
1349
 
1288
1350
class ConflictsInTree(BzrError):
1289
1351
 
1290
1352
    _fmt = "Working tree has conflicts."