/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
2052.3.1 by John Arbash Meinel
Add tests to cleanup the copyright of all source files
1
# Copyright (C) 2005, 2006 Canonical Ltd
1830.3.5 by John Arbash Meinel
make_entry refuses to create non-normalized entries.
2
#
1 by mbp at sourcefrog
import from baz patch-364
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
1830.3.5 by John Arbash Meinel
make_entry refuses to create non-normalized entries.
7
#
1 by mbp at sourcefrog
import from baz patch-364
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
1830.3.5 by John Arbash Meinel
make_entry refuses to create non-normalized entries.
12
#
1 by mbp at sourcefrog
import from baz patch-364
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
1185.16.61 by mbp at sourcefrog
- start introducing hct error classes
17
"""Exceptions for bzr, and reporting of them.
18
"""
19
1614.2.13 by Olaf Conradi
Re-added AmbiguousBase with a deprecated warning.
20
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
21
from bzrlib import symbol_versioning
1185.82.128 by Aaron Bentley
Provide errors from bzrlib.patches in bzrlib.errors
22
from bzrlib.patches import (PatchSyntax, 
23
                            PatchConflict, 
24
                            MalformedPatchHeader,
25
                            MalformedHunkHeader,
26
                            MalformedLine,)
27
28
1185.16.62 by mbp at sourcefrog
- convert NotBranchError to new exception base
29
# TODO: is there any value in providing the .args field used by standard
30
# python exceptions?   A list of values with no names seems less useful 
31
# to me.
32
1185.16.63 by Martin Pool
- more error conversion
33
# TODO: Perhaps convert the exception to a string at the moment it's 
34
# constructed to make sure it will succeed.  But that says nothing about
35
# exceptions that are never raised.
36
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
37
# TODO: selftest assertRaises should probably also check that every error
38
# raised can be formatted as a string successfully, and without giving
39
# 'unprintable'.
1662.1.12 by Martin Pool
Translate unknown sftp errors to PathError, no NoSuchFile
40
1185.16.61 by mbp at sourcefrog
- start introducing hct error classes
41
1 by mbp at sourcefrog
import from baz patch-364
42
class BzrError(StandardError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
43
    """
44
    Base class for errors raised by bzrlib.
45
2067.3.2 by Martin Pool
Error cleanup review comments:
46
    :cvar internal_error: if true (or absent) this was probably caused by a
47
    bzr bug and should be displayed with a traceback; if False this was
48
    probably a user or environment error and they don't need the gory details.
49
    (That can be overridden by -Derror on the command line.)
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
50
2067.3.2 by Martin Pool
Error cleanup review comments:
51
    :cvar _fmt: Format string to display the error; this is expanded
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
52
    by the instance's dict.
53
    """
1740.5.6 by Martin Pool
Clean up many exception classes.
54
    
2067.3.2 by Martin Pool
Error cleanup review comments:
55
    internal_error = False
1685.2.1 by Brian M. Carlson
Add a workaround for usage of the args attribute in exceptions.
56
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
57
    def __init__(self, msg=None, **kwds):
58
        """Construct a new BzrError.
59
60
        There are two alternative forms for constructing these objects.
61
        Either a preformatted string may be passed, or a set of named
62
        arguments can be given.  The first is for generic "user" errors which
63
        are not intended to be caught and so do not need a specific subclass.
64
        The second case is for use with subclasses that provide a _fmt format
65
        string to print the arguments.  
66
67
        Keyword arguments are taken as parameters to the error, which can 
68
        be inserted into the format string template.  It's recommended 
69
        that subclasses override the __init__ method to require specific 
70
        parameters.
71
2067.3.2 by Martin Pool
Error cleanup review comments:
72
        :param msg: If given, this is the literal complete text for the error,
73
        not subject to expansion.
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
74
        """
75
        StandardError.__init__(self)
76
        if msg is not None:
2067.3.4 by Martin Pool
Error deprecations will come in for 0.13
77
            # I was going to deprecate this, but it actually turns out to be
78
            # quite handy - mbp 20061103.
2067.3.2 by Martin Pool
Error cleanup review comments:
79
            self._preformatted_string = msg
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
80
        else:
2067.3.2 by Martin Pool
Error cleanup review comments:
81
            self._preformatted_string = None
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
82
            for key, value in kwds.items():
83
                setattr(self, key, value)
84
1193 by Martin Pool
- better string formatting of BzrErrors with explanation
85
    def __str__(self):
2067.3.2 by Martin Pool
Error cleanup review comments:
86
        s = getattr(self, '_preformatted_string', None)
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
87
        if s is not None:
88
            # contains a preformatted message; must be cast to plain str
89
            return str(s)
90
        try:
2067.3.2 by Martin Pool
Error cleanup review comments:
91
            fmt = self._get_format_string()
92
            if fmt:
93
                s = fmt % self.__dict__
94
                # __str__() should always return a 'str' object
95
                # never a 'unicode' object.
96
                if isinstance(s, unicode):
97
                    return s.encode('utf8')
98
                return s
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
99
        except (AttributeError, TypeError, NameError, ValueError, KeyError), e:
100
            return 'Unprintable exception %s: dict=%r, fmt=%r, error=%s' \
101
                % (self.__class__.__name__,
102
                   self.__dict__,
103
                   getattr(self, '_fmt', None),
104
                   str(e))
1193 by Martin Pool
- better string formatting of BzrErrors with explanation
105
2067.3.2 by Martin Pool
Error cleanup review comments:
106
    def _get_format_string(self):
107
        """Return format string for this exception or None"""
108
        fmt = getattr(self, '_fmt', None)
109
        if fmt is not None:
110
            return fmt
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
111
        fmt = getattr(self, '__doc__', None)
2067.3.2 by Martin Pool
Error cleanup review comments:
112
        if fmt is not None:
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
113
            symbol_versioning.warn("%s uses its docstring as a format, "
114
                    "it should use _fmt instead" % self.__class__.__name__,
115
                    DeprecationWarning)
116
            return fmt
117
        return 'Unprintable exception %s: dict=%r, fmt=%r' \
118
            % (self.__class__.__name__,
119
               self.__dict__,
120
               getattr(self, '_fmt', None),
121
               )
2067.3.2 by Martin Pool
Error cleanup review comments:
122
1185.1.14 by Robert Collins
remove more duplicate merged hunks. Bad MERGE3, BAD.
123
1185.16.62 by mbp at sourcefrog
- convert NotBranchError to new exception base
124
class BzrNewError(BzrError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
125
    """Deprecated error base class."""
1185.16.61 by mbp at sourcefrog
- start introducing hct error classes
126
    # base classes should override the docstring with their human-
127
    # readable explanation
128
1685.2.1 by Brian M. Carlson
Add a workaround for usage of the args attribute in exceptions.
129
    def __init__(self, *args, **kwds):
130
        # XXX: Use the underlying BzrError to always generate the args attribute
1685.2.2 by Brian M. Carlson
Change the BzrNewError super invocation to a direct call, so it works with 2.4.
131
        # if it doesn't exist.  We can't use super here, because exceptions are
132
        # old-style classes in python2.4 (but new in 2.5).  --bmc, 20060426
2067.3.4 by Martin Pool
Error deprecations will come in for 0.13
133
        symbol_versioning.warn('BzrNewError was deprecated in bzr 0.13; '
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
134
             'please convert %s to use BzrError instead' 
135
             % self.__class__.__name__,
136
             DeprecationWarning,
137
             stacklevel=2)
1685.2.2 by Brian M. Carlson
Change the BzrNewError super invocation to a direct call, so it works with 2.4.
138
        BzrError.__init__(self, *args)
1185.16.61 by mbp at sourcefrog
- start introducing hct error classes
139
        for key, value in kwds.items():
140
            setattr(self, key, value)
141
142
    def __str__(self):
143
        try:
1948.1.6 by John Arbash Meinel
Make BzrNewError always return a str object
144
            # __str__() should always return a 'str' object
145
            # never a 'unicode' object.
146
            s = self.__doc__ % self.__dict__
147
            if isinstance(s, unicode):
148
                return s.encode('utf8')
149
            return s
1910.12.1 by Andrew Bennetts
Catch TypeError in BzrNewError.__str__, and print more information if an exception happens in that.
150
        except (TypeError, NameError, ValueError, KeyError), e:
151
            return 'Unprintable exception %s(%r): %s' \
152
                % (self.__class__.__name__,
153
                   self.__dict__, str(e))
1185.16.61 by mbp at sourcefrog
- start introducing hct error classes
154
155
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
156
class AlreadyBuilding(BzrError):
157
    
158
    _fmt = "The tree builder is already building a tree."
159
160
161
class BzrCheckError(BzrError):
162
    
163
    _fmt = "Internal check failed: %(message)s"
1508.1.22 by Robert Collins
implement out of date working tree checks in commit.
164
2067.3.2 by Martin Pool
Error cleanup review comments:
165
    internal_error = True
1740.5.6 by Martin Pool
Clean up many exception classes.
166
1185.16.63 by Martin Pool
- more error conversion
167
    def __init__(self, message):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
168
        BzrError.__init__(self)
1185.16.63 by Martin Pool
- more error conversion
169
        self.message = message
170
171
2018.9.1 by Andrew Bennetts
Merge from bzr.dev.
172
class DisabledMethod(BzrError):
173
174
    _fmt = "The smart server method '%(class_name)s' is disabled."
175
176
    internal_error = True
2018.5.24 by Andrew Bennetts
Setting NO_SMART_VFS in environment will disable VFS methods in the smart server. (Robert Collins, John Arbash Meinel, Andrew Bennetts)
177
178
    def __init__(self, class_name):
2018.9.1 by Andrew Bennetts
Merge from bzr.dev.
179
        BzrError.__init__(self)
2018.5.24 by Andrew Bennetts
Setting NO_SMART_VFS in environment will disable VFS methods in the smart server. (Robert Collins, John Arbash Meinel, Andrew Bennetts)
180
        self.class_name = class_name
181
182
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
183
class InvalidEntryName(BzrError):
184
    
185
    _fmt = "Invalid entry name: %(name)s"
1740.5.6 by Martin Pool
Clean up many exception classes.
186
2067.3.2 by Martin Pool
Error cleanup review comments:
187
    internal_error = True
1740.5.6 by Martin Pool
Clean up many exception classes.
188
1185.16.63 by Martin Pool
- more error conversion
189
    def __init__(self, name):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
190
        BzrError.__init__(self)
1185.16.63 by Martin Pool
- more error conversion
191
        self.name = name
192
193
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
194
class InvalidRevisionNumber(BzrError):
195
    
196
    _fmt = "Invalid revision number %(revno)s"
197
1185.16.63 by Martin Pool
- more error conversion
198
    def __init__(self, revno):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
199
        BzrError.__init__(self)
1185.16.63 by Martin Pool
- more error conversion
200
        self.revno = revno
201
202
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
203
class InvalidRevisionId(BzrError):
204
205
    _fmt = "Invalid revision-id {%(revision_id)s} in %(branch)s"
1908.5.9 by Robert Collins
Add a guard against setting the tree last-revision value to a ghost in the new tree parent management api.
206
1185.16.103 by mbp at sourcefrog
Fix up all calls to InvalidRevisionId() to specify parameters.
207
    def __init__(self, revision_id, branch):
1668.5.1 by Olaf Conradi
Fix bug in knits when raising InvalidRevisionId without the required
208
        # branch can be any string or object with __str__ defined
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
209
        BzrError.__init__(self)
1185.12.90 by Aaron Bentley
Fixed InvalidRevisionID handling in Branch.get_revision_xml
210
        self.revision_id = revision_id
1185.16.103 by mbp at sourcefrog
Fix up all calls to InvalidRevisionId() to specify parameters.
211
        self.branch = branch
974.1.26 by aaron.bentley at utoronto
merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472
212
213
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
214
class NoSuchId(BzrError):
215
216
    _fmt = "The file id %(file_id)s is not present in the tree %(tree)s."
1988.2.1 by Robert Collins
WorkingTree has a new api ``unversion`` which allow the unversioning of
217
    
218
    def __init__(self, tree, file_id):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
219
        BzrError.__init__(self)
1988.2.1 by Robert Collins
WorkingTree has a new api ``unversion`` which allow the unversioning of
220
        self.file_id = file_id
221
        self.tree = tree
222
223
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
224
class InventoryModified(BzrError):
225
226
    _fmt = ("The current inventory for the tree %(tree)r has been modified, "
227
            "so a clean inventory cannot be read without data loss.")
228
229
    internal_error = True
230
231
    def __init__(self, tree):
232
        self.tree = tree
233
234
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
235
class NoWorkingTree(BzrError):
236
237
    _fmt = "No WorkingTree exists for %(base)s."
1497 by Robert Collins
Move Branch.read_working_inventory to WorkingTree.
238
    
239
    def __init__(self, base):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
240
        BzrError.__init__(self)
1497 by Robert Collins
Move Branch.read_working_inventory to WorkingTree.
241
        self.base = base
1506 by Robert Collins
Merge Johns current integration work.
242
243
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
244
class NotBuilding(BzrError):
245
246
    _fmt = "Not currently building a tree."
247
248
249
class NotLocalUrl(BzrError):
250
251
    _fmt = "%(url)s is not a local path."
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
252
1534.4.42 by Robert Collins
add working tree to the BzrDir facilities.
253
    def __init__(self, url):
254
        self.url = url
255
256
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
257
class WorkingTreeAlreadyPopulated(BzrError):
258
259
    _fmt = """Working tree already populated in %(base)s"""
260
261
    internal_error = True
262
263
    def __init__(self, base):
264
        self.base = base
265
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
266
class BzrCommandError(BzrError):
1740.5.6 by Martin Pool
Clean up many exception classes.
267
    """Error from user command"""
1740.5.8 by Martin Pool
Review cleanups: better error reporting, put back report_exception.
268
2067.3.2 by Martin Pool
Error cleanup review comments:
269
    internal_error = False
1740.5.8 by Martin Pool
Review cleanups: better error reporting, put back report_exception.
270
271
    # Error from malformed user command; please avoid raising this as a
272
    # generic exception not caused by user input.
1185.54.18 by Aaron Bentley
Noted difference of opinion wrt BzrCommandError
273
    #
274
    # I think it's a waste of effort to differentiate between errors that
275
    # are not intended to be caught anyway.  UI code need not subclass
276
    # BzrCommandError, and non-UI code should not throw a subclass of
277
    # BzrCommandError.  ADHB 20051211
1740.5.6 by Martin Pool
Clean up many exception classes.
278
    def __init__(self, msg):
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
279
        # Object.__str__() must return a real string
280
        # returning a Unicode string is a python error.
281
        if isinstance(msg, unicode):
282
            self.msg = msg.encode('utf8')
283
        else:
284
            self.msg = msg
1740.5.6 by Martin Pool
Clean up many exception classes.
285
1393.1.64 by Martin Pool
- improved display of some errors, including NotBranchError
286
    def __str__(self):
1740.5.6 by Martin Pool
Clean up many exception classes.
287
        return self.msg
288
289
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
290
class NotWriteLocked(BzrError):
291
292
    _fmt = """%(not_locked)r is not write locked but needs to be."""
293
294
    def __init__(self, not_locked):
295
        self.not_locked = not_locked
296
297
1740.5.8 by Martin Pool
Review cleanups: better error reporting, put back report_exception.
298
class BzrOptionError(BzrCommandError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
299
300
    _fmt = "Error in command line options"
1740.5.8 by Martin Pool
Review cleanups: better error reporting, put back report_exception.
301
302
    
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
303
class StrictCommitFailed(BzrError):
304
305
    _fmt = "Commit refused because there are unknown files in the tree"
1 by mbp at sourcefrog
import from baz patch-364
306
1185.31.41 by John Arbash Meinel
Creating a PathNotChild exception, and using relpath in HTTPTestUtil
307
1662.1.12 by Martin Pool
Translate unknown sftp errors to PathError, no NoSuchFile
308
# XXX: Should be unified with TransportError; they seem to represent the
309
# same thing
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
310
class PathError(BzrError):
311
    
312
    _fmt = "Generic path error: %(path)r%(extra)s)"
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
313
1185.31.44 by John Arbash Meinel
Cleaned up Exceptions for all transports.
314
    def __init__(self, path, extra=None):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
315
        BzrError.__init__(self)
1185.31.44 by John Arbash Meinel
Cleaned up Exceptions for all transports.
316
        self.path = path
1908.4.11 by John Arbash Meinel
reverting changes to errors.py and local transport.
317
        if extra:
318
            self.extra = ': ' + str(extra)
319
        else:
320
            self.extra = ''
1185.31.44 by John Arbash Meinel
Cleaned up Exceptions for all transports.
321
322
323
class NoSuchFile(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
324
325
    _fmt = "No such file: %(path)r%(extra)s"
1185.31.44 by John Arbash Meinel
Cleaned up Exceptions for all transports.
326
327
328
class FileExists(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
329
330
    _fmt = "File exists: %(path)r%(extra)s"
1185.31.44 by John Arbash Meinel
Cleaned up Exceptions for all transports.
331
332
1553.5.10 by Martin Pool
New DirectoryNotEmpty exception, and raise this from local and memory
333
class DirectoryNotEmpty(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
334
335
    _fmt = "Directory not empty: %(path)r%(extra)s"
1553.5.10 by Martin Pool
New DirectoryNotEmpty exception, and raise this from local and memory
336
337
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
338
class ReadingCompleted(BzrError):
339
    
340
    _fmt = ("The MediumRequest '%(request)s' has already had finish_reading "
341
            "called upon it - the request has been completed and no more "
342
            "data may be read.")
343
344
    internal_error = True
2018.2.28 by Andrew Bennetts
Changes in response to review: re-use _base_curl, rather than keeping a seperate _post_curl object; add docstring to test_http.RecordingServer, set is_user_error on some new exceptions.
345
2018.2.4 by Robert Collins
separate out the client medium from the client encoding protocol for the smart server.
346
    def __init__(self, request):
347
        self.request = request
348
349
1558.10.1 by Aaron Bentley
Handle lockdirs over NFS properly
350
class ResourceBusy(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
351
352
    _fmt = "Device or resource busy: %(path)r%(extra)s"
1558.10.1 by Aaron Bentley
Handle lockdirs over NFS properly
353
354
1185.31.44 by John Arbash Meinel
Cleaned up Exceptions for all transports.
355
class PermissionDenied(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
356
357
    _fmt = "Permission denied: %(path)r%(extra)s"
1740.5.8 by Martin Pool
Review cleanups: better error reporting, put back report_exception.
358
359
1185.85.76 by John Arbash Meinel
Adding an InvalidURL so transports can report they expect utf-8 quoted paths. Updated tests
360
class InvalidURL(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
361
362
    _fmt = "Invalid url supplied to transport: %(path)r%(extra)s"
1185.85.76 by John Arbash Meinel
Adding an InvalidURL so transports can report they expect utf-8 quoted paths. Updated tests
363
364
1685.1.55 by John Arbash Meinel
Adding bzrlib.urlutils.join() to handle joining URLs
365
class InvalidURLJoin(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
366
367
    _fmt = "Invalid URL join request: %(args)s%(extra)s"
1685.1.55 by John Arbash Meinel
Adding bzrlib.urlutils.join() to handle joining URLs
368
369
    def __init__(self, msg, base, args):
370
        PathError.__init__(self, base, msg)
2027.2.2 by Marien Zwart
Fixes for python 2.5.
371
        self.args = [base] + list(args)
1685.1.55 by John Arbash Meinel
Adding bzrlib.urlutils.join() to handle joining URLs
372
373
1843.1.1 by John Arbash Meinel
Update get_transport to raise a nicer error which includes dependency info
374
class UnsupportedProtocol(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
375
376
    _fmt = 'Unsupported protocol for url "%(path)s"%(extra)s'
1843.1.1 by John Arbash Meinel
Update get_transport to raise a nicer error which includes dependency info
377
378
    def __init__(self, url, extra):
379
        PathError.__init__(self, url, extra=extra)
380
381
2001.3.2 by John Arbash Meinel
Force all transports to raise ShortReadvError if they can
382
class ShortReadvError(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
383
384
    _fmt = "readv() read %(actual)s bytes rather than %(length)s bytes at %(offset)s for %(path)s%(extra)s"
2001.3.2 by John Arbash Meinel
Force all transports to raise ShortReadvError if they can
385
2067.3.2 by Martin Pool
Error cleanup review comments:
386
    internal_error = True
2001.3.2 by John Arbash Meinel
Force all transports to raise ShortReadvError if they can
387
2001.3.3 by John Arbash Meinel
review feedback: add the actual count written to ShortReadvError
388
    def __init__(self, path, offset, length, actual, extra=None):
2001.3.2 by John Arbash Meinel
Force all transports to raise ShortReadvError if they can
389
        PathError.__init__(self, path, extra=extra)
390
        self.offset = offset
391
        self.length = length
2001.3.3 by John Arbash Meinel
review feedback: add the actual count written to ShortReadvError
392
        self.actual = actual
2001.3.2 by John Arbash Meinel
Force all transports to raise ShortReadvError if they can
393
394
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
395
class PathNotChild(BzrError):
396
397
    _fmt = "Path %(path)r is not a child of path %(base)r%(extra)s"
1740.5.6 by Martin Pool
Clean up many exception classes.
398
2067.3.2 by Martin Pool
Error cleanup review comments:
399
    internal_error = True
1740.5.6 by Martin Pool
Clean up many exception classes.
400
1185.31.44 by John Arbash Meinel
Cleaned up Exceptions for all transports.
401
    def __init__(self, path, base, extra=None):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
402
        BzrError.__init__(self)
1185.31.41 by John Arbash Meinel
Creating a PathNotChild exception, and using relpath in HTTPTestUtil
403
        self.path = path
404
        self.base = base
1185.31.44 by John Arbash Meinel
Cleaned up Exceptions for all transports.
405
        if extra:
406
            self.extra = ': ' + str(extra)
407
        else:
408
            self.extra = ''
1185.31.41 by John Arbash Meinel
Creating a PathNotChild exception, and using relpath in HTTPTestUtil
409
410
1830.3.5 by John Arbash Meinel
make_entry refuses to create non-normalized entries.
411
class InvalidNormalization(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
412
413
    _fmt = "Path %(path)r is not unicode normalized"
1830.3.5 by John Arbash Meinel
make_entry refuses to create non-normalized entries.
414
415
1685.1.60 by Martin Pool
[broken] NotBranchError should unescape the url if possible
416
# TODO: This is given a URL; we try to unescape it but doing that from inside
417
# the exception object is a bit undesirable.
418
# TODO: Probably this behavior of should be a common superclass 
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
419
class NotBranchError(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
420
421
    _fmt = "Not a branch: %(path)s"
1685.1.60 by Martin Pool
[broken] NotBranchError should unescape the url if possible
422
423
    def __init__(self, path):
424
       import bzrlib.urlutils as urlutils
1908.4.11 by John Arbash Meinel
reverting changes to errors.py and local transport.
425
       self.path = urlutils.unescape_for_display(path, 'ascii')
1654.1.4 by Robert Collins
Teach `bzr init` how to init at the root of a repository.
426
427
428
class AlreadyBranchError(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
429
430
    _fmt = "Already a branch: %(path)s."
1662.1.19 by Martin Pool
Better error message when initting existing tree
431
432
433
class BranchExistsWithoutWorkingTree(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
434
435
    _fmt = "Directory contains a branch, but no working tree \
2067.3.2 by Martin Pool
Error cleanup review comments:
436
(use bzr checkout if you wish to build a working tree): %(path)s"
1185.16.62 by mbp at sourcefrog
- convert NotBranchError to new exception base
437
573 by Martin Pool
- new exception NotBranchError
438
1755.3.6 by John Arbash Meinel
Add a test suite for Atomic File, and clean it up so that it really does set the mode properly.
439
class AtomicFileAlreadyClosed(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
440
441
    _fmt = "'%(function)s' called on an AtomicFile after it was closed: %(path)s"
1755.3.6 by John Arbash Meinel
Add a test suite for Atomic File, and clean it up so that it really does set the mode properly.
442
443
    def __init__(self, path, function):
444
        PathError.__init__(self, path=path, extra=None)
445
        self.function = function
446
447
1864.7.2 by John Arbash Meinel
Test that we copy the parent across properly (if it is available)
448
class InaccessibleParent(PathError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
449
450
    _fmt = "Parent not accessible given base %(base)s and relative path %(path)s"
1864.7.2 by John Arbash Meinel
Test that we copy the parent across properly (if it is available)
451
452
    def __init__(self, path, base):
453
        PathError.__init__(self, path)
454
        self.base = base
455
456
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
457
class NoRepositoryPresent(BzrError):
458
459
    _fmt = "No repository present: %(path)r"
1534.4.47 by Robert Collins
Split out repository into .bzr/repository
460
    def __init__(self, bzrdir):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
461
        BzrError.__init__(self)
1534.4.47 by Robert Collins
Split out repository into .bzr/repository
462
        self.path = bzrdir.transport.clone('..').base
463
464
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
465
class FileInWrongBranch(BzrError):
466
467
    _fmt = "File %(path)s in not in branch %(branch_base)s."
1534.4.44 by Robert Collins
Make a new BzrDir format that uses a versioned branch format in a branch/ subdirectory.
468
1185.35.32 by Aaron Bentley
Fixed handling of files in mixed branches
469
    def __init__(self, branch, path):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
470
        BzrError.__init__(self)
1185.35.32 by Aaron Bentley
Fixed handling of files in mixed branches
471
        self.branch = branch
472
        self.branch_base = branch.base
473
        self.path = path
474
475
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
476
class UnsupportedFormatError(BzrError):
477
    
478
    _fmt = "Unsupported branch format: %(format)s"
479
480
481
class UnknownFormatError(BzrError):
482
    
483
    _fmt = "Unknown branch format: %(format)r"
484
485
486
class IncompatibleFormat(BzrError):
487
    
488
    _fmt = "Format %(format)s is not compatible with .bzr version %(bzrdir)s."
1534.4.44 by Robert Collins
Make a new BzrDir format that uses a versioned branch format in a branch/ subdirectory.
489
490
    def __init__(self, format, bzrdir_format):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
491
        BzrError.__init__(self)
1534.4.44 by Robert Collins
Make a new BzrDir format that uses a versioned branch format in a branch/ subdirectory.
492
        self.format = format
493
        self.bzrdir = bzrdir_format
494
495
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
496
class IncompatibleRevision(BzrError):
497
    
498
    _fmt = "Revision is not compatible with %(repo_format)s"
1910.2.60 by Aaron Bentley
Ensure that new-model revisions aren't installed into old-model repos
499
500
    def __init__(self, repo_format):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
501
        BzrError.__init__(self)
1910.2.60 by Aaron Bentley
Ensure that new-model revisions aren't installed into old-model repos
502
        self.repo_format = repo_format
503
504
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
505
class NotVersionedError(BzrError):
506
507
    _fmt = "%(path)s is not versioned"
508
1185.16.72 by Martin Pool
[merge] from robert and fix up tests
509
    def __init__(self, path):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
510
        BzrError.__init__(self)
1185.16.72 by Martin Pool
[merge] from robert and fix up tests
511
        self.path = path
753 by Martin Pool
- new exception NotVersionedError
512
513
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
514
class PathsNotVersionedError(BzrError):
1658.1.9 by Martin Pool
Give an error for bzr diff on an nonexistent file (Malone #3619)
515
    # used when reporting several paths are not versioned
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
516
517
    _fmt = "Path(s) are not versioned: %(paths_as_string)s"
1658.1.9 by Martin Pool
Give an error for bzr diff on an nonexistent file (Malone #3619)
518
519
    def __init__(self, paths):
520
        from bzrlib.osutils import quotefn
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
521
        BzrError.__init__(self)
1658.1.9 by Martin Pool
Give an error for bzr diff on an nonexistent file (Malone #3619)
522
        self.paths = paths
523
        self.paths_as_string = ' '.join([quotefn(p) for p in paths])
524
525
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
526
class PathsDoNotExist(BzrError):
527
528
    _fmt = "Path(s) do not exist: %(paths_as_string)s"
1662.1.14 by Martin Pool
(PathsDoNotExist) review style comments
529
1662.1.9 by Martin Pool
Give a clear error for bzr status of an unversioned, nonexistent file. (Malone #3619)
530
    # used when reporting that paths are neither versioned nor in the working
531
    # tree
532
533
    def __init__(self, paths):
1662.1.14 by Martin Pool
(PathsDoNotExist) review style comments
534
        # circular import
1662.1.9 by Martin Pool
Give a clear error for bzr status of an unversioned, nonexistent file. (Malone #3619)
535
        from bzrlib.osutils import quotefn
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
536
        BzrError.__init__(self)
1662.1.9 by Martin Pool
Give a clear error for bzr status of an unversioned, nonexistent file. (Malone #3619)
537
        self.paths = paths
538
        self.paths_as_string = ' '.join([quotefn(p) for p in paths])
539
540
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
541
class BadFileKindError(BzrError):
542
543
    _fmt = "Cannot operate on %(filename)s of unsupported kind %(kind)s"
544
545
546
class ForbiddenControlFileError(BzrError):
547
548
    _fmt = "Cannot operate on %(filename)s because it is a control file"
549
550
551
class LockError(BzrError):
552
553
    _fmt = "Lock error: %(message)s"
2067.3.2 by Martin Pool
Error cleanup review comments:
554
1185.16.63 by Martin Pool
- more error conversion
555
    # All exceptions from the lock/unlock functions should be from
556
    # this exception class.  They will be translated as necessary. The
557
    # original exception is available as e.original_error
1553.5.11 by Martin Pool
Change some lock and transaction related exceptions to BzrNewException style
558
    #
559
    # New code should prefer to raise specific subclasses
560
    def __init__(self, message):
561
        self.message = message
882 by Martin Pool
- Optionally raise EmptyCommit if there are no changes. Test for this.
562
563
1417.1.6 by Robert Collins
introduce transactions for grouping actions done to and with branches
564
class CommitNotPossible(LockError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
565
566
    _fmt = "A commit was attempted but we do not have a write lock open."
2067.3.2 by Martin Pool
Error cleanup review comments:
567
1553.5.11 by Martin Pool
Change some lock and transaction related exceptions to BzrNewException style
568
    def __init__(self):
569
        pass
1417.1.6 by Robert Collins
introduce transactions for grouping actions done to and with branches
570
571
572
class AlreadyCommitted(LockError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
573
574
    _fmt = "A rollback was requested, but is not able to be accomplished."
2067.3.2 by Martin Pool
Error cleanup review comments:
575
1553.5.11 by Martin Pool
Change some lock and transaction related exceptions to BzrNewException style
576
    def __init__(self):
577
        pass
1417.1.6 by Robert Collins
introduce transactions for grouping actions done to and with branches
578
579
1417.1.8 by Robert Collins
use transactions in the weave store interface, which enables caching for log
580
class ReadOnlyError(LockError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
581
582
    _fmt = "A write attempt was made in a read only transaction on %(obj)s"
2067.3.2 by Martin Pool
Error cleanup review comments:
583
1553.5.33 by Martin Pool
LockDir review comment fixes
584
    def __init__(self, obj):
585
        self.obj = obj
1553.5.11 by Martin Pool
Change some lock and transaction related exceptions to BzrNewException style
586
587
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
588
class OutSideTransaction(BzrError):
589
590
    _fmt = "A transaction related operation was attempted after the transaction finished."
1594.2.21 by Robert Collins
Teach versioned files to prevent mutation after finishing.
591
592
1553.5.36 by Martin Pool
Clean up duplicate BranchNotLocked error and rename to ObjectNotLocked
593
class ObjectNotLocked(LockError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
594
595
    _fmt = "%(obj)r is not locked"
1740.5.8 by Martin Pool
Review cleanups: better error reporting, put back report_exception.
596
2067.3.2 by Martin Pool
Error cleanup review comments:
597
    internal_error = True
1740.5.8 by Martin Pool
Review cleanups: better error reporting, put back report_exception.
598
1553.5.36 by Martin Pool
Clean up duplicate BranchNotLocked error and rename to ObjectNotLocked
599
    # this can indicate that any particular object is not locked; see also
600
    # LockNotHeld which means that a particular *lock* object is not held by
601
    # the caller -- perhaps they should be unified.
602
    def __init__(self, obj):
603
        self.obj = obj
1553.5.11 by Martin Pool
Change some lock and transaction related exceptions to BzrNewException style
604
605
606
class ReadOnlyObjectDirtiedError(ReadOnlyError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
607
608
    _fmt = "Cannot change object %(obj)r in read only transaction"
2067.3.2 by Martin Pool
Error cleanup review comments:
609
1553.5.11 by Martin Pool
Change some lock and transaction related exceptions to BzrNewException style
610
    def __init__(self, obj):
611
        self.obj = obj
612
613
614
class UnlockableTransport(LockError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
615
616
    _fmt = "Cannot lock: transport is read only: %(transport)s"
2067.3.2 by Martin Pool
Error cleanup review comments:
617
1553.5.11 by Martin Pool
Change some lock and transaction related exceptions to BzrNewException style
618
    def __init__(self, transport):
619
        self.transport = transport
620
621
622
class LockContention(LockError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
623
624
    _fmt = "Could not acquire lock %(lock)s"
1553.5.11 by Martin Pool
Change some lock and transaction related exceptions to BzrNewException style
625
    # TODO: show full url for lock, combining the transport and relative bits?
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
626
    
1553.5.11 by Martin Pool
Change some lock and transaction related exceptions to BzrNewException style
627
    def __init__(self, lock):
628
        self.lock = lock
629
630
1553.5.23 by Martin Pool
Start LockDir.confirm method and LockBroken exception
631
class LockBroken(LockError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
632
633
    _fmt = "Lock was broken while still open: %(lock)s - check storage consistency!"
634
1553.5.23 by Martin Pool
Start LockDir.confirm method and LockBroken exception
635
    def __init__(self, lock):
636
        self.lock = lock
637
638
1553.5.27 by Martin Pool
Confirm that only the intended holder of a lock was broken.
639
class LockBreakMismatch(LockError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
640
641
    _fmt = "Lock was released and re-acquired before being broken: %(lock)s: held by %(holder)r, wanted to break %(target)r"
642
1553.5.27 by Martin Pool
Confirm that only the intended holder of a lock was broken.
643
    def __init__(self, lock, holder, target):
644
        self.lock = lock
645
        self.holder = holder
646
        self.target = target
647
648
1553.5.11 by Martin Pool
Change some lock and transaction related exceptions to BzrNewException style
649
class LockNotHeld(LockError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
650
651
    _fmt = "Lock not held: %(lock)s"
652
1553.5.11 by Martin Pool
Change some lock and transaction related exceptions to BzrNewException style
653
    def __init__(self, lock):
654
        self.lock = lock
655
656
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
657
class PointlessCommit(BzrError):
658
659
    _fmt = "No changes to commit"
660
661
662
class UpgradeReadonly(BzrError):
663
664
    _fmt = "Upgrade URL cannot work with readonly URLs."
665
666
667
class UpToDateFormat(BzrError):
668
669
    _fmt = "The branch format %(format)s is already at the most recent format."
1534.5.7 by Robert Collins
Start factoring out the upgrade policy logic.
670
671
    def __init__(self, format):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
672
        BzrError.__init__(self)
1534.5.7 by Robert Collins
Start factoring out the upgrade policy logic.
673
        self.format = format
674
675
1185.22.1 by Michael Ellerman
Implement strict commits with --strict flag.
676
class StrictCommitFailed(Exception):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
677
678
    _fmt = "Commit refused because there are unknowns in the tree."
679
680
681
class NoSuchRevision(BzrError):
682
683
    _fmt = "Branch %(branch)s has no revision %(revision)s"
1740.5.6 by Martin Pool
Clean up many exception classes.
684
2067.3.2 by Martin Pool
Error cleanup review comments:
685
    internal_error = True
1740.5.6 by Martin Pool
Clean up many exception classes.
686
974.1.26 by aaron.bentley at utoronto
merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472
687
    def __init__(self, branch, revision):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
688
        BzrError.__init__(self, branch=branch, revision=revision)
689
690
691
class NoSuchRevisionSpec(BzrError):
692
693
    _fmt = "No namespace registered for string: %(spec)r"
1948.4.25 by John Arbash Meinel
Check that invalid specs are properly handled
694
695
    def __init__(self, spec):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
696
        BzrError.__init__(self, spec=spec)
697
698
699
class InvalidRevisionSpec(BzrError):
700
701
    _fmt = "Requested revision: %(spec)r does not exist in branch: %(branch)s%(extra)s"
1948.4.1 by John Arbash Meinel
Update number parsers to raise InvalidRevisionSpec. Update revno: itself so it supports negative numbers
702
703
    def __init__(self, spec, branch, extra=None):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
704
        BzrError.__init__(self, branch=branch, spec=spec)
1948.4.1 by John Arbash Meinel
Update number parsers to raise InvalidRevisionSpec. Update revno: itself so it supports negative numbers
705
        if extra:
1948.4.15 by John Arbash Meinel
Change the InvalidRevisionSpec formatting to be more readable
706
            self.extra = '\n' + str(extra)
1948.4.1 by John Arbash Meinel
Update number parsers to raise InvalidRevisionSpec. Update revno: itself so it supports negative numbers
707
        else:
708
            self.extra = ''
1740.5.6 by Martin Pool
Clean up many exception classes.
709
710
1192 by Martin Pool
- clean up code for retrieving stored inventories
711
class HistoryMissing(BzrError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
712
713
    _fmt = "%(branch)s is missing %(object_type)s {%(object_id)s}"
714
715
716
class DivergedBranches(BzrError):
717
    
718
    _fmt = "These branches have diverged.  Use the merge command to reconcile them."""
1740.5.6 by Martin Pool
Clean up many exception classes.
719
2067.3.2 by Martin Pool
Error cleanup review comments:
720
    internal_error = False
1649.1.1 by Robert Collins
* 'pull' and 'push' now normalise the revision history, so that any two
721
1185.2.1 by Lalo Martins
moving DivergedBranches from bzrlib.branch to bzrlib.errors, obeying:
722
    def __init__(self, branch1, branch2):
723
        self.branch1 = branch1
724
        self.branch2 = branch2
725
1390 by Robert Collins
pair programming worx... merge integration and weave
726
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
727
class UnrelatedBranches(BzrError):
2067.3.2 by Martin Pool
Error cleanup review comments:
728
729
    _fmt = "Branches have no common ancestor, and no merge base revision was specified."
730
731
    internal_error = False
1740.5.6 by Martin Pool
Clean up many exception classes.
732
733
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
734
class NoCommonAncestor(BzrError):
2067.3.2 by Martin Pool
Error cleanup review comments:
735
    
736
    _fmt = "Revisions have no common ancestor: %(revision_a)s %(revision_b)s"
1740.5.6 by Martin Pool
Clean up many exception classes.
737
974.1.80 by Aaron Bentley
Improved merge error handling and testing
738
    def __init__(self, revision_a, revision_b):
1740.5.6 by Martin Pool
Clean up many exception classes.
739
        self.revision_a = revision_a
740
        self.revision_b = revision_b
974.1.80 by Aaron Bentley
Improved merge error handling and testing
741
1551.2.1 by Aaron Bentley
recommit 1527 PEP8 fixes
742
974.1.80 by Aaron Bentley
Improved merge error handling and testing
743
class NoCommonRoot(BzrError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
744
745
    _fmt = "Revisions are not derived from the same root: " \
746
           "%(revision_a)s %(revision_b)s."
747
974.1.80 by Aaron Bentley
Improved merge error handling and testing
748
    def __init__(self, revision_a, revision_b):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
749
        BzrError.__init__(self, revision_a=revision_a, revision_b=revision_b)
1551.2.1 by Aaron Bentley
recommit 1527 PEP8 fixes
750
1587.1.6 by Robert Collins
Update bound branch implementation to 0.8.
751
974.2.7 by aaron.bentley at utoronto
Merged from bzr.24
752
class NotAncestor(BzrError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
753
754
    _fmt = "Revision %(rev_id)s is not an ancestor of %(not_ancestor_id)s"
755
974.2.7 by aaron.bentley at utoronto
Merged from bzr.24
756
    def __init__(self, rev_id, not_ancestor_id):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
757
        BzrError.__init__(self, rev_id=rev_id,
758
            not_ancestor_id=not_ancestor_id)
1185.1.12 by Robert Collins
merge in lsdiff/filterdiff friendliness
759
760
974.1.30 by aaron.bentley at utoronto
Changed copy_multi to permit failure and return a tuple, tested missing required revisions
761
class InstallFailed(BzrError):
2067.3.2 by Martin Pool
Error cleanup review comments:
762
974.1.30 by aaron.bentley at utoronto
Changed copy_multi to permit failure and return a tuple, tested missing required revisions
763
    def __init__(self, revisions):
2116.3.1 by John Arbash Meinel
Cleanup error tests
764
        revision_str = ", ".join(str(r) for r in revisions)
765
        msg = "Could not install revisions:\n%s" % revision_str
1185.1.14 by Robert Collins
remove more duplicate merged hunks. Bad MERGE3, BAD.
766
        BzrError.__init__(self, msg)
974.1.30 by aaron.bentley at utoronto
Changed copy_multi to permit failure and return a tuple, tested missing required revisions
767
        self.revisions = revisions
1154 by Martin Pool
- fix imports for moved errors
768
769
1614.2.13 by Olaf Conradi
Re-added AmbiguousBase with a deprecated warning.
770
class AmbiguousBase(BzrError):
2067.3.2 by Martin Pool
Error cleanup review comments:
771
1614.2.13 by Olaf Conradi
Re-added AmbiguousBase with a deprecated warning.
772
    def __init__(self, bases):
773
        warn("BzrError AmbiguousBase has been deprecated as of bzrlib 0.8.",
774
                DeprecationWarning)
1759.2.1 by Jelmer Vernooij
Fix some types (found using aspell).
775
        msg = "The correct base is unclear, because %s are all equally close" %\
1614.2.13 by Olaf Conradi
Re-added AmbiguousBase with a deprecated warning.
776
            ", ".join(bases)
777
        BzrError.__init__(self, msg)
778
        self.bases = bases
779
780
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
781
class NoCommits(BzrError):
782
783
    _fmt = "Branch %(branch)s has no commits."
1948.4.20 by John Arbash Meinel
Make NoCommits a BzrNewError
784
974.1.80 by Aaron Bentley
Improved merge error handling and testing
785
    def __init__(self, branch):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
786
        BzrError.__init__(self, branch=branch)
1185.10.1 by Aaron Bentley
Added --basis option to bzr branch
787
1551.2.1 by Aaron Bentley
recommit 1527 PEP8 fixes
788
1185.10.1 by Aaron Bentley
Added --basis option to bzr branch
789
class UnlistableStore(BzrError):
2067.3.2 by Martin Pool
Error cleanup review comments:
790
1185.10.1 by Aaron Bentley
Added --basis option to bzr branch
791
    def __init__(self, store):
792
        BzrError.__init__(self, "Store %s is not listable" % store)
793
1551.2.1 by Aaron Bentley
recommit 1527 PEP8 fixes
794
1587.1.6 by Robert Collins
Update bound branch implementation to 0.8.
795
1185.10.1 by Aaron Bentley
Added --basis option to bzr branch
796
class UnlistableBranch(BzrError):
2067.3.2 by Martin Pool
Error cleanup review comments:
797
1185.10.1 by Aaron Bentley
Added --basis option to bzr branch
798
    def __init__(self, br):
799
        BzrError.__init__(self, "Stores for branch %s are not listable" % br)
1392 by Robert Collins
reinstate testfetch test case
800
801
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
802
class BoundBranchOutOfDate(BzrError):
803
804
    _fmt = "Bound branch %(branch)s is out of date with master branch %(master)s."
2067.3.2 by Martin Pool
Error cleanup review comments:
805
1505.1.24 by John Arbash Meinel
Updated commit to handle bound branches. Included test to handle commit after merge
806
    def __init__(self, branch, master):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
807
        BzrError.__init__(self)
1505.1.24 by John Arbash Meinel
Updated commit to handle bound branches. Included test to handle commit after merge
808
        self.branch = branch
809
        self.master = master
810
811
        
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
812
class CommitToDoubleBoundBranch(BzrError):
813
814
    _fmt = "Cannot commit to branch %(branch)s. It is bound to %(master)s, which is bound to %(remote)s."
2067.3.2 by Martin Pool
Error cleanup review comments:
815
1505.1.24 by John Arbash Meinel
Updated commit to handle bound branches. Included test to handle commit after merge
816
    def __init__(self, branch, master, remote):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
817
        BzrError.__init__(self)
1505.1.24 by John Arbash Meinel
Updated commit to handle bound branches. Included test to handle commit after merge
818
        self.branch = branch
819
        self.master = master
820
        self.remote = remote
821
1505.1.25 by John Arbash Meinel
Updated pull. Now all paths which call set_revision_history maintain the branch invariant. All tests pass.
822
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
823
class OverwriteBoundBranch(BzrError):
824
825
    _fmt = "Cannot pull --overwrite to a branch which is bound %(branch)s"
2067.3.2 by Martin Pool
Error cleanup review comments:
826
1505.1.25 by John Arbash Meinel
Updated pull. Now all paths which call set_revision_history maintain the branch invariant. All tests pass.
827
    def __init__(self, branch):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
828
        BzrError.__init__(self)
1505.1.25 by John Arbash Meinel
Updated pull. Now all paths which call set_revision_history maintain the branch invariant. All tests pass.
829
        self.branch = branch
830
1505.1.29 by John Arbash Meinel
Added special exceptions when unable to contact parent branch. Added tests for failure. bind() no longer updates the remote working tree
831
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
832
class BoundBranchConnectionFailure(BzrError):
833
834
    _fmt = "Unable to connect to target of bound branch %(branch)s => %(target)s: %(error)s"
2067.3.2 by Martin Pool
Error cleanup review comments:
835
1505.1.29 by John Arbash Meinel
Added special exceptions when unable to contact parent branch. Added tests for failure. bind() no longer updates the remote working tree
836
    def __init__(self, branch, target, error):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
837
        BzrError.__init__(self)
1505.1.29 by John Arbash Meinel
Added special exceptions when unable to contact parent branch. Added tests for failure. bind() no longer updates the remote working tree
838
        self.branch = branch
839
        self.target = target
840
        self.error = error
841
842
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
843
class WeaveError(BzrError):
844
845
    _fmt = "Error in processing weave: %(message)s"
1563.2.10 by Robert Collins
Change weave store to be a versioned store, using WeaveFiles which maintain integrity without needing explicit 'put' operations.
846
1185.16.116 by mbp at sourcefrog
Move weave errors into bzrlib.errors and make consistent with new system.
847
    def __init__(self, message=None):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
848
        BzrError.__init__(self)
1185.16.116 by mbp at sourcefrog
Move weave errors into bzrlib.errors and make consistent with new system.
849
        self.message = message
850
851
852
class WeaveRevisionAlreadyPresent(WeaveError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
853
854
    _fmt = "Revision {%(revision_id)s} already present in %(weave)s"
2067.3.2 by Martin Pool
Error cleanup review comments:
855
1185.16.116 by mbp at sourcefrog
Move weave errors into bzrlib.errors and make consistent with new system.
856
    def __init__(self, revision_id, weave):
1563.2.10 by Robert Collins
Change weave store to be a versioned store, using WeaveFiles which maintain integrity without needing explicit 'put' operations.
857
1185.16.116 by mbp at sourcefrog
Move weave errors into bzrlib.errors and make consistent with new system.
858
        WeaveError.__init__(self)
859
        self.revision_id = revision_id
860
        self.weave = weave
861
862
863
class WeaveRevisionNotPresent(WeaveError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
864
865
    _fmt = "Revision {%(revision_id)s} not present in %(weave)s"
1563.2.10 by Robert Collins
Change weave store to be a versioned store, using WeaveFiles which maintain integrity without needing explicit 'put' operations.
866
1185.16.116 by mbp at sourcefrog
Move weave errors into bzrlib.errors and make consistent with new system.
867
    def __init__(self, revision_id, weave):
868
        WeaveError.__init__(self)
869
        self.revision_id = revision_id
870
        self.weave = weave
871
872
873
class WeaveFormatError(WeaveError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
874
875
    _fmt = "Weave invariant violated: %(what)s"
1563.2.10 by Robert Collins
Change weave store to be a versioned store, using WeaveFiles which maintain integrity without needing explicit 'put' operations.
876
1185.16.116 by mbp at sourcefrog
Move weave errors into bzrlib.errors and make consistent with new system.
877
    def __init__(self, what):
878
        WeaveError.__init__(self)
879
        self.what = what
880
881
882
class WeaveParentMismatch(WeaveError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
883
884
    _fmt = "Parents are mismatched between two revisions."
1185.16.116 by mbp at sourcefrog
Move weave errors into bzrlib.errors and make consistent with new system.
885
    
1393.2.1 by John Arbash Meinel
Merged in split-storage-2 branch. Need to cleanup a little bit more still.
886
1185.50.23 by John Arbash Meinel
Adding sha1 check when weave extracts a text.
887
class WeaveInvalidChecksum(WeaveError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
888
889
    _fmt = "Text did not match it's checksum: %(message)s"
890
891
892
class WeaveTextDiffers(WeaveError):
893
894
    _fmt = "Weaves differ on text content. Revision: {%(revision_id)s}, %(weave_a)s, %(weave_b)s"
895
896
    def __init__(self, revision_id, weave_a, weave_b):
897
        WeaveError.__init__(self)
898
        self.revision_id = revision_id
899
        self.weave_a = weave_a
900
        self.weave_b = weave_b
901
902
903
class WeaveTextDiffers(WeaveError):
904
905
    _fmt = "Weaves differ on text content. Revision: {%(revision_id)s}, %(weave_a)s, %(weave_b)s"
906
907
    def __init__(self, revision_id, weave_a, weave_b):
908
        WeaveError.__init__(self)
909
        self.revision_id = revision_id
910
        self.weave_a = weave_a
911
        self.weave_b = weave_b
912
913
914
class VersionedFileError(BzrError):
915
    
916
    _fmt = "Versioned file error"
1563.2.1 by Robert Collins
Merge in a variation of the versionedfile api from versioned-file.
917
918
919
class RevisionNotPresent(VersionedFileError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
920
    
921
    _fmt = "Revision {%(revision_id)s} not present in %(file_id)s."
1563.2.1 by Robert Collins
Merge in a variation of the versionedfile api from versioned-file.
922
923
    def __init__(self, revision_id, file_id):
924
        VersionedFileError.__init__(self)
925
        self.revision_id = revision_id
926
        self.file_id = file_id
927
928
929
class RevisionAlreadyPresent(VersionedFileError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
930
    
931
    _fmt = "Revision {%(revision_id)s} already present in %(file_id)s."
1563.2.1 by Robert Collins
Merge in a variation of the versionedfile api from versioned-file.
932
933
    def __init__(self, revision_id, file_id):
934
        VersionedFileError.__init__(self)
935
        self.revision_id = revision_id
936
        self.file_id = file_id
937
938
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
939
class KnitError(BzrError):
940
    
941
    _fmt = "Knit error"
1563.2.1 by Robert Collins
Merge in a variation of the versionedfile api from versioned-file.
942
943
944
class KnitHeaderError(KnitError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
945
2171.1.1 by John Arbash Meinel
Knit index files should ignore empty indexes rather than consider them corrupt.
946
    _fmt = "Knit header error: %(badline)r unexpected for file %(filename)s"
1563.2.1 by Robert Collins
Merge in a variation of the versionedfile api from versioned-file.
947
2171.1.1 by John Arbash Meinel
Knit index files should ignore empty indexes rather than consider them corrupt.
948
    def __init__(self, badline, filename):
1563.2.1 by Robert Collins
Merge in a variation of the versionedfile api from versioned-file.
949
        KnitError.__init__(self)
950
        self.badline = badline
2171.1.1 by John Arbash Meinel
Knit index files should ignore empty indexes rather than consider them corrupt.
951
        self.filename = filename
1563.2.1 by Robert Collins
Merge in a variation of the versionedfile api from versioned-file.
952
953
954
class KnitCorrupt(KnitError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
955
956
    _fmt = "Knit %(filename)s corrupt: %(how)s"
1563.2.1 by Robert Collins
Merge in a variation of the versionedfile api from versioned-file.
957
958
    def __init__(self, filename, how):
959
        KnitError.__init__(self)
960
        self.filename = filename
961
        self.how = how
962
963
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
964
class NoSuchExportFormat(BzrError):
965
    
966
    _fmt = "Export format %(format)r not supported"
967
1185.31.12 by John Arbash Meinel
Refactored the export code to make it easier to add new export formats.
968
    def __init__(self, format):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
969
        BzrError.__init__(self)
1185.31.12 by John Arbash Meinel
Refactored the export code to make it easier to add new export formats.
970
        self.format = format
971
972
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
973
class TransportError(BzrError):
974
    
975
    _fmt = "Transport error: %(msg)s %(orig_error)s"
1824.2.1 by Johan Rydberg
Let TransportError inherit BzrNerError.
976
1185.11.9 by John Arbash Meinel
Most tests pass, some problems with unavailable socket recv
977
    def __init__(self, msg=None, orig_error=None):
978
        if msg is None and orig_error is not None:
979
            msg = str(orig_error)
1824.2.1 by Johan Rydberg
Let TransportError inherit BzrNerError.
980
        if orig_error is None:
981
            orig_error = ''
982
        if msg is None:
983
            msg =  ''
1185.11.9 by John Arbash Meinel
Most tests pass, some problems with unavailable socket recv
984
        self.msg = msg
985
        self.orig_error = orig_error
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
986
        BzrError.__init__(self)
1185.11.9 by John Arbash Meinel
Most tests pass, some problems with unavailable socket recv
987
1551.2.1 by Aaron Bentley
recommit 1527 PEP8 fixes
988
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
989
class TooManyConcurrentRequests(BzrError):
990
991
    _fmt = ("The medium '%(medium)s' has reached its concurrent request limit. "
992
            "Be sure to finish_writing and finish_reading on the "
993
            "current request that is open.")
994
995
    internal_error = True
996
997
    def __init__(self, medium):
998
        self.medium = medium
1185.11.9 by John Arbash Meinel
Most tests pass, some problems with unavailable socket recv
999
1551.2.1 by Aaron Bentley
recommit 1527 PEP8 fixes
1000
1910.19.14 by Robert Collins
Fix up all tests to pass, remove a couple more deprecated function calls, and break the dependency on sftp for the smart transport.
1001
class SmartProtocolError(TransportError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1002
1003
    _fmt = "Generic bzr smart protocol error: %(details)s"
1910.19.13 by Andrew Bennetts
Address various review comments.
1004
1005
    def __init__(self, details):
1006
        self.details = details
1007
1008
1185.11.9 by John Arbash Meinel
Most tests pass, some problems with unavailable socket recv
1009
# A set of semi-meaningful errors which can be thrown
1010
class TransportNotPossible(TransportError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1011
1012
    _fmt = "Transport operation not possible: %(msg)s %(orig_error)s"
1185.11.9 by John Arbash Meinel
Most tests pass, some problems with unavailable socket recv
1013
1185.31.44 by John Arbash Meinel
Cleaned up Exceptions for all transports.
1014
1015
class ConnectionError(TransportError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1016
1017
    _fmt = "Connection error: %(msg)s %(orig_error)s"
1185.31.44 by John Arbash Meinel
Cleaned up Exceptions for all transports.
1018
1185.11.9 by John Arbash Meinel
Most tests pass, some problems with unavailable socket recv
1019
2052.4.4 by John Arbash Meinel
Create a SocketConnectionError to make creating nice errors easier
1020
class SocketConnectionError(ConnectionError):
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
1021
1022
    _fmt = "%(msg)s %(host)s%(port)s%(orig_error)s"
2052.4.4 by John Arbash Meinel
Create a SocketConnectionError to make creating nice errors easier
1023
1024
    def __init__(self, host, port=None, msg=None, orig_error=None):
1025
        if msg is None:
1026
            msg = 'Failed to connect to'
1027
        if orig_error is None:
1028
            orig_error = ''
1029
        else:
1030
            orig_error = '; ' + str(orig_error)
1031
        ConnectionError.__init__(self, msg=msg, orig_error=orig_error)
1032
        self.host = host
1033
        if port is None:
1034
            self.port = ''
1035
        else:
1036
            self.port = ':%s' % port
1037
1038
1185.11.9 by John Arbash Meinel
Most tests pass, some problems with unavailable socket recv
1039
class ConnectionReset(TransportError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1040
1041
    _fmt = "Connection closed: %(msg)s %(orig_error)s"
1185.11.9 by John Arbash Meinel
Most tests pass, some problems with unavailable socket recv
1042
1551.2.1 by Aaron Bentley
recommit 1527 PEP8 fixes
1043
1786.1.8 by John Arbash Meinel
[merge] Johan Rydberg test updates
1044
class InvalidRange(TransportError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1045
1046
    _fmt = "Invalid range access in %(path)s at %(offset)s."
1786.1.8 by John Arbash Meinel
[merge] Johan Rydberg test updates
1047
    
1048
    def __init__(self, path, offset):
1049
        TransportError.__init__(self, ("Invalid range access in %s at %d"
1050
                                       % (path, offset)))
1979.1.1 by John Arbash Meinel
Fix bug #57723, parse boundary="" correctly, since Squid uses it
1051
        self.path = path
1052
        self.offset = offset
1786.1.8 by John Arbash Meinel
[merge] Johan Rydberg test updates
1053
1054
1786.1.17 by John Arbash Meinel
Adding tests for _parse_boundary.
1055
class InvalidHttpResponse(TransportError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1056
1057
    _fmt = "Invalid http response for %(path)s: %(msg)s"
1786.1.17 by John Arbash Meinel
Adding tests for _parse_boundary.
1058
1786.1.31 by John Arbash Meinel
Update http errors to properly use BzrNewError
1059
    def __init__(self, path, msg, orig_error=None):
1786.1.17 by John Arbash Meinel
Adding tests for _parse_boundary.
1060
        self.path = path
1786.1.31 by John Arbash Meinel
Update http errors to properly use BzrNewError
1061
        TransportError.__init__(self, msg, orig_error=orig_error)
1786.1.17 by John Arbash Meinel
Adding tests for _parse_boundary.
1062
1063
1064
class InvalidHttpRange(InvalidHttpResponse):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1065
1066
    _fmt = "Invalid http range %(range)r for %(path)s: %(msg)s"
1786.1.13 by John Arbash Meinel
Found a few bugs in error handling code, updated tests
1067
    
1068
    def __init__(self, path, range, msg):
1069
        self.range = range
1786.1.17 by John Arbash Meinel
Adding tests for _parse_boundary.
1070
        InvalidHttpResponse.__init__(self, path, msg)
1071
1072
1073
class InvalidHttpContentType(InvalidHttpResponse):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1074
1075
    _fmt = 'Invalid http Content-type "%(ctype)s" for %(path)s: %(msg)s'
1786.1.17 by John Arbash Meinel
Adding tests for _parse_boundary.
1076
    
1077
    def __init__(self, path, ctype, msg):
1078
        self.ctype = ctype
1079
        InvalidHttpResponse.__init__(self, path, msg)
1786.1.13 by John Arbash Meinel
Found a few bugs in error handling code, updated tests
1080
1081
1185.14.10 by Aaron Bentley
Commit aborts with conflicts in the tree.
1082
class ConflictsInTree(BzrError):
2067.3.2 by Martin Pool
Error cleanup review comments:
1083
1084
    _fmt = "Working tree has conflicts."
1185.12.49 by Aaron Bentley
Switched to ConfigObj
1085
1551.2.1 by Aaron Bentley
recommit 1527 PEP8 fixes
1086
1185.12.49 by Aaron Bentley
Switched to ConfigObj
1087
class ParseConfigError(BzrError):
2067.3.2 by Martin Pool
Error cleanup review comments:
1088
1185.12.49 by Aaron Bentley
Switched to ConfigObj
1089
    def __init__(self, errors, filename):
1090
        if filename is None:
1091
            filename = ""
1092
        message = "Error(s) parsing config file %s:\n%s" % \
1093
            (filename, ('\n'.join(e.message for e in errors)))
1094
        BzrError.__init__(self, message)
1185.12.52 by Aaron Bentley
Merged more config stuff from Robert
1095
1551.2.1 by Aaron Bentley
recommit 1527 PEP8 fixes
1096
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1097
class NoEmailInUsername(BzrError):
1098
1099
    _fmt = "%(username)r does not seem to contain a reasonable email address"
2055.2.2 by John Arbash Meinel
Switch extract_email_address() to use a more specific exception
1100
1101
    def __init__(self, username):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1102
        BzrError.__init__(self)
2055.2.2 by John Arbash Meinel
Switch extract_email_address() to use a more specific exception
1103
        self.username = username
1104
1105
1442.1.58 by Robert Collins
gpg signing of content
1106
class SigningFailed(BzrError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1107
1108
    _fmt = "Failed to gpg sign data with command %(command_line)r"
1109
1442.1.58 by Robert Collins
gpg signing of content
1110
    def __init__(self, command_line):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1111
        BzrError.__init__(self, command_line=command_line)
1185.12.83 by Aaron Bentley
Preliminary weave merge support
1112
1551.2.1 by Aaron Bentley
recommit 1527 PEP8 fixes
1113
1185.12.83 by Aaron Bentley
Preliminary weave merge support
1114
class WorkingTreeNotRevision(BzrError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1115
1116
    _fmt = ("The working tree for %(basedir)s has changed since" 
1117
            " the last commit, but weave merge requires that it be"
1118
            " unchanged")
1119
1185.12.83 by Aaron Bentley
Preliminary weave merge support
1120
    def __init__(self, tree):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1121
        BzrError.__init__(self, basedir=tree.basedir)
1122
1123
1124
class CantReprocessAndShowBase(BzrError):
1125
1126
    _fmt = "Can't reprocess and show base, because reprocessing obscures " \
1127
           "the relationship of conflicting lines to the base"
1128
1129
1130
class GraphCycleError(BzrError):
1131
1132
    _fmt = "Cycle in graph %(graph)r"
2067.3.2 by Martin Pool
Error cleanup review comments:
1133
1185.16.114 by mbp at sourcefrog
Improved topological sort
1134
    def __init__(self, graph):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1135
        BzrError.__init__(self)
1185.16.114 by mbp at sourcefrog
Improved topological sort
1136
        self.graph = graph
1185.35.1 by Aaron Bentley
Implemented conflicts.restore
1137
1505.1.23 by John Arbash Meinel
Whitespace cleanup of bzrlib.errors
1138
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
1139
class WritingCompleted(BzrError):
1140
1141
    _fmt = ("The MediumRequest '%(request)s' has already had finish_writing "
1142
            "called upon it - accept bytes may not be called anymore.")
1143
1144
    internal_error = True
1145
1146
    def __init__(self, request):
1147
        self.request = request
1148
1149
1150
class WritingNotComplete(BzrError):
1151
1152
    _fmt = ("The MediumRequest '%(request)s' has not has finish_writing "
1153
            "called upon it - until the write phase is complete no "
1154
            "data may be read.")
1155
1156
    internal_error = True
1157
1158
    def __init__(self, request):
1159
        self.request = request
1160
1161
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1162
class NotConflicted(BzrError):
1163
1164
    _fmt = "File %(filename)s is not conflicted."
1534.3.1 by Robert Collins
* bzrlib.osutils.safe_unicode now exists to provide parameter coercion
1165
1185.35.1 by Aaron Bentley
Implemented conflicts.restore
1166
    def __init__(self, filename):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1167
        BzrError.__init__(self)
1185.35.1 by Aaron Bentley
Implemented conflicts.restore
1168
        self.filename = filename
1185.35.13 by Aaron Bentley
Merged Martin
1169
1505.1.23 by John Arbash Meinel
Whitespace cleanup of bzrlib.errors
1170
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
1171
class MediumNotConnected(BzrError):
1172
1173
    _fmt = """The medium '%(medium)s' is not connected."""
1174
1175
    internal_error = True
2018.2.3 by Andrew Bennetts
Starting factoring out the smart server client "medium" from the protocol.
1176
1177
    def __init__(self, medium):
1178
        self.medium = medium
1179
1180
1492 by Robert Collins
Support decoration of commands.
1181
class MustUseDecorated(Exception):
2067.3.2 by Martin Pool
Error cleanup review comments:
1182
    
1183
    _fmt = """A decorating function has requested its original command be used."""
1184
    
1185.82.3 by John Arbash Meinel
Working on creating a factor for serializing changesets.
1185
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1186
class NoBundleFound(BzrError):
1187
1188
    _fmt = "No bundle was found in %(filename)s"
2067.3.2 by Martin Pool
Error cleanup review comments:
1189
1185.82.3 by John Arbash Meinel
Working on creating a factor for serializing changesets.
1190
    def __init__(self, filename):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1191
        BzrError.__init__(self)
1185.82.3 by John Arbash Meinel
Working on creating a factor for serializing changesets.
1192
        self.filename = filename
1193
1194
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1195
class BundleNotSupported(BzrError):
1196
1197
    _fmt = "Unable to handle bundle version %(version)s: %(msg)s"
2067.3.2 by Martin Pool
Error cleanup review comments:
1198
1185.82.3 by John Arbash Meinel
Working on creating a factor for serializing changesets.
1199
    def __init__(self, version, msg):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1200
        BzrError.__init__(self)
1185.82.3 by John Arbash Meinel
Working on creating a factor for serializing changesets.
1201
        self.version = version
1202
        self.msg = msg
1203
1204
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1205
class MissingText(BzrError):
1206
1207
    _fmt = "Branch %(base)s is missing revision %(text_revision)s of %(file_id)s"
1534.3.1 by Robert Collins
* bzrlib.osutils.safe_unicode now exists to provide parameter coercion
1208
1185.35.42 by Aaron Bentley
Fixed fetch to be safer wrt ghosts and corrupt branches
1209
    def __init__(self, branch, text_revision, file_id):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1210
        BzrError.__init__(self)
1185.35.42 by Aaron Bentley
Fixed fetch to be safer wrt ghosts and corrupt branches
1211
        self.branch = branch
1212
        self.base = branch.base
1213
        self.text_revision = text_revision
1214
        self.file_id = file_id
1534.7.5 by Aaron Bentley
Got unique_add under test
1215
1505.1.23 by John Arbash Meinel
Whitespace cleanup of bzrlib.errors
1216
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1217
class DuplicateKey(BzrError):
1218
1219
    _fmt = "Key %(key)s is already present in map"
1220
1221
1222
class MalformedTransform(BzrError):
1223
1224
    _fmt = "Tree transform is malformed %(conflicts)r"
1225
1226
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
1227
class NoFinalPath(BzrError):
1228
1229
    _fmt = ("No final name for trans_id %(trans_id)r\n"
1230
            "file-id: %(file_id)r\n"
1231
            "root trans-id: %(root_trans_id)r\n")
1731.1.33 by Aaron Bentley
Revert no-special-root changes
1232
1233
    def __init__(self, trans_id, transform):
1234
        self.trans_id = trans_id
1235
        self.file_id = transform.final_file_id(trans_id)
1236
        self.root_trans_id = transform.root
1237
1238
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1239
class BzrBadParameter(BzrError):
1240
1241
    _fmt = "Bad parameter: %(param)r"
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
1242
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1243
    # This exception should never be thrown, but it is a base class for all
1244
    # parameter-to-function errors.
1245
1534.3.1 by Robert Collins
* bzrlib.osutils.safe_unicode now exists to provide parameter coercion
1246
    def __init__(self, param):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1247
        BzrError.__init__(self)
1534.3.1 by Robert Collins
* bzrlib.osutils.safe_unicode now exists to provide parameter coercion
1248
        self.param = param
1534.7.32 by Aaron Bentley
Got conflict handling working when conflicts involve existing files
1249
1534.4.3 by Robert Collins
Implement BranchTestProviderAdapter, so tests now run across all branch formats.
1250
1185.65.29 by Robert Collins
Implement final review suggestions.
1251
class BzrBadParameterNotUnicode(BzrBadParameter):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1252
1253
    _fmt = "Parameter %(param)s is neither unicode nor utf8."
1254
1255
1256
class ReusingTransform(BzrError):
1257
1258
    _fmt = "Attempt to reuse a transform that has already been applied."
1259
1260
1261
class CantMoveRoot(BzrError):
1262
1263
    _fmt = "Moving the root directory is not supported at this time"
1185.65.29 by Robert Collins
Implement final review suggestions.
1264
1534.7.120 by Aaron Bentley
PEP8 fixes
1265
1185.65.29 by Robert Collins
Implement final review suggestions.
1266
class BzrBadParameterNotString(BzrBadParameter):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1267
1268
    _fmt = "Parameter %(param)s is not a string or unicode string."
1185.62.24 by John Arbash Meinel
Changing the exception that sftp.py throws when it can't find paramiko, so that the test suite can handle it.
1269
1270
1534.4.44 by Robert Collins
Make a new BzrDir format that uses a versioned branch format in a branch/ subdirectory.
1271
class BzrBadParameterMissing(BzrBadParameter):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1272
1273
    _fmt = "Parameter $(param)s is required but not present."
1534.4.44 by Robert Collins
Make a new BzrDir format that uses a versioned branch format in a branch/ subdirectory.
1274
1275
1666.1.6 by Robert Collins
Make knit the default format.
1276
class BzrBadParameterUnicode(BzrBadParameter):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1277
1278
    _fmt = "Parameter %(param)s is unicode but only byte-strings are permitted."
1666.1.6 by Robert Collins
Make knit the default format.
1279
1280
1281
class BzrBadParameterContainsNewline(BzrBadParameter):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1282
1283
    _fmt = "Parameter %(param)s contains a newline."
1284
1285
1286
class DependencyNotPresent(BzrError):
1287
1288
    _fmt = 'Unable to import library "%(library)s": %(error)s'
1185.62.24 by John Arbash Meinel
Changing the exception that sftp.py throws when it can't find paramiko, so that the test suite can handle it.
1289
1290
    def __init__(self, library, error):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1291
        BzrError.__init__(self, library=library, error=error)
1185.62.24 by John Arbash Meinel
Changing the exception that sftp.py throws when it can't find paramiko, so that the test suite can handle it.
1292
1293
1294
class ParamikoNotPresent(DependencyNotPresent):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1295
1296
    _fmt = "Unable to import paramiko (required for sftp support): %(error)s"
1185.62.24 by John Arbash Meinel
Changing the exception that sftp.py throws when it can't find paramiko, so that the test suite can handle it.
1297
1298
    def __init__(self, error):
1299
        DependencyNotPresent.__init__(self, 'paramiko', error)
1300
1301
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1302
class PointlessMerge(BzrError):
1303
1304
    _fmt = "Nothing to merge."
1305
1306
1307
class UninitializableFormat(BzrError):
1308
1309
    _fmt = "Format %(format)s cannot be initialised by this version of bzr."
1534.4.3 by Robert Collins
Implement BranchTestProviderAdapter, so tests now run across all branch formats.
1310
1311
    def __init__(self, format):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1312
        BzrError.__init__(self)
1534.4.3 by Robert Collins
Implement BranchTestProviderAdapter, so tests now run across all branch formats.
1313
        self.format = format
1551.3.4 by Aaron Bentley
Implemented default command options
1314
1534.7.156 by Aaron Bentley
PEP8 fixes
1315
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1316
class BadConversionTarget(BzrError):
1317
1318
    _fmt = "Cannot convert to format %(format)s.  %(problem)s"
1910.2.12 by Aaron Bentley
Implement knit repo format 2
1319
1320
    def __init__(self, problem, format):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1321
        BzrError.__init__(self)
1910.2.12 by Aaron Bentley
Implement knit repo format 2
1322
        self.problem = problem
1323
        self.format = format
1324
1325
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1326
class NoDiff(BzrError):
1327
1328
    _fmt = "Diff is not installed on this machine: %(msg)s"
1711.2.56 by John Arbash Meinel
Raise NoDiff if 'diff' not present.
1329
1330
    def __init__(self, msg):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1331
        BzrError.__init__(self, msg=msg)
1332
1333
1334
class NoDiff3(BzrError):
1335
1336
    _fmt = "Diff3 is not installed on this machine."
1337
1338
1339
class ExistingLimbo(BzrError):
1340
1341
    _fmt = """This tree contains left-over files from a failed operation.
1342
    Please examine %(limbo_dir)s to see if it contains any files you wish to
1343
    keep, and delete it when you are done."""
1344
    
1345
    def __init__(self, limbo_dir):
1346
       BzrError.__init__(self)
1347
       self.limbo_dir = limbo_dir
1348
1349
1350
class ImmortalLimbo(BzrError):
1351
1352
    _fmt = """Unable to delete transform temporary directory $(limbo_dir)s.
1353
    Please examine %(limbo_dir)s to see if it contains any files you wish to
1354
    keep, and delete it when you are done."""
1355
1356
    def __init__(self, limbo_dir):
1357
       BzrError.__init__(self)
1358
       self.limbo_dir = limbo_dir
1359
1360
1361
class OutOfDateTree(BzrError):
1362
1363
    _fmt = "Working tree is out of date, please run 'bzr update'."
1508.1.25 by Robert Collins
Update per review comments.
1364
1365
    def __init__(self, tree):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1366
        BzrError.__init__(self)
1508.1.25 by Robert Collins
Update per review comments.
1367
        self.tree = tree
1534.7.196 by Aaron Bentley
Switched to Rio format for merge-modified list
1368
1563.2.22 by Robert Collins
Move responsibility for repository.has_revision into RevisionStore
1369
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1370
class MergeModifiedFormatError(BzrError):
1371
1372
    _fmt = "Error in merge modified format"
1373
1374
1375
class ConflictFormatError(BzrError):
1376
1377
    _fmt = "Format error in conflict listings"
1378
1379
1380
class CorruptRepository(BzrError):
1381
1382
    _fmt = """An error has been detected in the repository %(repo_path)s.
1570.1.13 by Robert Collins
Check for incorrect revision parentage in the weave during revision access.
1383
Please run bzr reconcile on this repository."""
1384
1385
    def __init__(self, repo):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1386
        BzrError.__init__(self)
1570.1.13 by Robert Collins
Check for incorrect revision parentage in the weave during revision access.
1387
        self.repo_path = repo.bzrdir.root_transport.base
1587.1.6 by Robert Collins
Update bound branch implementation to 0.8.
1388
1389
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1390
class UpgradeRequired(BzrError):
1391
1392
    _fmt = "To use this feature you must upgrade your branch at %(path)s."
1587.1.6 by Robert Collins
Update bound branch implementation to 0.8.
1393
1394
    def __init__(self, path):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1395
        BzrError.__init__(self)
1587.1.6 by Robert Collins
Update bound branch implementation to 0.8.
1396
        self.path = path
1397
1587.1.8 by Robert Collins
Local commits on unbound branches fail.
1398
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1399
class LocalRequiresBoundBranch(BzrError):
1400
1401
    _fmt = "Cannot perform local-only commits on unbound branches."
1402
1403
1404
class MissingProgressBarFinish(BzrError):
1405
1406
    _fmt = "A nested progress bar was not 'finished' correctly."
1407
1408
1409
class InvalidProgressBarType(BzrError):
1410
1411
    _fmt = """Environment variable BZR_PROGRESS_BAR='%(bar_type)s is not a supported type
1843.3.7 by John Arbash Meinel
new env var 'BZR_PROGRESS_BAR' to select the exact progress type
1412
Select one of: %(valid_types)s"""
1413
1414
    def __init__(self, bar_type, valid_types):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1415
        BzrError.__init__(self, bar_type=bar_type, valid_types=valid_types)
1416
1417
1418
class UnsupportedOperation(BzrError):
1419
1420
    _fmt = "The method %(mname)s is not supported on objects of type %(tname)s."
2067.3.2 by Martin Pool
Error cleanup review comments:
1421
1534.10.8 by Aaron Bentley
Implemented conflict_lines in terms of old system on WorkingTree
1422
    def __init__(self, method, method_self):
1423
        self.method = method
1424
        self.mname = method.__name__
1425
        self.tname = type(method_self).__name__
1558.15.1 by Aaron Bentley
Add text_file function
1426
1427
2150.2.2 by Robert Collins
Change the commit builder selected-revision-id test to use a unicode revision id where possible, leading to stricter testing of the hypothetical unicode revision id support in bzr.
1428
class CannotSetRevisionId(UnsupportedOperation):
1429
    """Raised when a commit is attempting to set a revision id but cant."""
1430
1431
1432
class NonAsciiRevisionId(UnsupportedOperation):
1433
    """Raised when a commit is attempting to set a non-ascii revision id but cant."""
1434
1435
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1436
class BinaryFile(BzrError):
1437
    
1438
    _fmt = "File is binary but should be text."
1439
1440
1441
class IllegalPath(BzrError):
1442
1443
    _fmt = "The path %(path)s is not permitted on this platform"
1551.2.55 by abentley
Fix fileid involed tests on win32 (by skipping them for unescaped weave formats)
1444
1445
    def __init__(self, path):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1446
        BzrError.__init__(self)
1551.2.55 by abentley
Fix fileid involed tests on win32 (by skipping them for unescaped weave formats)
1447
        self.path = path
1185.82.118 by Aaron Bentley
Ensure that StrictTestament handles execute bit differences
1448
1449
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1450
class TestamentMismatch(BzrError):
1451
1452
    _fmt = """Testament did not match expected value.  
1185.82.118 by Aaron Bentley
Ensure that StrictTestament handles execute bit differences
1453
       For revision_id {%(revision_id)s}, expected {%(expected)s}, measured 
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1454
       {%(measured)s}"""
1455
1185.82.118 by Aaron Bentley
Ensure that StrictTestament handles execute bit differences
1456
    def __init__(self, revision_id, expected, measured):
1457
        self.revision_id = revision_id
1458
        self.expected = expected
1459
        self.measured = measured
1185.82.131 by Aaron Bentley
Move BadBundle error (and subclasses) to errors.py
1460
1461
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1462
class NotABundle(BzrError):
1463
    
1464
    _fmt = "Not a bzr revision-bundle: %(text)r"
1185.82.142 by Aaron Bentley
Update for review comments
1465
1185.82.139 by Aaron Bentley
Raise NotABundle when a non-bundle is supplied
1466
    def __init__(self, text):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1467
        BzrError.__init__(self)
1907.2.1 by Hermann Kraus
Convert bundle errors from Exception to BzrNewError.
1468
        self.text = text
1469
1470
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1471
class BadBundle(BzrError): 
1472
    
1473
    _fmt = "Bad bzr revision-bundle: %(text)r"
1907.2.1 by Hermann Kraus
Convert bundle errors from Exception to BzrNewError.
1474
1475
    def __init__(self, text):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1476
        BzrError.__init__(self)
1907.2.1 by Hermann Kraus
Convert bundle errors from Exception to BzrNewError.
1477
        self.text = text
1478
1479
1480
class MalformedHeader(BadBundle): 
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1481
    
1482
    _fmt = "Malformed bzr revision-bundle header: %(text)r"
1907.2.1 by Hermann Kraus
Convert bundle errors from Exception to BzrNewError.
1483
1484
1485
class MalformedPatches(BadBundle): 
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1486
    
1487
    _fmt = "Malformed patches in bzr revision-bundle: %(text)r"
1907.2.1 by Hermann Kraus
Convert bundle errors from Exception to BzrNewError.
1488
1489
1490
class MalformedFooter(BadBundle): 
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1491
    
1492
    _fmt = "Malformed footer in bzr revision-bundle: %(text)r"
1907.2.2 by Hermann Kraus
Detect wrong eol markers.
1493
1752.3.14 by Andrew Bennetts
Fix shallow bug (bad conflict resolution?) in errors.UnsupportedEOLMarker
1494
1907.2.2 by Hermann Kraus
Detect wrong eol markers.
1495
class UnsupportedEOLMarker(BadBundle):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1496
    
1497
    _fmt = "End of line marker was not \\n in bzr revision-bundle"    
1907.2.2 by Hermann Kraus
Detect wrong eol markers.
1498
1499
    def __init__(self):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1500
        # XXX: BadBundle's constructor assumes there's explanatory text, 
1501
        # but for this there is not
1502
        BzrError.__init__(self)
1503
1504
1505
class IncompatibleBundleFormat(BzrError):
1506
    
1507
    _fmt = "Bundle format %(bundle_format)s is incompatible with %(other)s"
1910.2.49 by Aaron Bentley
Ensure that 0.8 bundles aren't used with KnitRepository2
1508
1509
    def __init__(self, bundle_format, other):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1510
        BzrError.__init__(self)
1910.2.49 by Aaron Bentley
Ensure that 0.8 bundles aren't used with KnitRepository2
1511
        self.bundle_format = bundle_format
1512
        self.other = other
1513
1514
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1515
class BadInventoryFormat(BzrError):
1516
    
1517
    _fmt = "Root class for inventory serialization errors"
1910.2.31 by Aaron Bentley
Fix bugs in basis inventory handling, change filename
1518
1519
1520
class UnexpectedInventoryFormat(BadInventoryFormat):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1521
1522
    _fmt = "The inventory was not in the expected format:\n %(msg)s"
1910.2.31 by Aaron Bentley
Fix bugs in basis inventory handling, change filename
1523
1524
    def __init__(self, msg):
1525
        BadInventoryFormat.__init__(self, msg=msg)
1910.2.47 by Aaron Bentley
Merge bzr.dev
1526
1527
2067.3.3 by Martin Pool
merge bzr.dev and reconcile several changes, also some test fixes
1528
class NoSmartMedium(BzrError):
1529
1530
    _fmt = "The transport '%(transport)s' cannot tunnel the smart protocol."
2018.2.3 by Andrew Bennetts
Starting factoring out the smart server client "medium" from the protocol.
1531
1532
    def __init__(self, transport):
1533
        self.transport = transport
1534
1535
1910.19.2 by Andrew Bennetts
Add a new method ``Transport.get_smart_client()``. This is provided to allow
1536
class NoSmartServer(NotBranchError):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1537
1538
    _fmt = "No smart server available at %(url)s"
1910.19.2 by Andrew Bennetts
Add a new method ``Transport.get_smart_client()``. This is provided to allow
1539
1540
    def __init__(self, url):
1541
        self.url = url
1752.3.9 by Andrew Bennetts
Merge from bzr.dev
1542
1752.5.3 by Andrew Bennetts
Merge from sftp refactoring 2.
1543
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1544
class UnknownSSH(BzrError):
1545
1546
    _fmt = "Unrecognised value for BZR_SSH environment variable: %(vendor)s"
1951.1.8 by Andrew Bennetts
Make _get_ssh_vendor return the vendor object, rather than just a string.
1547
1548
    def __init__(self, vendor):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1549
        BzrError.__init__(self)
1951.1.8 by Andrew Bennetts
Make _get_ssh_vendor return the vendor object, rather than just a string.
1550
        self.vendor = vendor
1551
1908.5.16 by Robert Collins
Merge bzr.dev to resolve conflicts for merging.
1552
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1553
class GhostRevisionUnusableHere(BzrError):
1554
1555
    _fmt = "Ghost revision {%(revision_id)s} cannot be used here."
1908.5.9 by Robert Collins
Add a guard against setting the tree last-revision value to a ghost in the new tree parent management api.
1556
1557
    def __init__(self, revision_id):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1558
        BzrError.__init__(self)
1908.5.9 by Robert Collins
Add a guard against setting the tree last-revision value to a ghost in the new tree parent management api.
1559
        self.revision_id = revision_id
1996.1.16 by John Arbash Meinel
Raise an exception when ScopeReplacer has been misused
1560
1561
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1562
class IllegalUseOfScopeReplacer(BzrError):
1563
1564
    _fmt = "ScopeReplacer object %(name)r was used incorrectly: %(msg)s%(extra)s"
1996.1.16 by John Arbash Meinel
Raise an exception when ScopeReplacer has been misused
1565
2067.3.2 by Martin Pool
Error cleanup review comments:
1566
    internal_error = True
1996.1.16 by John Arbash Meinel
Raise an exception when ScopeReplacer has been misused
1567
1568
    def __init__(self, name, msg, extra=None):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1569
        BzrError.__init__(self)
1996.1.16 by John Arbash Meinel
Raise an exception when ScopeReplacer has been misused
1570
        self.name = name
1571
        self.msg = msg
1572
        if extra:
1573
            self.extra = ': ' + str(extra)
1574
        else:
1575
            self.extra = ''
1576
1996.1.18 by John Arbash Meinel
Add more structured error handling
1577
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1578
class InvalidImportLine(BzrError):
1579
1580
    _fmt = "Not a valid import statement: %(msg)\n%(text)s"
1996.1.18 by John Arbash Meinel
Add more structured error handling
1581
2067.3.2 by Martin Pool
Error cleanup review comments:
1582
    internal_error = True
1996.1.18 by John Arbash Meinel
Add more structured error handling
1583
1584
    def __init__(self, text, msg):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1585
        BzrError.__init__(self)
1996.1.18 by John Arbash Meinel
Add more structured error handling
1586
        self.text = text
1587
        self.msg = msg
1588
1589
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1590
class ImportNameCollision(BzrError):
1591
1592
    _fmt = "Tried to import an object to the same name as an existing object. %(name)s"
1996.1.18 by John Arbash Meinel
Add more structured error handling
1593
2067.3.2 by Martin Pool
Error cleanup review comments:
1594
    internal_error = True
1996.1.18 by John Arbash Meinel
Add more structured error handling
1595
1596
    def __init__(self, name):
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
1597
        BzrError.__init__(self)
1996.1.18 by John Arbash Meinel
Add more structured error handling
1598
        self.name = name