~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/errors.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2009-04-09 23:12:55 UTC
  • mfrom: (3920.2.37 dpush)
  • Revision ID: pqm@pqm.ubuntu.com-20090409231255-o8w1g2q3igiyf8b2
(Jelmer) Add the dpush command.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005-2010 Canonical Ltd
 
1
# Copyright (C) 2005, 2006, 2007, 2008 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
636
636
        self.url = url
637
637
 
638
638
 
639
 
class UnstackableLocationError(BzrError):
640
 
 
641
 
    _fmt = "The branch '%(branch_url)s' cannot be stacked on '%(target_url)s'."
642
 
 
643
 
    def __init__(self, branch_url, target_url):
644
 
        BzrError.__init__(self)
645
 
        self.branch_url = branch_url
646
 
        self.target_url = target_url
647
 
 
648
 
 
649
639
class UnstackableRepositoryFormat(BzrError):
650
640
 
651
641
    _fmt = ("The repository '%(url)s'(%(format)s) is not a stackable format. "
702
692
# TODO: Probably this behavior of should be a common superclass
703
693
class NotBranchError(PathError):
704
694
 
705
 
    _fmt = 'Not a branch: "%(path)s"%(detail)s.'
 
695
    _fmt = 'Not a branch: "%(path)s".'
706
696
 
707
 
    def __init__(self, path, detail=None, bzrdir=None):
 
697
    def __init__(self, path):
708
698
       import bzrlib.urlutils as urlutils
709
 
       path = urlutils.unescape_for_display(path, 'ascii')
710
 
       if detail is not None:
711
 
           detail = ': ' + detail
712
 
       self.detail = detail
713
 
       self.bzrdir = bzrdir
714
 
       PathError.__init__(self, path=path)
715
 
 
716
 
    def _format(self):
717
 
        # XXX: Ideally self.detail would be a property, but Exceptions in
718
 
        # Python 2.4 have to be old-style classes so properties don't work.
719
 
        # Instead we override _format.
720
 
        if self.detail is None:
721
 
            if self.bzrdir is not None:
722
 
                try:
723
 
                    self.bzrdir.open_repository()
724
 
                except NoRepositoryPresent:
725
 
                    self.detail = ''
726
 
                else:
727
 
                    self.detail = ': location is a repository'
728
 
            else:
729
 
                self.detail = ''
730
 
        return PathError._format(self)
 
699
       self.path = urlutils.unescape_for_display(path, 'ascii')
731
700
 
732
701
 
733
702
class NoSubmitBranch(PathError):
814
783
 
815
784
 
816
785
class IncompatibleRepositories(BzrError):
817
 
    """Report an error that two repositories are not compatible.
818
 
 
819
 
    Note that the source and target repositories are permitted to be strings:
820
 
    this exception is thrown from the smart server and may refer to a
821
 
    repository the client hasn't opened.
822
 
    """
823
786
 
824
787
    _fmt = "%(target)s\n" \
825
788
            "is not compatible with\n" \
1041
1004
class LockContention(LockError):
1042
1005
 
1043
1006
    _fmt = 'Could not acquire lock "%(lock)s": %(msg)s'
 
1007
    # TODO: show full url for lock, combining the transport and relative
 
1008
    # bits?
1044
1009
 
1045
1010
    internal_error = False
1046
1011
 
1177
1142
 
1178
1143
class InvalidRevisionSpec(BzrError):
1179
1144
 
1180
 
    _fmt = ("Requested revision: '%(spec)s' does not exist in branch:"
 
1145
    _fmt = ("Requested revision: %(spec)r does not exist in branch:"
1181
1146
            " %(branch)s%(extra)s")
1182
1147
 
1183
1148
    def __init__(self, spec, branch, extra=None):
1208
1173
class DivergedBranches(BzrError):
1209
1174
 
1210
1175
    _fmt = ("These branches have diverged."
1211
 
            " Use the missing command to see how.\n"
1212
 
            "Use the merge command to reconcile them.")
 
1176
            " Use the merge command to reconcile them.")
1213
1177
 
1214
1178
    def __init__(self, branch1, branch2):
1215
1179
        self.branch1 = branch1
1263
1227
            not_ancestor_id=not_ancestor_id)
1264
1228
 
1265
1229
 
 
1230
class InstallFailed(BzrError):
 
1231
 
 
1232
    def __init__(self, revisions):
 
1233
        revision_str = ", ".join(str(r) for r in revisions)
 
1234
        msg = "Could not install revisions:\n%s" % revision_str
 
1235
        BzrError.__init__(self, msg)
 
1236
        self.revisions = revisions
 
1237
 
 
1238
 
1266
1239
class AmbiguousBase(BzrError):
1267
1240
 
1268
1241
    def __init__(self, bases):
1269
 
        symbol_versioning.warn("BzrError AmbiguousBase has been deprecated "
1270
 
            "as of bzrlib 0.8.", DeprecationWarning, stacklevel=2)
 
1242
        warn("BzrError AmbiguousBase has been deprecated as of bzrlib 0.8.",
 
1243
                DeprecationWarning)
1271
1244
        msg = ("The correct base is unclear, because %s are all equally close"
1272
1245
                % ", ".join(bases))
1273
1246
        BzrError.__init__(self, msg)
1295
1268
class BoundBranchOutOfDate(BzrError):
1296
1269
 
1297
1270
    _fmt = ("Bound branch %(branch)s is out of date with master branch"
1298
 
            " %(master)s.%(extra_help)s")
 
1271
            " %(master)s.")
1299
1272
 
1300
1273
    def __init__(self, branch, master):
1301
1274
        BzrError.__init__(self)
1302
1275
        self.branch = branch
1303
1276
        self.master = master
1304
 
        self.extra_help = ''
1305
1277
 
1306
1278
 
1307
1279
class CommitToDoubleBoundBranch(BzrError):
1923
1895
    _fmt = "Moving the root directory is not supported at this time"
1924
1896
 
1925
1897
 
1926
 
class TransformRenameFailed(BzrError):
1927
 
 
1928
 
    _fmt = "Failed to rename %(from_path)s to %(to_path)s: %(why)s"
1929
 
 
1930
 
    def __init__(self, from_path, to_path, why, errno):
1931
 
        self.from_path = from_path
1932
 
        self.to_path = to_path
1933
 
        self.why = why
1934
 
        self.errno = errno
1935
 
 
1936
 
 
1937
1898
class BzrMoveFailedError(BzrError):
1938
1899
 
1939
1900
    _fmt = "Could not move %(from_path)s%(operator)s %(to_path)s%(extra)s"
2043
2004
 
2044
2005
class BadConversionTarget(BzrError):
2045
2006
 
2046
 
    _fmt = "Cannot convert from format %(from_format)s to format %(format)s." \
2047
 
            "    %(problem)s"
 
2007
    _fmt = "Cannot convert to format %(format)s.  %(problem)s"
2048
2008
 
2049
 
    def __init__(self, problem, format, from_format=None):
 
2009
    def __init__(self, problem, format):
2050
2010
        BzrError.__init__(self)
2051
2011
        self.problem = problem
2052
2012
        self.format = format
2053
 
        self.from_format = from_format or '(unspecified)'
2054
2013
 
2055
2014
 
2056
2015
class NoDiffFound(BzrError):
2132
2091
 
2133
2092
class OutOfDateTree(BzrError):
2134
2093
 
2135
 
    _fmt = "Working tree is out of date, please run 'bzr update'.%(more)s"
 
2094
    _fmt = "Working tree is out of date, please run 'bzr update'."
2136
2095
 
2137
 
    def __init__(self, tree, more=None):
2138
 
        if more is None:
2139
 
            more = ''
2140
 
        else:
2141
 
            more = ' ' + more
 
2096
    def __init__(self, tree):
2142
2097
        BzrError.__init__(self)
2143
2098
        self.tree = tree
2144
 
        self.more = more
2145
2099
 
2146
2100
 
2147
2101
class PublicBranchOutOfDate(BzrError):
2185
2139
 
2186
2140
    def __init__(self, repo):
2187
2141
        BzrError.__init__(self)
2188
 
        self.repo_path = repo.user_url
 
2142
        self.repo_path = repo.bzrdir.root_transport.base
2189
2143
 
2190
2144
 
2191
2145
class InconsistentDelta(BzrError):
2201
2155
        self.reason = reason
2202
2156
 
2203
2157
 
2204
 
class InconsistentDeltaDelta(InconsistentDelta):
2205
 
    """Used when we get a delta that is not valid."""
2206
 
 
2207
 
    _fmt = ("An inconsistent delta was supplied: %(delta)r"
2208
 
            "\nreason: %(reason)s")
2209
 
 
2210
 
    def __init__(self, delta, reason):
2211
 
        BzrError.__init__(self)
2212
 
        self.delta = delta
2213
 
        self.reason = reason
2214
 
 
2215
 
 
2216
2158
class UpgradeRequired(BzrError):
2217
2159
 
2218
2160
    _fmt = "To use this feature you must upgrade your branch at %(path)s."
2227
2169
    _fmt = "To use this feature you must upgrade your repository at %(path)s."
2228
2170
 
2229
2171
 
2230
 
class RichRootUpgradeRequired(UpgradeRequired):
2231
 
 
2232
 
    _fmt = ("To use this feature you must upgrade your branch at %(path)s to"
2233
 
           " a format which supports rich roots.")
2234
 
 
2235
 
 
2236
2172
class LocalRequiresBoundBranch(BzrError):
2237
2173
 
2238
2174
    _fmt = "Cannot perform local-only commits on unbound branches."
2239
2175
 
2240
2176
 
 
2177
class InvalidProgressBarType(BzrError):
 
2178
 
 
2179
    _fmt = ("Environment variable BZR_PROGRESS_BAR='%(bar_type)s"
 
2180
            " is not a supported type Select one of: %(valid_types)s")
 
2181
 
 
2182
    def __init__(self, bar_type, valid_types):
 
2183
        BzrError.__init__(self, bar_type=bar_type, valid_types=valid_types)
 
2184
 
 
2185
 
2241
2186
class UnsupportedOperation(BzrError):
2242
2187
 
2243
2188
    _fmt = ("The method %(mname)s is not supported on"
2763
2708
 
2764
2709
    def __init__(self, bzrdir):
2765
2710
        import bzrlib.urlutils as urlutils
2766
 
        display_url = urlutils.unescape_for_display(bzrdir.user_url,
 
2711
        display_url = urlutils.unescape_for_display(bzrdir.root_transport.base,
2767
2712
                                                    'ascii')
2768
2713
        BzrError.__init__(self, bzrdir=bzrdir, display_url=display_url)
2769
2714
 
2834
2779
 
2835
2780
class UncommittedChanges(BzrError):
2836
2781
 
2837
 
    _fmt = ('Working tree "%(display_url)s" has uncommitted changes'
2838
 
            ' (See bzr status).%(more)s')
 
2782
    _fmt = 'Working tree "%(display_url)s" has uncommitted changes.'
2839
2783
 
2840
 
    def __init__(self, tree, more=None):
2841
 
        if more is None:
2842
 
            more = ''
2843
 
        else:
2844
 
            more = ' ' + more
 
2784
    def __init__(self, tree):
2845
2785
        import bzrlib.urlutils as urlutils
2846
2786
        display_url = urlutils.unescape_for_display(
2847
 
            tree.user_url, 'ascii')
2848
 
        BzrError.__init__(self, tree=tree, display_url=display_url, more=more)
2849
 
 
2850
 
 
2851
 
class ShelvedChanges(UncommittedChanges):
2852
 
 
2853
 
    _fmt = ('Working tree "%(display_url)s" has shelved changes'
2854
 
            ' (See bzr shelve --list).%(more)s')
 
2787
            tree.bzrdir.root_transport.base, 'ascii')
 
2788
        BzrError.__init__(self, tree=tree, display_url=display_url)
2855
2789
 
2856
2790
 
2857
2791
class MissingTemplateVariable(BzrError):
2963
2897
    _fmt = 'Cannot bind address "%(host)s:%(port)i": %(orig_error)s.'
2964
2898
 
2965
2899
    def __init__(self, host, port, orig_error):
2966
 
        # nb: in python2.4 socket.error doesn't have a useful repr
2967
2900
        BzrError.__init__(self, host=host, port=port,
2968
 
            orig_error=repr(orig_error.args))
 
2901
            orig_error=orig_error[1])
2969
2902
 
2970
2903
 
2971
2904
class UnknownRules(BzrError):
2979
2912
class HookFailed(BzrError):
2980
2913
    """Raised when a pre_change_branch_tip hook function fails anything other
2981
2914
    than TipChangeRejected.
2982
 
 
2983
 
    Note that this exception is no longer raised, and the import is only left
2984
 
    to be nice to code which might catch it in a plugin.
2985
2915
    """
2986
2916
 
2987
2917
    _fmt = ("Hook '%(hook_name)s' during %(hook_stage)s failed:\n"
2988
2918
            "%(traceback_text)s%(exc_value)s")
2989
2919
 
2990
 
    def __init__(self, hook_stage, hook_name, exc_info, warn=True):
2991
 
        if warn:
2992
 
            symbol_versioning.warn("BzrError HookFailed has been deprecated "
2993
 
                "as of bzrlib 2.1.", DeprecationWarning, stacklevel=2)
 
2920
    def __init__(self, hook_stage, hook_name, exc_info):
2994
2921
        import traceback
2995
2922
        self.hook_stage = hook_stage
2996
2923
        self.hook_name = hook_name
3033
2960
        BzrError.__init__(self, invalid_id=invalid_id)
3034
2961
 
3035
2962
 
3036
 
class JailBreak(BzrError):
3037
 
 
3038
 
    _fmt = "An attempt to access a url outside the server jail was made: '%(url)s'."
3039
 
 
3040
 
    def __init__(self, url):
3041
 
        BzrError.__init__(self, url=url)
3042
 
 
3043
 
 
3044
2963
class UserAbort(BzrError):
3045
2964
 
3046
2965
    _fmt = 'The user aborted the operation.'
3106
3025
 
3107
3026
    def __init__(self, repository):
3108
3027
        self.repository = repository
3109
 
 
3110
 
 
3111
 
class LossyPushToSameVCS(BzrError):
3112
 
 
3113
 
    _fmt = ("Lossy push not possible between %(source_branch)r and "
3114
 
            "%(target_branch)r that are in the same VCS.")
3115
 
 
3116
 
    internal_error = True
3117
 
 
3118
 
    def __init__(self, source_branch, target_branch):
3119
 
        self.source_branch = source_branch
3120
 
        self.target_branch = target_branch
3121
 
 
3122
 
 
3123
 
class NoRoundtrippingSupport(BzrError):
3124
 
 
3125
 
    _fmt = ("Roundtripping is not supported between %(source_branch)r and "
3126
 
            "%(target_branch)r.")
3127
 
 
3128
 
    internal_error = True
3129
 
 
3130
 
    def __init__(self, source_branch, target_branch):
3131
 
        self.source_branch = source_branch
3132
 
        self.target_branch = target_branch
3133
 
 
3134
 
 
3135
 
class FileTimestampUnavailable(BzrError):
3136
 
 
3137
 
    _fmt = "The filestamp for %(path)s is not available."
3138
 
 
3139
 
    internal_error = True
3140
 
 
3141
 
    def __init__(self, path):
3142
 
        self.path = path
3143
 
 
3144
 
 
3145
 
class NoColocatedBranchSupport(BzrError):
3146
 
 
3147
 
    _fmt = ("%(bzrdir)r does not support co-located branches.")
3148
 
 
3149
 
    def __init__(self, bzrdir):
3150
 
        self.bzrdir = bzrdir
3151
 
 
3152
 
 
3153
 
class NoWhoami(BzrError):
3154
 
 
3155
 
    _fmt = ('Unable to determine your name.\n'
3156
 
        "Please, set your name with the 'whoami' command.\n"
3157
 
        'E.g. bzr whoami "Your Name <name@example.com>"')
3158
 
 
3159
 
 
3160
 
class InvalidPattern(BzrError):
3161
 
 
3162
 
    _fmt = ('Invalid pattern(s) found. %(msg)s')
3163
 
 
3164
 
    def __init__(self, msg):
3165
 
        self.msg = msg
3166
 
 
3167
 
 
3168
 
class RecursiveBind(BzrError):
3169
 
 
3170
 
    _fmt = ('Branch "%(branch_url)s" appears to be bound to itself. '
3171
 
        'Please use `bzr unbind` to fix.')
3172
 
 
3173
 
    def __init__(self, branch_url):
3174
 
        self.branch_url = branch_url
3175