/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 bzrlib/errors.py

  • Committer: Vincent Ladeuil
  • Date: 2011-09-09 12:32:08 UTC
  • mfrom: (5050.78.4 2.2)
  • mto: (5609.48.11 2.3)
  • mto: This revision was merged to the branch mainline in revision 6134.
  • Revision ID: v.ladeuil+lp@free.fr-20110909123208-uynckga1tmvhklrr
Merge 2.2 into 2.3 resolving conflicts

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005-2010 Canonical Ltd
 
1
# Copyright (C) 2005-2011 Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
680
680
 
681
681
    _fmt = 'Path "%(path)s" is not a child of path "%(base)s"%(extra)s'
682
682
 
683
 
    internal_error = True
 
683
    internal_error = False
684
684
 
685
685
    def __init__(self, path, base, extra=None):
686
686
        BzrError.__init__(self)
713
713
       self.bzrdir = bzrdir
714
714
       PathError.__init__(self, path=path)
715
715
 
 
716
    def __repr__(self):
 
717
        return '<%s %r>' % (self.__class__.__name__, self.__dict__)
 
718
 
716
719
    def _format(self):
717
720
        # XXX: Ideally self.detail would be a property, but Exceptions in
718
721
        # Python 2.4 have to be old-style classes so properties don't work.
723
726
                    self.bzrdir.open_repository()
724
727
                except NoRepositoryPresent:
725
728
                    self.detail = ''
 
729
                except Exception:
 
730
                    # Just ignore unexpected errors.  Raising arbitrary errors
 
731
                    # during str(err) can provoke strange bugs.  Concretely
 
732
                    # Launchpad's codehosting managed to raise NotBranchError
 
733
                    # here, and then get stuck in an infinite loop/recursion
 
734
                    # trying to str() that error.  All this error really cares
 
735
                    # about that there's no working repository there, and if
 
736
                    # open_repository() fails, there probably isn't.
 
737
                    self.detail = ''
726
738
                else:
727
739
                    self.detail = ': location is a repository'
728
740
            else:
782
794
 
783
795
    _fmt = 'File "%(path)s" is not in branch %(branch_base)s.'
784
796
 
 
797
    # use PathNotChild instead
 
798
    @symbol_versioning.deprecated_method(symbol_versioning.deprecated_in((2, 3, 0)))
785
799
    def __init__(self, branch, path):
786
800
        BzrError.__init__(self)
787
801
        self.branch = branch
947
961
    # original exception is available as e.original_error
948
962
    #
949
963
    # New code should prefer to raise specific subclasses
950
 
    def __init__(self, message):
951
 
        # Python 2.5 uses a slot for StandardError.message,
952
 
        # so use a different variable name.  We now work around this in
953
 
        # BzrError.__str__, but this member name is kept for compatability.
954
 
        self.msg = message
 
964
    def __init__(self, msg):
 
965
        self.msg = msg
955
966
 
956
967
 
957
968
class LockActive(LockError):
1041
1052
class LockContention(LockError):
1042
1053
 
1043
1054
    _fmt = 'Could not acquire lock "%(lock)s": %(msg)s'
1044
 
    # TODO: show full url for lock, combining the transport and relative
1045
 
    # bits?
1046
1055
 
1047
1056
    internal_error = False
1048
1057
 
1075
1084
        self.target = target
1076
1085
 
1077
1086
 
 
1087
class LockCorrupt(LockError):
 
1088
 
 
1089
    _fmt = ("Lock is apparently held, but corrupted: %(corruption_info)s\n"
 
1090
            "Use 'bzr break-lock' to clear it")
 
1091
 
 
1092
    internal_error = False
 
1093
 
 
1094
    def __init__(self, corruption_info, file_data=None):
 
1095
        self.corruption_info = corruption_info
 
1096
        self.file_data = file_data
 
1097
 
 
1098
 
1078
1099
class LockNotHeld(LockError):
1079
1100
 
1080
1101
    _fmt = "Lock not held: %(lock)s"
1180
1201
class InvalidRevisionSpec(BzrError):
1181
1202
 
1182
1203
    _fmt = ("Requested revision: '%(spec)s' does not exist in branch:"
1183
 
            " %(branch)s%(extra)s")
 
1204
            " %(branch_url)s%(extra)s")
1184
1205
 
1185
1206
    def __init__(self, spec, branch, extra=None):
1186
1207
        BzrError.__init__(self, branch=branch, spec=spec)
 
1208
        self.branch_url = getattr(branch, 'user_url', str(branch))
1187
1209
        if extra:
1188
1210
            self.extra = '\n' + str(extra)
1189
1211
        else:
1380
1402
 
1381
1403
class WeaveParentMismatch(WeaveError):
1382
1404
 
1383
 
    _fmt = "Parents are mismatched between two revisions. %(message)s"
 
1405
    _fmt = "Parents are mismatched between two revisions. %(msg)s"
1384
1406
 
1385
1407
 
1386
1408
class WeaveInvalidChecksum(WeaveError):
1387
1409
 
1388
 
    _fmt = "Text did not match it's checksum: %(message)s"
 
1410
    _fmt = "Text did not match its checksum: %(msg)s"
1389
1411
 
1390
1412
 
1391
1413
class WeaveTextDiffers(WeaveError):
1439
1461
 
1440
1462
class VersionedFileInvalidChecksum(VersionedFileError):
1441
1463
 
1442
 
    _fmt = "Text did not match its checksum: %(message)s"
 
1464
    _fmt = "Text did not match its checksum: %(msg)s"
1443
1465
 
1444
1466
 
1445
1467
class KnitError(InternalBzrError):
1700
1722
        InvalidHttpResponse.__init__(self, path, msg)
1701
1723
 
1702
1724
 
 
1725
class HttpBoundaryMissing(InvalidHttpResponse):
 
1726
    """A multipart response ends with no boundary marker.
 
1727
 
 
1728
    This is a special case caused by buggy proxies, described in
 
1729
    <https://bugs.launchpad.net/bzr/+bug/198646>.
 
1730
    """
 
1731
 
 
1732
    _fmt = "HTTP MIME Boundary missing for %(path)s: %(msg)s"
 
1733
 
 
1734
    def __init__(self, path, msg):
 
1735
        InvalidHttpResponse.__init__(self, path, msg)
 
1736
 
 
1737
 
1703
1738
class InvalidHttpContentType(InvalidHttpResponse):
1704
1739
 
1705
1740
    _fmt = 'Invalid http Content-type "%(ctype)s" for %(path)s: %(msg)s'
1925
1960
    _fmt = "Moving the root directory is not supported at this time"
1926
1961
 
1927
1962
 
 
1963
class TransformRenameFailed(BzrError):
 
1964
 
 
1965
    _fmt = "Failed to rename %(from_path)s to %(to_path)s: %(why)s"
 
1966
 
 
1967
    def __init__(self, from_path, to_path, why, errno):
 
1968
        self.from_path = from_path
 
1969
        self.to_path = to_path
 
1970
        self.why = why
 
1971
        self.errno = errno
 
1972
 
 
1973
 
1928
1974
class BzrMoveFailedError(BzrError):
1929
1975
 
1930
1976
    _fmt = "Could not move %(from_path)s%(operator)s %(to_path)s%(extra)s"
1975
2021
        "Use --keep to not delete them, or --force to delete them regardless.")
1976
2022
 
1977
2023
    def __init__(self, tree_delta):
 
2024
        symbol_versioning.warn(symbol_versioning.deprecated_in((2, 3, 0)) %
 
2025
            "BzrRemoveChangedFilesError", DeprecationWarning, stacklevel=2)
1978
2026
        BzrError.__init__(self)
1979
2027
        self.changes_as_text = tree_delta.get_changes_as_text()
1980
2028
        #self.paths_as_string = '\n'.join(changed_files)
1988
2036
 
1989
2037
class BzrBadParameterMissing(BzrBadParameter):
1990
2038
 
1991
 
    _fmt = "Parameter $(param)s is required but not present."
 
2039
    _fmt = "Parameter %(param)s is required but not present."
1992
2040
 
1993
2041
 
1994
2042
class BzrBadParameterUnicode(BzrBadParameter):
2834
2882
        else:
2835
2883
            more = ' ' + more
2836
2884
        import bzrlib.urlutils as urlutils
2837
 
        display_url = urlutils.unescape_for_display(
2838
 
            tree.user_url, 'ascii')
 
2885
        user_url = getattr(tree, "user_url", None)
 
2886
        if user_url is None:
 
2887
            display_url = str(tree)
 
2888
        else:
 
2889
            display_url = urlutils.unescape_for_display(user_url, 'ascii')
2839
2890
        BzrError.__init__(self, tree=tree, display_url=display_url, more=more)
2840
2891
 
2841
2892
 
 
2893
class ShelvedChanges(UncommittedChanges):
 
2894
 
 
2895
    _fmt = ('Working tree "%(display_url)s" has shelved changes'
 
2896
            ' (See bzr shelve --list).%(more)s')
 
2897
 
 
2898
 
2842
2899
class MissingTemplateVariable(BzrError):
2843
2900
 
2844
2901
    _fmt = 'Variable {%(name)s} is not available.'
2913
2970
        self.user_encoding = osutils.get_user_encoding()
2914
2971
 
2915
2972
 
 
2973
class NoSuchConfig(BzrError):
 
2974
 
 
2975
    _fmt = ('The "%(config_id)s" configuration does not exist.')
 
2976
 
 
2977
    def __init__(self, config_id):
 
2978
        BzrError.__init__(self, config_id=config_id)
 
2979
 
 
2980
 
 
2981
class NoSuchConfigOption(BzrError):
 
2982
 
 
2983
    _fmt = ('The "%(option_name)s" configuration option does not exist.')
 
2984
 
 
2985
    def __init__(self, option_name):
 
2986
        BzrError.__init__(self, option_name=option_name)
 
2987
 
 
2988
 
2916
2989
class NoSuchAlias(BzrError):
2917
2990
 
2918
2991
    _fmt = ('The alias "%(alias_name)s" does not exist.')
3134
3207
    def __init__(self, bzrdir):
3135
3208
        self.bzrdir = bzrdir
3136
3209
 
 
3210
 
 
3211
class NoWhoami(BzrError):
 
3212
 
 
3213
    _fmt = ('Unable to determine your name.\n'
 
3214
        "Please, set your name with the 'whoami' command.\n"
 
3215
        'E.g. bzr whoami "Your Name <name@example.com>"')
 
3216
 
 
3217
 
 
3218
class InvalidPattern(BzrError):
 
3219
 
 
3220
    _fmt = ('Invalid pattern(s) found. %(msg)s')
 
3221
 
 
3222
    def __init__(self, msg):
 
3223
        self.msg = msg
 
3224
 
 
3225
 
 
3226
class RecursiveBind(BzrError):
 
3227
 
 
3228
    _fmt = ('Branch "%(branch_url)s" appears to be bound to itself. '
 
3229
        'Please use `bzr unbind` to fix.')
 
3230
 
 
3231
    def __init__(self, branch_url):
 
3232
        self.branch_url = branch_url
 
3233