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