bzr branch
http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
| 1553.5.24
by Martin Pool Warning to check storage when lock was broken | 1 | # Copyright (C) 2005, 2006 Canonical
 | 
| 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 | ||
| 1740.5.6
by Martin Pool Clean up many exception classes. | 19 | There are 3 different classes of error:
 | 
| 20 | ||
| 21 |  * KeyboardInterrupt, and OSError with EPIPE - the program terminates 
 | |
| 22 |    with an appropriate short message
 | |
| 23 | ||
| 24 |  * User errors, indicating a problem caused by the user such as a bad URL.
 | |
| 25 |    These are printed in a short form.
 | |
| 26 |  
 | |
| 27 |  * Internal unexpected errors, including most Python builtin errors
 | |
| 28 |    and some raised from inside bzr.  These are printed with a full 
 | |
| 29 |    traceback and an invitation to report the bug.
 | |
| 30 | ||
| 1185.16.61
by mbp at sourcefrog - start introducing hct error classes | 31 | Exceptions are caught at a high level to report errors to the user, and
 | 
| 32 | might also be caught inside the program.  Therefore it needs to be
 | |
| 33 | possible to convert them to a meaningful string, and also for them to be
 | |
| 34 | interrogated by the program.
 | |
| 35 | ||
| 36 | Exceptions are defined such that the arguments given to the constructor
 | |
| 37 | are stored in the object as properties of the same name.  When the
 | |
| 38 | object is printed as a string, the doc string of the class is used as
 | |
| 39 | a format string with the property dictionary available to it.
 | |
| 40 | ||
| 41 | This means that exceptions can used like this:
 | |
| 42 | ||
| 43 | >>> import sys
 | |
| 44 | >>> try:
 | |
| 45 | ...   raise NotBranchError(path='/foo/bar')
 | |
| 46 | ... except:
 | |
| 47 | ...   print sys.exc_type
 | |
| 48 | ...   print sys.exc_value
 | |
| 1551.6.23
by Aaron Bentley Added None to getattr for case where error doesn't has have path | 49 | ...   path = getattr(sys.exc_value, 'path', None)
 | 
| 1185.50.38
by John Arbash Meinel Changed exception traceback route to not use hasattr, which generates its own exception. | 50 | ...   if path is not None:
 | 
| 51 | ...     print path
 | |
| 1185.16.61
by mbp at sourcefrog - start introducing hct error classes | 52 | bzrlib.errors.NotBranchError
 | 
| 53 | Not a branch: /foo/bar
 | |
| 54 | /foo/bar
 | |
| 55 | ||
| 56 | Therefore:
 | |
| 57 | ||
| 58 |  * create a new exception class for any class of error that can be
 | |
| 1740.5.6
by Martin Pool Clean up many exception classes. | 59 |    usefully distinguished.  If no callers are likely to want to catch
 | 
| 60 |    one but not another, don't worry about them.
 | |
| 61 | ||
| 62 |  * the __str__ method should generate something useful; BzrError provides
 | |
| 63 |    a good default implementation
 | |
| 64 | ||
| 65 | Exception strings should start with a capital letter and should not have a
 | |
| 66 | final fullstop.
 | |
| 1185.16.61
by mbp at sourcefrog - start introducing hct error classes | 67 | """
 | 
| 68 | ||
| 1614.2.13
by Olaf Conradi Re-added AmbiguousBase with a deprecated warning. | 69 | from warnings import warn | 
| 70 | ||
| 1185.82.128
by Aaron Bentley Provide errors from bzrlib.patches in bzrlib.errors | 71 | from bzrlib.patches import (PatchSyntax, | 
| 72 | PatchConflict, | |
| 73 | MalformedPatchHeader, | |
| 74 | MalformedHunkHeader, | |
| 75 | MalformedLine,) | |
| 76 | ||
| 77 | ||
| 1185.16.61
by mbp at sourcefrog - start introducing hct error classes | 78 | # based on Scott James Remnant's hct error classes
 | 
| 79 | ||
| 1185.16.62
by mbp at sourcefrog - convert NotBranchError to new exception base | 80 | # TODO: is there any value in providing the .args field used by standard
 | 
| 81 | # python exceptions?   A list of values with no names seems less useful 
 | |
| 82 | # to me.
 | |
| 83 | ||
| 1185.16.63
by Martin Pool - more error conversion | 84 | # TODO: Perhaps convert the exception to a string at the moment it's 
 | 
| 85 | # constructed to make sure it will succeed.  But that says nothing about
 | |
| 86 | # exceptions that are never raised.
 | |
| 87 | ||
| 88 | # TODO: Convert all the other error classes here to BzrNewError, and eliminate
 | |
| 89 | # the old one.
 | |
| 1185.16.62
by mbp at sourcefrog - convert NotBranchError to new exception base | 90 | |
| 1662.1.12
by Martin Pool Translate unknown sftp errors to PathError, no NoSuchFile | 91 | # TODO: The pattern (from hct) of using classes docstrings as message
 | 
| 92 | # templates is cute but maybe not such a great idea - perhaps should have a
 | |
| 93 | # separate static message_template.
 | |
| 94 | ||
| 1185.16.61
by mbp at sourcefrog - start introducing hct error classes | 95 | |
| 1
by mbp at sourcefrog import from baz patch-364 | 96 | class BzrError(StandardError): | 
| 1740.5.6
by Martin Pool Clean up many exception classes. | 97 | |
| 98 | is_user_error = True | |
| 99 | ||
| 1193
by Martin Pool - better string formatting of BzrErrors with explanation | 100 | def __str__(self): | 
| 1393.1.64
by Martin Pool - improved display of some errors, including NotBranchError | 101 |         # XXX: Should we show the exception class in 
 | 
| 102 |         # exceptions that don't provide their own message?  
 | |
| 103 |         # maybe it should be done at a higher level
 | |
| 104 |         ## n = self.__class__.__name__ + ': '
 | |
| 105 | n = '' | |
| 1195
by Martin Pool - better error display | 106 | if len(self.args) == 1: | 
| 1449
by Robert Collins teach check about ghosts | 107 | return str(self.args[0]) | 
| 1195
by Martin Pool - better error display | 108 | elif len(self.args) == 2: | 
| 1193
by Martin Pool - better string formatting of BzrErrors with explanation | 109 |             # further explanation or suggestions
 | 
| 1405
by Robert Collins remove some of the upgrade code that was duplicated with inventory_entry, and give all inventory entries a weave | 110 | try: | 
| 1393.1.64
by Martin Pool - improved display of some errors, including NotBranchError | 111 | return n + '\n '.join([self.args[0]] + self.args[1]) | 
| 1405
by Robert Collins remove some of the upgrade code that was duplicated with inventory_entry, and give all inventory entries a weave | 112 | except TypeError: | 
| 1393.1.64
by Martin Pool - improved display of some errors, including NotBranchError | 113 | return n + "%r" % self | 
| 1193
by Martin Pool - better string formatting of BzrErrors with explanation | 114 | else: | 
| 1393.1.64
by Martin Pool - improved display of some errors, including NotBranchError | 115 | return n + `self.args` | 
| 1193
by Martin Pool - better string formatting of BzrErrors with explanation | 116 | |
| 1185.1.14
by Robert Collins remove more duplicate merged hunks. Bad MERGE3, BAD. | 117 | |
| 1185.16.62
by mbp at sourcefrog - convert NotBranchError to new exception base | 118 | class BzrNewError(BzrError): | 
| 1185.16.61
by mbp at sourcefrog - start introducing hct error classes | 119 | """bzr error""" | 
| 120 |     # base classes should override the docstring with their human-
 | |
| 121 |     # readable explanation
 | |
| 122 | ||
| 123 | def __init__(self, **kwds): | |
| 124 | for key, value in kwds.items(): | |
| 125 | setattr(self, key, value) | |
| 126 | ||
| 127 | def __str__(self): | |
| 128 | try: | |
| 129 | return self.__doc__ % self.__dict__ | |
| 130 | except (NameError, ValueError, KeyError), e: | |
| 131 | return 'Unprintable exception %s: %s' \ | |
| 132 | % (self.__class__.__name__, str(e)) | |
| 133 | ||
| 134 | ||
| 1185.16.63
by Martin Pool - more error conversion | 135 | class BzrCheckError(BzrNewError): | 
| 136 | """Internal check failed: %(message)s""" | |
| 1508.1.22
by Robert Collins implement out of date working tree checks in commit. | 137 | |
| 1740.5.6
by Martin Pool Clean up many exception classes. | 138 | is_user_error = False | 
| 139 | ||
| 1185.16.63
by Martin Pool - more error conversion | 140 | def __init__(self, message): | 
| 1185.16.103
by mbp at sourcefrog Fix up all calls to InvalidRevisionId() to specify parameters. | 141 | BzrNewError.__init__(self) | 
| 1185.16.63
by Martin Pool - more error conversion | 142 | self.message = message | 
| 143 | ||
| 144 | ||
| 145 | class InvalidEntryName(BzrNewError): | |
| 146 | """Invalid entry name: %(name)s""" | |
| 1740.5.6
by Martin Pool Clean up many exception classes. | 147 | |
| 148 | is_user_error = False | |
| 149 | ||
| 1185.16.63
by Martin Pool - more error conversion | 150 | def __init__(self, name): | 
| 1185.16.103
by mbp at sourcefrog Fix up all calls to InvalidRevisionId() to specify parameters. | 151 | BzrNewError.__init__(self) | 
| 1185.16.63
by Martin Pool - more error conversion | 152 | self.name = name | 
| 153 | ||
| 154 | ||
| 155 | class InvalidRevisionNumber(BzrNewError): | |
| 156 | """Invalid revision number %(revno)d""" | |
| 157 | def __init__(self, revno): | |
| 1185.16.103
by mbp at sourcefrog Fix up all calls to InvalidRevisionId() to specify parameters. | 158 | BzrNewError.__init__(self) | 
| 1185.16.63
by Martin Pool - more error conversion | 159 | self.revno = revno | 
| 160 | ||
| 161 | ||
| 162 | class InvalidRevisionId(BzrNewError): | |
| 1185.16.103
by mbp at sourcefrog Fix up all calls to InvalidRevisionId() to specify parameters. | 163 | """Invalid revision-id {%(revision_id)s} in %(branch)s""" | 
| 164 | def __init__(self, revision_id, branch): | |
| 1668.5.1
by Olaf Conradi Fix bug in knits when raising InvalidRevisionId without the required | 165 |         # branch can be any string or object with __str__ defined
 | 
| 1185.16.103
by mbp at sourcefrog Fix up all calls to InvalidRevisionId() to specify parameters. | 166 | BzrNewError.__init__(self) | 
| 1185.12.90
by Aaron Bentley Fixed InvalidRevisionID handling in Branch.get_revision_xml | 167 | self.revision_id = revision_id | 
| 1185.16.103
by mbp at sourcefrog Fix up all calls to InvalidRevisionId() to specify parameters. | 168 | self.branch = branch | 
| 974.1.26
by aaron.bentley at utoronto merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472 | 169 | |
| 170 | ||
| 1497
by Robert Collins Move Branch.read_working_inventory to WorkingTree. | 171 | class NoWorkingTree(BzrNewError): | 
| 1662.1.6
by Martin Pool Fix formatting of NoWorkingTree and NotLocalUrl exceptions | 172 | """No WorkingTree exists for %(base)s.""" | 
| 1497
by Robert Collins Move Branch.read_working_inventory to WorkingTree. | 173 | |
| 174 | def __init__(self, base): | |
| 175 | BzrNewError.__init__(self) | |
| 176 | self.base = base | |
| 1506
by Robert Collins Merge Johns current integration work. | 177 | |
| 178 | ||
| 1534.4.42
by Robert Collins add working tree to the BzrDir facilities. | 179 | class NotLocalUrl(BzrNewError): | 
| 1662.1.6
by Martin Pool Fix formatting of NoWorkingTree and NotLocalUrl exceptions | 180 | """%(url)s is not a local path.""" | 
| 1534.4.42
by Robert Collins add working tree to the BzrDir facilities. | 181 | |
| 182 | def __init__(self, url): | |
| 183 | BzrNewError.__init__(self) | |
| 184 | self.url = url | |
| 185 | ||
| 186 | ||
| 1740.5.6
by Martin Pool Clean up many exception classes. | 187 | class BzrCommandError(BzrNewError): | 
| 188 | """Error from user command""" | |
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 189 | |
| 1740.5.6
by Martin Pool Clean up many exception classes. | 190 | is_user_error = True | 
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 191 | |
| 192 |     # Error from malformed user command; please avoid raising this as a
 | |
| 193 |     # generic exception not caused by user input.
 | |
| 1185.54.18
by Aaron Bentley Noted difference of opinion wrt BzrCommandError | 194 |     #
 | 
| 195 |     # I think it's a waste of effort to differentiate between errors that
 | |
| 196 |     # are not intended to be caught anyway.  UI code need not subclass
 | |
| 197 |     # BzrCommandError, and non-UI code should not throw a subclass of
 | |
| 198 |     # BzrCommandError.  ADHB 20051211
 | |
| 1740.5.6
by Martin Pool Clean up many exception classes. | 199 | def __init__(self, msg): | 
| 200 | self.msg = msg | |
| 201 | ||
| 1393.1.64
by Martin Pool - improved display of some errors, including NotBranchError | 202 | def __str__(self): | 
| 1740.5.6
by Martin Pool Clean up many exception classes. | 203 | return self.msg | 
| 204 | ||
| 205 | ||
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 206 | class BzrOptionError(BzrCommandError): | 
| 207 | """Error in command line options""" | |
| 208 | ||
| 209 | ||
| 1740.5.6
by Martin Pool Clean up many exception classes. | 210 | class StrictCommitFailed(BzrNewError): | 
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 211 | """Commit refused because there are unknown files in the tree""" | 
| 1
by mbp at sourcefrog import from baz patch-364 | 212 | |
| 1185.31.41
by John Arbash Meinel Creating a PathNotChild exception, and using relpath in HTTPTestUtil | 213 | |
| 1662.1.12
by Martin Pool Translate unknown sftp errors to PathError, no NoSuchFile | 214 | # XXX: Should be unified with TransportError; they seem to represent the
 | 
| 215 | # same thing
 | |
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 216 | class PathError(BzrNewError): | 
| 217 | """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. | 218 | |
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 219 | def __init__(self, path, extra=None): | 
| 220 | BzrNewError.__init__(self) | |
| 221 | self.path = path | |
| 222 | if extra: | |
| 223 | self.extra = ': ' + str(extra) | |
| 224 | else: | |
| 225 | self.extra = '' | |
| 226 | ||
| 227 | ||
| 228 | class NoSuchFile(PathError): | |
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 229 | """No such file: %(path)r%(extra)s""" | 
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 230 | |
| 231 | ||
| 232 | class FileExists(PathError): | |
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 233 | """File exists: %(path)r%(extra)s""" | 
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 234 | |
| 235 | ||
| 1553.5.10
by Martin Pool New DirectoryNotEmpty exception, and raise this from local and memory | 236 | class DirectoryNotEmpty(PathError): | 
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 237 | """Directory not empty: %(path)r%(extra)s""" | 
| 1553.5.10
by Martin Pool New DirectoryNotEmpty exception, and raise this from local and memory | 238 | |
| 239 | ||
| 1558.10.1
by Aaron Bentley Handle lockdirs over NFS properly | 240 | class ResourceBusy(PathError): | 
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 241 | """Device or resource busy: %(path)r%(extra)s""" | 
| 1558.10.1
by Aaron Bentley Handle lockdirs over NFS properly | 242 | |
| 243 | ||
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 244 | class PermissionDenied(PathError): | 
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 245 | """Permission denied: %(path)r%(extra)s""" | 
| 246 | ||
| 247 | ||
| 1185.85.76
by John Arbash Meinel Adding an InvalidURL so transports can report they expect utf-8 quoted paths. Updated tests | 248 | class InvalidURL(PathError): | 
| 249 | """Invalid url supplied to transport: %(path)r%(extra)s""" | |
| 250 | ||
| 251 | ||
| 1685.1.55
by John Arbash Meinel Adding bzrlib.urlutils.join() to handle joining URLs | 252 | class InvalidURLJoin(PathError): | 
| 253 | """Invalid URL join request: %(args)s%(extra)s""" | |
| 254 | ||
| 255 | def __init__(self, msg, base, args): | |
| 256 | PathError.__init__(self, base, msg) | |
| 257 | self.args = [base] | |
| 258 | self.args.extend(args) | |
| 259 | ||
| 260 | ||
| 1843.1.1
by John Arbash Meinel Update get_transport to raise a nicer error which includes dependency info | 261 | class UnsupportedProtocol(PathError): | 
| 262 | """Unsupported protocol for url "%(path)s"%(extra)s""" | |
| 263 | ||
| 264 | def __init__(self, url, extra): | |
| 265 | PathError.__init__(self, url, extra=extra) | |
| 266 | ||
| 267 | ||
| 1185.31.41
by John Arbash Meinel Creating a PathNotChild exception, and using relpath in HTTPTestUtil | 268 | class PathNotChild(BzrNewError): | 
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 269 | """Path %(path)r is not a child of path %(base)r%(extra)s""" | 
| 1740.5.6
by Martin Pool Clean up many exception classes. | 270 | |
| 271 | is_user_error = False | |
| 272 | ||
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 273 | def __init__(self, path, base, extra=None): | 
| 1185.31.41
by John Arbash Meinel Creating a PathNotChild exception, and using relpath in HTTPTestUtil | 274 | BzrNewError.__init__(self) | 
| 275 | self.path = path | |
| 276 | self.base = base | |
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 277 | if extra: | 
| 278 | self.extra = ': ' + str(extra) | |
| 279 | else: | |
| 280 | self.extra = '' | |
| 1185.31.41
by John Arbash Meinel Creating a PathNotChild exception, and using relpath in HTTPTestUtil | 281 | |
| 282 | ||
| 1830.3.5
by John Arbash Meinel make_entry refuses to create non-normalized entries. | 283 | class InvalidNormalization(PathError): | 
| 284 | """Path %(path)r is not unicode normalized""" | |
| 285 | ||
| 286 | ||
| 1685.1.60
by Martin Pool [broken] NotBranchError should unescape the url if possible | 287 | # TODO: This is given a URL; we try to unescape it but doing that from inside
 | 
| 288 | # the exception object is a bit undesirable.
 | |
| 289 | # 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. | 290 | class NotBranchError(PathError): | 
| 1685.1.80
by Wouter van Heyst more code cleanup | 291 | """Not a branch: %(path)s""" | 
| 1685.1.60
by Martin Pool [broken] NotBranchError should unescape the url if possible | 292 | |
| 293 | def __init__(self, path): | |
| 294 | import bzrlib.urlutils as urlutils | |
| 295 | 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. | 296 | |
| 297 | ||
| 298 | class AlreadyBranchError(PathError): | |
| 1662.1.19
by Martin Pool Better error message when initting existing tree | 299 | """Already a branch: %(path)s.""" | 
| 300 | ||
| 301 | ||
| 302 | class BranchExistsWithoutWorkingTree(PathError): | |
| 303 | """Directory contains a branch, but no working tree \ | |
| 304 | (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 | 305 | |
| 573
by Martin Pool - new exception NotBranchError | 306 | |
| 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. | 307 | class AtomicFileAlreadyClosed(PathError): | 
| 308 | """'%(function)s' called on an AtomicFile after it was closed: %(path)s""" | |
| 309 | ||
| 310 | def __init__(self, path, function): | |
| 311 | PathError.__init__(self, path=path, extra=None) | |
| 312 | self.function = function | |
| 313 | ||
| 314 | ||
| 1864.7.2
by John Arbash Meinel Test that we copy the parent across properly (if it is available) | 315 | class InaccessibleParent(PathError): | 
| 316 | """Parent not accessible given base %(base)s and relative path %(path)s""" | |
| 317 | ||
| 318 | def __init__(self, path, base): | |
| 319 | PathError.__init__(self, path) | |
| 320 | self.base = base | |
| 321 | ||
| 322 | ||
| 1534.4.47
by Robert Collins Split out repository into .bzr/repository | 323 | class NoRepositoryPresent(BzrNewError): | 
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 324 | """No repository present: %(path)r""" | 
| 1534.4.47
by Robert Collins Split out repository into .bzr/repository | 325 | def __init__(self, bzrdir): | 
| 326 | BzrNewError.__init__(self) | |
| 327 | self.path = bzrdir.transport.clone('..').base | |
| 328 | ||
| 329 | ||
| 1185.35.32
by Aaron Bentley Fixed handling of files in mixed branches | 330 | class FileInWrongBranch(BzrNewError): | 
| 331 | """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. | 332 | |
| 1185.35.32
by Aaron Bentley Fixed handling of files in mixed branches | 333 | def __init__(self, branch, path): | 
| 334 | BzrNewError.__init__(self) | |
| 335 | self.branch = branch | |
| 336 | self.branch_base = branch.base | |
| 337 | self.path = path | |
| 338 | ||
| 339 | ||
| 1740.5.6
by Martin Pool Clean up many exception classes. | 340 | class UnsupportedFormatError(BzrNewError): | 
| 341 | """Unsupported branch format: %(format)s""" | |
| 342 | ||
| 343 | ||
| 344 | class UnknownFormatError(BzrNewError): | |
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 345 | """Unknown branch format: %(format)r""" | 
| 1534.4.7
by Robert Collins Move downlevel check up to the Branch.open logic, removing it from the Branch constructor and deprecating relax_version_check to the same. | 346 | |
| 347 | ||
| 1534.4.44
by Robert Collins Make a new BzrDir format that uses a versioned branch format in a branch/ subdirectory. | 348 | class IncompatibleFormat(BzrNewError): | 
| 349 | """Format %(format)s is not compatible with .bzr version %(bzrdir)s.""" | |
| 350 | ||
| 351 | def __init__(self, format, bzrdir_format): | |
| 352 | BzrNewError.__init__(self) | |
| 353 | self.format = format | |
| 354 | self.bzrdir = bzrdir_format | |
| 355 | ||
| 356 | ||
| 1185.16.72
by Martin Pool [merge] from robert and fix up tests | 357 | class NotVersionedError(BzrNewError): | 
| 358 | """%(path)s is not versioned""" | |
| 359 | def __init__(self, path): | |
| 360 | BzrNewError.__init__(self) | |
| 361 | self.path = path | |
| 753
by Martin Pool - new exception NotVersionedError | 362 | |
| 363 | ||
| 1658.1.9
by Martin Pool Give an error for bzr diff on an nonexistent file (Malone #3619) | 364 | class PathsNotVersionedError(BzrNewError): | 
| 365 |     # used when reporting several paths are not versioned
 | |
| 366 | """Path(s) are not versioned: %(paths_as_string)s""" | |
| 367 | ||
| 368 | def __init__(self, paths): | |
| 369 | from bzrlib.osutils import quotefn | |
| 370 | BzrNewError.__init__(self) | |
| 371 | self.paths = paths | |
| 372 | self.paths_as_string = ' '.join([quotefn(p) for p in paths]) | |
| 373 | ||
| 374 | ||
| 1662.1.9
by Martin Pool Give a clear error for bzr status of an unversioned, nonexistent file. (Malone #3619) | 375 | class PathsDoNotExist(BzrNewError): | 
| 1662.1.14
by Martin Pool (PathsDoNotExist) review style comments | 376 | """Path(s) do not exist: %(paths_as_string)s""" | 
| 377 | ||
| 1662.1.9
by Martin Pool Give a clear error for bzr status of an unversioned, nonexistent file. (Malone #3619) | 378 |     # used when reporting that paths are neither versioned nor in the working
 | 
| 379 |     # tree
 | |
| 380 | ||
| 381 | def __init__(self, paths): | |
| 1662.1.14
by Martin Pool (PathsDoNotExist) review style comments | 382 |         # circular import
 | 
| 1662.1.9
by Martin Pool Give a clear error for bzr status of an unversioned, nonexistent file. (Malone #3619) | 383 | from bzrlib.osutils import quotefn | 
| 384 | BzrNewError.__init__(self) | |
| 385 | self.paths = paths | |
| 386 | self.paths_as_string = ' '.join([quotefn(p) for p in paths]) | |
| 387 | ||
| 388 | ||
| 1773.4.1
by Martin Pool Add pyflakes makefile target; fix many warnings | 389 | class BadFileKindError(BzrNewError): | 
| 390 | """Cannot operate on %(filename)s of unsupported kind %(kind)s""" | |
| 391 | ||
| 392 | ||
| 1773.4.2
by Martin Pool Cleanup of imports; undeprecate all_revision_ids() | 393 | class ForbiddenControlFileError(BzrNewError): | 
| 1773.4.1
by Martin Pool Add pyflakes makefile target; fix many warnings | 394 | """Cannot operate on %(filename)s because it is a control file""" | 
| 599
by Martin Pool - better error reporting from smart_add | 395 | |
| 396 | ||
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 397 | class LockError(BzrNewError): | 
| 398 | """Lock error: %(message)s""" | |
| 1185.16.63
by Martin Pool - more error conversion | 399 |     # All exceptions from the lock/unlock functions should be from
 | 
| 400 |     # this exception class.  They will be translated as necessary. The
 | |
| 401 |     # original exception is available as e.original_error
 | |
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 402 |     #
 | 
| 403 |     # New code should prefer to raise specific subclasses
 | |
| 404 | def __init__(self, message): | |
| 405 | self.message = message | |
| 882
by Martin Pool - Optionally raise EmptyCommit if there are no changes. Test for this. | 406 | |
| 407 | ||
| 1417.1.6
by Robert Collins introduce transactions for grouping actions done to and with branches | 408 | class CommitNotPossible(LockError): | 
| 409 | """A commit was attempted but we do not have a write lock open.""" | |
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 410 | def __init__(self): | 
| 411 |         pass
 | |
| 1417.1.6
by Robert Collins introduce transactions for grouping actions done to and with branches | 412 | |
| 413 | ||
| 414 | class AlreadyCommitted(LockError): | |
| 415 | """A rollback was requested, but is not able to be accomplished.""" | |
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 416 | def __init__(self): | 
| 417 |         pass
 | |
| 1417.1.6
by Robert Collins introduce transactions for grouping actions done to and with branches | 418 | |
| 419 | ||
| 1417.1.8
by Robert Collins use transactions in the weave store interface, which enables caching for log | 420 | class ReadOnlyError(LockError): | 
| 1553.5.33
by Martin Pool LockDir review comment fixes | 421 | """A write attempt was made in a read only transaction on %(obj)s""" | 
| 422 | def __init__(self, obj): | |
| 423 | self.obj = obj | |
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 424 | |
| 425 | ||
| 1594.2.21
by Robert Collins Teach versioned files to prevent mutation after finishing. | 426 | class OutSideTransaction(BzrNewError): | 
| 427 | """A transaction related operation was attempted after the transaction finished.""" | |
| 428 | ||
| 429 | ||
| 1553.5.36
by Martin Pool Clean up duplicate BranchNotLocked error and rename to ObjectNotLocked | 430 | class ObjectNotLocked(LockError): | 
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 431 | """%(obj)r is not locked""" | 
| 432 | ||
| 1740.5.6
by Martin Pool Clean up many exception classes. | 433 | is_user_error = False | 
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 434 | |
| 1553.5.36
by Martin Pool Clean up duplicate BranchNotLocked error and rename to ObjectNotLocked | 435 |     # this can indicate that any particular object is not locked; see also
 | 
| 436 |     # LockNotHeld which means that a particular *lock* object is not held by
 | |
| 437 |     # the caller -- perhaps they should be unified.
 | |
| 438 | def __init__(self, obj): | |
| 439 | self.obj = obj | |
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 440 | |
| 441 | ||
| 442 | class ReadOnlyObjectDirtiedError(ReadOnlyError): | |
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 443 | """Cannot change object %(obj)r in read only transaction""" | 
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 444 | def __init__(self, obj): | 
| 445 | self.obj = obj | |
| 446 | ||
| 447 | ||
| 448 | class UnlockableTransport(LockError): | |
| 449 | """Cannot lock: transport is read only: %(transport)s""" | |
| 450 | def __init__(self, transport): | |
| 451 | self.transport = transport | |
| 452 | ||
| 453 | ||
| 454 | class LockContention(LockError): | |
| 455 | """Could not acquire lock %(lock)s""" | |
| 456 |     # TODO: show full url for lock, combining the transport and relative bits?
 | |
| 457 | def __init__(self, lock): | |
| 458 | self.lock = lock | |
| 459 | ||
| 460 | ||
| 1553.5.23
by Martin Pool Start LockDir.confirm method and LockBroken exception | 461 | class LockBroken(LockError): | 
| 1553.5.24
by Martin Pool Warning to check storage when lock was broken | 462 | """Lock was broken while still open: %(lock)s - check storage consistency!""" | 
| 1553.5.23
by Martin Pool Start LockDir.confirm method and LockBroken exception | 463 | def __init__(self, lock): | 
| 464 | self.lock = lock | |
| 465 | ||
| 466 | ||
| 1553.5.27
by Martin Pool Confirm that only the intended holder of a lock was broken. | 467 | class LockBreakMismatch(LockError): | 
| 1740.5.8
by Martin Pool Review cleanups: better error reporting, put back report_exception. | 468 | """Lock was released and re-acquired before being broken: %(lock)s: held by %(holder)r, wanted to break %(target)r""" | 
| 1553.5.27
by Martin Pool Confirm that only the intended holder of a lock was broken. | 469 | def __init__(self, lock, holder, target): | 
| 470 | self.lock = lock | |
| 471 | self.holder = holder | |
| 472 | self.target = target | |
| 473 | ||
| 474 | ||
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 475 | class LockNotHeld(LockError): | 
| 476 | """Lock not held: %(lock)s""" | |
| 477 | def __init__(self, lock): | |
| 478 | self.lock = lock | |
| 479 | ||
| 480 | ||
| 1185.16.63
by Martin Pool - more error conversion | 481 | class PointlessCommit(BzrNewError): | 
| 1185.16.64
by Martin Pool - more error conversions | 482 | """No changes to commit""" | 
| 974.1.26
by aaron.bentley at utoronto merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472 | 483 | |
| 1551.3.1
by Aaron Bentley PEP8 fixes | 484 | |
| 1534.4.13
by Robert Collins Give a reasonable warning on attempts to upgrade a readonly url. | 485 | class UpgradeReadonly(BzrNewError): | 
| 486 | """Upgrade URL cannot work with readonly URL's.""" | |
| 487 | ||
| 488 | ||
| 1534.5.7
by Robert Collins Start factoring out the upgrade policy logic. | 489 | class UpToDateFormat(BzrNewError): | 
| 490 | """The branch format %(format)s is already at the most recent format.""" | |
| 491 | ||
| 492 | def __init__(self, format): | |
| 493 | BzrNewError.__init__(self) | |
| 494 | self.format = format | |
| 495 | ||
| 496 | ||
| 1587.1.6
by Robert Collins Update bound branch implementation to 0.8. | 497 | |
| 1185.22.1
by Michael Ellerman Implement strict commits with --strict flag. | 498 | class StrictCommitFailed(Exception): | 
| 499 | """Commit refused because there are unknowns in the tree.""" | |
| 974.1.26
by aaron.bentley at utoronto merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472 | 500 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 501 | |
| 1740.5.6
by Martin Pool Clean up many exception classes. | 502 | class NoSuchRevision(BzrNewError): | 
| 503 | """Branch %(branch)s has no revision %(revision)s""" | |
| 504 | ||
| 505 | is_user_error = False | |
| 506 | ||
| 974.1.26
by aaron.bentley at utoronto merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472 | 507 | def __init__(self, branch, revision): | 
| 508 | self.branch = branch | |
| 509 | self.revision = revision | |
| 1740.5.6
by Martin Pool Clean up many exception classes. | 510 | |
| 511 | ||
| 1192
by Martin Pool - clean up code for retrieving stored inventories | 512 | class HistoryMissing(BzrError): | 
| 513 | def __init__(self, branch, object_type, object_id): | |
| 514 | self.branch = branch | |
| 515 | BzrError.__init__(self, | |
| 516 | '%s is missing %s {%s}' | |
| 517 | % (branch, object_type, object_id)) | |
| 518 | ||
| 519 | ||
| 1740.5.6
by Martin Pool Clean up many exception classes. | 520 | class DivergedBranches(BzrNewError): | 
| 521 |     "These branches have diverged.  Use the merge command to reconcile them."""
 | |
| 522 | ||
| 523 | is_user_error = True | |
| 1649.1.1
by Robert Collins * 'pull' and 'push' now normalise the revision history, so that any two | 524 | |
| 1185.2.1
by Lalo Martins moving DivergedBranches from bzrlib.branch to bzrlib.errors, obeying: | 525 | def __init__(self, branch1, branch2): | 
| 526 | self.branch1 = branch1 | |
| 527 | self.branch2 = branch2 | |
| 528 | ||
| 1390
by Robert Collins pair programming worx... merge integration and weave | 529 | |
| 1740.5.6
by Martin Pool Clean up many exception classes. | 530 | class UnrelatedBranches(BzrNewError): | 
| 531 |     "Branches have no common ancestor, and no merge base revision was specified."
 | |
| 532 | ||
| 533 | is_user_error = True | |
| 534 | ||
| 535 | ||
| 536 | class NoCommonAncestor(BzrNewError): | |
| 537 | "Revisions have no common ancestor: %(revision_a)s %(revision_b)s" | |
| 538 | ||
| 974.1.80
by Aaron Bentley Improved merge error handling and testing | 539 | def __init__(self, revision_a, revision_b): | 
| 1740.5.6
by Martin Pool Clean up many exception classes. | 540 | self.revision_a = revision_a | 
| 541 | self.revision_b = revision_b | |
| 974.1.80
by Aaron Bentley Improved merge error handling and testing | 542 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 543 | |
| 974.1.80
by Aaron Bentley Improved merge error handling and testing | 544 | class NoCommonRoot(BzrError): | 
| 545 | def __init__(self, revision_a, revision_b): | |
| 546 | msg = "Revisions are not derived from the same root: %s %s." \ | |
| 547 | % (revision_a, revision_b) | |
| 548 | BzrError.__init__(self, msg) | |
| 1105
by Martin Pool - expose 'find-merge-base' as a new expert command, | 549 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 550 | |
| 1587.1.6
by Robert Collins Update bound branch implementation to 0.8. | 551 | |
| 974.2.7
by aaron.bentley at utoronto Merged from bzr.24 | 552 | class NotAncestor(BzrError): | 
| 553 | def __init__(self, rev_id, not_ancestor_id): | |
| 1185.1.14
by Robert Collins remove more duplicate merged hunks. Bad MERGE3, BAD. | 554 | msg = "Revision %s is not an ancestor of %s" % (not_ancestor_id, | 
| 555 | rev_id) | |
| 556 | BzrError.__init__(self, msg) | |
| 557 | self.rev_id = rev_id | |
| 558 | self.not_ancestor_id = not_ancestor_id | |
| 1185.1.12
by Robert Collins merge in lsdiff/filterdiff friendliness | 559 | |
| 560 | ||
| 974.1.30
by aaron.bentley at utoronto Changed copy_multi to permit failure and return a tuple, tested missing required revisions | 561 | class InstallFailed(BzrError): | 
| 562 | def __init__(self, revisions): | |
| 1185.1.14
by Robert Collins remove more duplicate merged hunks. Bad MERGE3, BAD. | 563 | msg = "Could not install revisions:\n%s" % " ,".join(revisions) | 
| 564 | 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 | 565 | self.revisions = revisions | 
| 1154
by Martin Pool - fix imports for moved errors | 566 | |
| 567 | ||
| 1614.2.13
by Olaf Conradi Re-added AmbiguousBase with a deprecated warning. | 568 | class AmbiguousBase(BzrError): | 
| 569 | def __init__(self, bases): | |
| 570 | warn("BzrError AmbiguousBase has been deprecated as of bzrlib 0.8.", | |
| 571 | DeprecationWarning) | |
| 1759.2.1
by Jelmer Vernooij Fix some types (found using aspell). | 572 | 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. | 573 | ", ".join(bases) | 
| 574 | BzrError.__init__(self, msg) | |
| 575 | self.bases = bases | |
| 576 | ||
| 577 | ||
| 974.1.80
by Aaron Bentley Improved merge error handling and testing | 578 | class NoCommits(BzrError): | 
| 579 | def __init__(self, branch): | |
| 580 | msg = "Branch %s has no commits." % branch | |
| 581 | BzrError.__init__(self, msg) | |
| 1185.10.1
by Aaron Bentley Added --basis option to bzr branch | 582 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 583 | |
| 1185.10.1
by Aaron Bentley Added --basis option to bzr branch | 584 | class UnlistableStore(BzrError): | 
| 585 | def __init__(self, store): | |
| 586 | BzrError.__init__(self, "Store %s is not listable" % store) | |
| 587 | ||
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 588 | |
| 1587.1.6
by Robert Collins Update bound branch implementation to 0.8. | 589 | |
| 1185.10.1
by Aaron Bentley Added --basis option to bzr branch | 590 | class UnlistableBranch(BzrError): | 
| 591 | def __init__(self, br): | |
| 592 | BzrError.__init__(self, "Stores for branch %s are not listable" % br) | |
| 1392
by Robert Collins reinstate testfetch test case | 593 | |
| 594 | ||
| 1505.1.24
by John Arbash Meinel Updated commit to handle bound branches. Included test to handle commit after merge | 595 | class BoundBranchOutOfDate(BzrNewError): | 
| 596 | """Bound branch %(branch)s is out of date with master branch %(master)s.""" | |
| 597 | def __init__(self, branch, master): | |
| 598 | BzrNewError.__init__(self) | |
| 599 | self.branch = branch | |
| 600 | self.master = master | |
| 601 | ||
| 602 | ||
| 603 | class CommitToDoubleBoundBranch(BzrNewError): | |
| 604 | """Cannot commit to branch %(branch)s. It is bound to %(master)s, which is bound to %(remote)s.""" | |
| 605 | def __init__(self, branch, master, remote): | |
| 606 | BzrNewError.__init__(self) | |
| 607 | self.branch = branch | |
| 608 | self.master = master | |
| 609 | self.remote = remote | |
| 610 | ||
| 1505.1.25
by John Arbash Meinel Updated pull. Now all paths which call set_revision_history maintain the branch invariant. All tests pass. | 611 | |
| 612 | class OverwriteBoundBranch(BzrNewError): | |
| 613 | """Cannot pull --overwrite to a branch which is bound %(branch)s""" | |
| 614 | def __init__(self, branch): | |
| 615 | BzrNewError.__init__(self) | |
| 616 | self.branch = branch | |
| 617 | ||
| 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 | 618 | |
| 619 | class BoundBranchConnectionFailure(BzrNewError): | |
| 620 | """Unable to connect to target of bound branch %(branch)s => %(target)s: %(error)s""" | |
| 621 | def __init__(self, branch, target, error): | |
| 622 | BzrNewError.__init__(self) | |
| 623 | self.branch = branch | |
| 624 | self.target = target | |
| 625 | self.error = error | |
| 626 | ||
| 627 | ||
| 1185.16.116
by mbp at sourcefrog Move weave errors into bzrlib.errors and make consistent with new system. | 628 | class WeaveError(BzrNewError): | 
| 629 | """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. | 630 | |
| 1185.16.116
by mbp at sourcefrog Move weave errors into bzrlib.errors and make consistent with new system. | 631 | def __init__(self, message=None): | 
| 632 | BzrNewError.__init__(self) | |
| 633 | self.message = message | |
| 634 | ||
| 635 | ||
| 636 | class WeaveRevisionAlreadyPresent(WeaveError): | |
| 637 | """Revision {%(revision_id)s} already present in %(weave)s""" | |
| 638 | 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. | 639 | |
| 1185.16.116
by mbp at sourcefrog Move weave errors into bzrlib.errors and make consistent with new system. | 640 | WeaveError.__init__(self) | 
| 641 | self.revision_id = revision_id | |
| 642 | self.weave = weave | |
| 643 | ||
| 644 | ||
| 645 | class WeaveRevisionNotPresent(WeaveError): | |
| 646 | """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. | 647 | |
| 1185.16.116
by mbp at sourcefrog Move weave errors into bzrlib.errors and make consistent with new system. | 648 | def __init__(self, revision_id, weave): | 
| 649 | WeaveError.__init__(self) | |
| 650 | self.revision_id = revision_id | |
| 651 | self.weave = weave | |
| 652 | ||
| 653 | ||
| 654 | class WeaveFormatError(WeaveError): | |
| 655 | """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. | 656 | |
| 1185.16.116
by mbp at sourcefrog Move weave errors into bzrlib.errors and make consistent with new system. | 657 | def __init__(self, what): | 
| 658 | WeaveError.__init__(self) | |
| 659 | self.what = what | |
| 660 | ||
| 661 | ||
| 662 | class WeaveParentMismatch(WeaveError): | |
| 663 | """Parents are mismatched between two revisions.""" | |
| 664 | ||
| 1393.2.1
by John Arbash Meinel Merged in split-storage-2 branch. Need to cleanup a little bit more still. | 665 | |
| 1185.50.23
by John Arbash Meinel Adding sha1 check when weave extracts a text. | 666 | class WeaveInvalidChecksum(WeaveError): | 
| 667 | """Text did not match it's checksum: %(message)s""" | |
| 668 | ||
| 669 | ||
| 1551.3.11
by Aaron Bentley Merge from Robert | 670 | class WeaveTextDiffers(WeaveError): | 
| 671 | """Weaves differ on text content. Revision: {%(revision_id)s}, %(weave_a)s, %(weave_b)s""" | |
| 672 | ||
| 673 | def __init__(self, revision_id, weave_a, weave_b): | |
| 674 | WeaveError.__init__(self) | |
| 675 | self.revision_id = revision_id | |
| 676 | self.weave_a = weave_a | |
| 677 | self.weave_b = weave_b | |
| 678 | ||
| 679 | ||
| 1534.7.158
by Aaron Bentley Merged John Meinel's integration | 680 | class WeaveTextDiffers(WeaveError): | 
| 681 | """Weaves differ on text content. Revision: {%(revision_id)s}, %(weave_a)s, %(weave_b)s""" | |
| 682 | ||
| 683 | def __init__(self, revision_id, weave_a, weave_b): | |
| 684 | WeaveError.__init__(self) | |
| 685 | self.revision_id = revision_id | |
| 686 | self.weave_a = weave_a | |
| 687 | self.weave_b = weave_b | |
| 688 | ||
| 689 | ||
| 1563.2.1
by Robert Collins Merge in a variation of the versionedfile api from versioned-file. | 690 | class VersionedFileError(BzrNewError): | 
| 691 | """Versioned file error.""" | |
| 692 | ||
| 693 | ||
| 694 | class RevisionNotPresent(VersionedFileError): | |
| 695 | """Revision {%(revision_id)s} not present in %(file_id)s.""" | |
| 696 | ||
| 697 | def __init__(self, revision_id, file_id): | |
| 698 | VersionedFileError.__init__(self) | |
| 699 | self.revision_id = revision_id | |
| 700 | self.file_id = file_id | |
| 701 | ||
| 702 | ||
| 703 | class RevisionAlreadyPresent(VersionedFileError): | |
| 704 | """Revision {%(revision_id)s} already present in %(file_id)s.""" | |
| 705 | ||
| 706 | def __init__(self, revision_id, file_id): | |
| 707 | VersionedFileError.__init__(self) | |
| 708 | self.revision_id = revision_id | |
| 709 | self.file_id = file_id | |
| 710 | ||
| 711 | ||
| 712 | class KnitError(BzrNewError): | |
| 713 | """Knit error""" | |
| 714 | ||
| 715 | ||
| 716 | class KnitHeaderError(KnitError): | |
| 717 | """Knit header error: %(badline)r unexpected""" | |
| 718 | ||
| 719 | def __init__(self, badline): | |
| 720 | KnitError.__init__(self) | |
| 721 | self.badline = badline | |
| 722 | ||
| 723 | ||
| 724 | class KnitCorrupt(KnitError): | |
| 725 | """Knit %(filename)s corrupt: %(how)s""" | |
| 726 | ||
| 727 | def __init__(self, filename, how): | |
| 728 | KnitError.__init__(self) | |
| 729 | self.filename = filename | |
| 730 | self.how = how | |
| 731 | ||
| 732 | ||
| 1185.31.12
by John Arbash Meinel Refactored the export code to make it easier to add new export formats. | 733 | class NoSuchExportFormat(BzrNewError): | 
| 734 | """Export format %(format)r not supported""" | |
| 735 | def __init__(self, format): | |
| 736 | BzrNewError.__init__(self) | |
| 737 | self.format = format | |
| 738 | ||
| 739 | ||
| 1824.2.1
by Johan Rydberg Let TransportError inherit BzrNerError. | 740 | class TransportError(BzrNewError): | 
| 741 | """Transport error: %(msg)s %(orig_error)s""" | |
| 742 | ||
| 1185.11.9
by John Arbash Meinel Most tests pass, some problems with unavailable socket recv | 743 | def __init__(self, msg=None, orig_error=None): | 
| 744 | if msg is None and orig_error is not None: | |
| 745 | msg = str(orig_error) | |
| 1824.2.1
by Johan Rydberg Let TransportError inherit BzrNerError. | 746 | if orig_error is None: | 
| 747 | orig_error = '' | |
| 748 | if msg is None: | |
| 749 | msg = '' | |
| 1185.11.9
by John Arbash Meinel Most tests pass, some problems with unavailable socket recv | 750 | self.msg = msg | 
| 751 | self.orig_error = orig_error | |
| 1824.2.1
by Johan Rydberg Let TransportError inherit BzrNerError. | 752 | BzrNewError.__init__(self) | 
| 1185.11.9
by John Arbash Meinel Most tests pass, some problems with unavailable socket recv | 753 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 754 | |
| 1185.11.9
by John Arbash Meinel Most tests pass, some problems with unavailable socket recv | 755 | # A set of semi-meaningful errors which can be thrown
 | 
| 756 | class TransportNotPossible(TransportError): | |
| 1824.2.1
by Johan Rydberg Let TransportError inherit BzrNerError. | 757 | """Transport operation not possible: %(msg)s %(orig_error)%""" | 
| 1185.11.9
by John Arbash Meinel Most tests pass, some problems with unavailable socket recv | 758 | |
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 759 | |
| 760 | class ConnectionError(TransportError): | |
| 1824.2.1
by Johan Rydberg Let TransportError inherit BzrNerError. | 761 | """Connection error: %(msg)s %(orig_error)s""" | 
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 762 | |
| 1185.11.9
by John Arbash Meinel Most tests pass, some problems with unavailable socket recv | 763 | |
| 764 | class ConnectionReset(TransportError): | |
| 1824.2.1
by Johan Rydberg Let TransportError inherit BzrNerError. | 765 | """Connection closed: %(msg)s %(orig_error)s""" | 
| 1185.11.9
by John Arbash Meinel Most tests pass, some problems with unavailable socket recv | 766 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 767 | |
| 1786.1.8
by John Arbash Meinel [merge] Johan Rydberg test updates | 768 | class InvalidRange(TransportError): | 
| 769 | """Invalid range access.""" | |
| 770 | ||
| 771 | def __init__(self, path, offset): | |
| 772 | TransportError.__init__(self, ("Invalid range access in %s at %d" | |
| 773 | % (path, offset))) | |
| 774 | ||
| 775 | ||
| 1786.1.17
by John Arbash Meinel Adding tests for _parse_boundary. | 776 | class InvalidHttpResponse(TransportError): | 
| 777 | """Invalid http response for %(path)s: %(msg)s""" | |
| 778 | ||
| 1786.1.31
by John Arbash Meinel Update http errors to properly use BzrNewError | 779 | def __init__(self, path, msg, orig_error=None): | 
| 1786.1.17
by John Arbash Meinel Adding tests for _parse_boundary. | 780 | self.path = path | 
| 1786.1.31
by John Arbash Meinel Update http errors to properly use BzrNewError | 781 | TransportError.__init__(self, msg, orig_error=orig_error) | 
| 1786.1.17
by John Arbash Meinel Adding tests for _parse_boundary. | 782 | |
| 783 | ||
| 784 | class InvalidHttpRange(InvalidHttpResponse): | |
| 1786.1.13
by John Arbash Meinel Found a few bugs in error handling code, updated tests | 785 | """Invalid http range "%(range)s" for %(path)s: %(msg)s""" | 
| 786 | ||
| 787 | def __init__(self, path, range, msg): | |
| 788 | self.range = range | |
| 1786.1.17
by John Arbash Meinel Adding tests for _parse_boundary. | 789 | InvalidHttpResponse.__init__(self, path, msg) | 
| 790 | ||
| 791 | ||
| 792 | class InvalidHttpContentType(InvalidHttpResponse): | |
| 793 | """Invalid http Content-type "%(ctype)s" for %(path)s: %(msg)s""" | |
| 794 | ||
| 795 | def __init__(self, path, ctype, msg): | |
| 796 | self.ctype = ctype | |
| 797 | InvalidHttpResponse.__init__(self, path, msg) | |
| 1786.1.13
by John Arbash Meinel Found a few bugs in error handling code, updated tests | 798 | |
| 799 | ||
| 1185.14.10
by Aaron Bentley Commit aborts with conflicts in the tree. | 800 | class ConflictsInTree(BzrError): | 
| 801 | def __init__(self): | |
| 802 | BzrError.__init__(self, "Working tree has conflicts.") | |
| 1185.12.49
by Aaron Bentley Switched to ConfigObj | 803 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 804 | |
| 1185.12.49
by Aaron Bentley Switched to ConfigObj | 805 | class ParseConfigError(BzrError): | 
| 806 | def __init__(self, errors, filename): | |
| 807 | if filename is None: | |
| 808 | filename = "" | |
| 809 | message = "Error(s) parsing config file %s:\n%s" % \ | |
| 810 | (filename, ('\n'.join(e.message for e in errors))) | |
| 811 | BzrError.__init__(self, message) | |
| 1185.12.52
by Aaron Bentley Merged more config stuff from Robert | 812 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 813 | |
| 1442.1.58
by Robert Collins gpg signing of content | 814 | class SigningFailed(BzrError): | 
| 815 | def __init__(self, command_line): | |
| 816 | BzrError.__init__(self, "Failed to gpg sign data with command '%s'" | |
| 817 | % command_line) | |
| 1185.12.83
by Aaron Bentley Preliminary weave merge support | 818 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 819 | |
| 1185.12.83
by Aaron Bentley Preliminary weave merge support | 820 | class WorkingTreeNotRevision(BzrError): | 
| 821 | def __init__(self, tree): | |
| 822 | BzrError.__init__(self, "The working tree for %s has changed since" | |
| 823 |                           " last commit, but weave merge requires that it be"
 | |
| 824 | " unchanged." % tree.basedir) | |
| 1185.12.104
by Aaron Bentley Merged Martin's latest | 825 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 826 | |
| 1185.24.1
by Aaron Bentley Got reprocessing working | 827 | class CantReprocessAndShowBase(BzrNewError): | 
| 828 | """Can't reprocess and show base. | |
| 829 | Reprocessing obscures relationship of conflicting lines to base."""
 | |
| 1185.24.2
by Aaron Bentley Merge from mainline | 830 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 831 | |
| 1185.16.114
by mbp at sourcefrog Improved topological sort | 832 | class GraphCycleError(BzrNewError): | 
| 833 | """Cycle in graph %(graph)r""" | |
| 834 | def __init__(self, graph): | |
| 835 | BzrNewError.__init__(self) | |
| 836 | self.graph = graph | |
| 1185.35.1
by Aaron Bentley Implemented conflicts.restore | 837 | |
| 1505.1.23
by John Arbash Meinel Whitespace cleanup of bzrlib.errors | 838 | |
| 1185.35.1
by Aaron Bentley Implemented conflicts.restore | 839 | class NotConflicted(BzrNewError): | 
| 1185.35.4
by Aaron Bentley Implemented remerge | 840 | """File %(filename)s is not conflicted.""" | 
| 1534.3.1
by Robert Collins * bzrlib.osutils.safe_unicode now exists to provide parameter coercion | 841 | |
| 1185.35.1
by Aaron Bentley Implemented conflicts.restore | 842 | def __init__(self, filename): | 
| 843 | BzrNewError.__init__(self) | |
| 844 | self.filename = filename | |
| 1185.35.13
by Aaron Bentley Merged Martin | 845 | |
| 1505.1.23
by John Arbash Meinel Whitespace cleanup of bzrlib.errors | 846 | |
| 1492
by Robert Collins Support decoration of commands. | 847 | class MustUseDecorated(Exception): | 
| 848 | """A decorating function has requested its original command be used. | |
| 849 |     
 | |
| 850 |     This should never escape bzr, so does not need to be printable.
 | |
| 851 |     """
 | |
| 852 | ||
| 1185.82.3
by John Arbash Meinel Working on creating a factor for serializing changesets. | 853 | |
| 1185.82.130
by Aaron Bentley Rename changesets to revision bundles | 854 | class NoBundleFound(BzrNewError): | 
| 855 | """No bundle was found in %(filename)s""" | |
| 1185.82.3
by John Arbash Meinel Working on creating a factor for serializing changesets. | 856 | def __init__(self, filename): | 
| 857 | BzrNewError.__init__(self) | |
| 858 | self.filename = filename | |
| 859 | ||
| 860 | ||
| 1185.82.130
by Aaron Bentley Rename changesets to revision bundles | 861 | class BundleNotSupported(BzrNewError): | 
| 862 | """Unable to handle bundle version %(version)s: %(msg)s""" | |
| 1185.82.3
by John Arbash Meinel Working on creating a factor for serializing changesets. | 863 | def __init__(self, version, msg): | 
| 864 | BzrNewError.__init__(self) | |
| 865 | self.version = version | |
| 866 | self.msg = msg | |
| 867 | ||
| 868 | ||
| 1185.35.42
by Aaron Bentley Fixed fetch to be safer wrt ghosts and corrupt branches | 869 | class MissingText(BzrNewError): | 
| 870 | """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 | 871 | |
| 1185.35.42
by Aaron Bentley Fixed fetch to be safer wrt ghosts and corrupt branches | 872 | def __init__(self, branch, text_revision, file_id): | 
| 1534.3.1
by Robert Collins * bzrlib.osutils.safe_unicode now exists to provide parameter coercion | 873 | BzrNewError.__init__(self) | 
| 1185.35.42
by Aaron Bentley Fixed fetch to be safer wrt ghosts and corrupt branches | 874 | self.branch = branch | 
| 875 | self.base = branch.base | |
| 876 | self.text_revision = text_revision | |
| 877 | self.file_id = file_id | |
| 1534.7.5
by Aaron Bentley Got unique_add under test | 878 | |
| 1505.1.23
by John Arbash Meinel Whitespace cleanup of bzrlib.errors | 879 | |
| 1534.7.5
by Aaron Bentley Got unique_add under test | 880 | class DuplicateKey(BzrNewError): | 
| 881 | """Key %(key)s is already present in map""" | |
| 1534.7.6
by Aaron Bentley Added conflict handling | 882 | |
| 1587.1.6
by Robert Collins Update bound branch implementation to 0.8. | 883 | |
| 1534.7.6
by Aaron Bentley Added conflict handling | 884 | class MalformedTransform(BzrNewError): | 
| 1534.7.49
by Aaron Bentley Printed conflicts in MalformedTransform | 885 | """Tree transform is malformed %(conflicts)r""" | 
| 1534.7.24
by Aaron Bentley Merge from the mainline | 886 | |
| 1534.3.1
by Robert Collins * bzrlib.osutils.safe_unicode now exists to provide parameter coercion | 887 | |
| 888 | class BzrBadParameter(BzrNewError): | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 889 | """A bad parameter : %(param)s is not usable. | 
| 1534.3.1
by Robert Collins * bzrlib.osutils.safe_unicode now exists to provide parameter coercion | 890 |     
 | 
| 1185.65.29
by Robert Collins Implement final review suggestions. | 891 |     This exception should never be thrown, but it is a base class for all
 | 
| 892 |     parameter-to-function errors.
 | |
| 893 |     """
 | |
| 1534.3.1
by Robert Collins * bzrlib.osutils.safe_unicode now exists to provide parameter coercion | 894 | def __init__(self, param): | 
| 895 | BzrNewError.__init__(self) | |
| 896 | self.param = param | |
| 1534.7.32
by Aaron Bentley Got conflict handling working when conflicts involve existing files | 897 | |
| 1534.4.3
by Robert Collins Implement BranchTestProviderAdapter, so tests now run across all branch formats. | 898 | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 899 | class BzrBadParameterNotUnicode(BzrBadParameter): | 
| 900 | """Parameter %(param)s is neither unicode nor utf8.""" | |
| 1534.7.120
by Aaron Bentley PEP8 fixes | 901 | |
| 902 | ||
| 1534.7.32
by Aaron Bentley Got conflict handling working when conflicts involve existing files | 903 | class ReusingTransform(BzrNewError): | 
| 904 | """Attempt to reuse a transform that has already been applied.""" | |
| 1534.7.66
by Aaron Bentley Ensured we don't accidentally move the root directory | 905 | |
| 1534.7.120
by Aaron Bentley PEP8 fixes | 906 | |
| 1534.7.66
by Aaron Bentley Ensured we don't accidentally move the root directory | 907 | class CantMoveRoot(BzrNewError): | 
| 908 | """Moving the root directory is not supported at this time""" | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 909 | |
| 1534.7.120
by Aaron Bentley PEP8 fixes | 910 | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 911 | class BzrBadParameterNotString(BzrBadParameter): | 
| 912 | """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. | 913 | |
| 914 | ||
| 1534.4.44
by Robert Collins Make a new BzrDir format that uses a versioned branch format in a branch/ subdirectory. | 915 | class BzrBadParameterMissing(BzrBadParameter): | 
| 916 | """Parameter $(param)s is required but not present.""" | |
| 917 | ||
| 918 | ||
| 1666.1.6
by Robert Collins Make knit the default format. | 919 | class BzrBadParameterUnicode(BzrBadParameter): | 
| 1666.1.9
by Robert Collins Mark knits as no longer experimental. | 920 | """Parameter %(param)s is unicode but only byte-strings are permitted.""" | 
| 1666.1.6
by Robert Collins Make knit the default format. | 921 | |
| 922 | ||
| 923 | class BzrBadParameterContainsNewline(BzrBadParameter): | |
| 1666.1.9
by Robert Collins Mark knits as no longer experimental. | 924 | """Parameter %(param)s contains a newline.""" | 
| 1666.1.6
by Robert Collins Make knit the default format. | 925 | |
| 926 | ||
| 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. | 927 | class DependencyNotPresent(BzrNewError): | 
| 1540.3.7
by Martin Pool Prepare to select a transport depending on what dependencies can be satisfied. | 928 | """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. | 929 | |
| 930 | def __init__(self, library, error): | |
| 931 | BzrNewError.__init__(self, library=library, error=error) | |
| 932 | ||
| 933 | ||
| 934 | class ParamikoNotPresent(DependencyNotPresent): | |
| 935 | """Unable to import paramiko (required for sftp support): %(error)s""" | |
| 936 | ||
| 937 | def __init__(self, error): | |
| 938 | DependencyNotPresent.__init__(self, 'paramiko', error) | |
| 939 | ||
| 940 | ||
| 1534.4.3
by Robert Collins Implement BranchTestProviderAdapter, so tests now run across all branch formats. | 941 | class UninitializableFormat(BzrNewError): | 
| 942 | """Format %(format)s cannot be initialised by this version of bzr.""" | |
| 943 | ||
| 944 | def __init__(self, format): | |
| 945 | BzrNewError.__init__(self) | |
| 946 | self.format = format | |
| 1551.3.4
by Aaron Bentley Implemented default command options | 947 | |
| 1534.7.156
by Aaron Bentley PEP8 fixes | 948 | |
| 1711.2.56
by John Arbash Meinel Raise NoDiff if 'diff' not present. | 949 | class NoDiff(BzrNewError): | 
| 950 | """Diff is not installed on this machine: %(msg)s""" | |
| 951 | ||
| 952 | def __init__(self, msg): | |
| 1899.1.1
by John Arbash Meinel Fix the bug in the NoDiff exception class, and add a test | 953 | BzrNewError.__init__(self, msg=msg) | 
| 1711.2.56
by John Arbash Meinel Raise NoDiff if 'diff' not present. | 954 | |
| 955 | ||
| 1534.7.130
by Aaron Bentley More conflict handling, test porting | 956 | class NoDiff3(BzrNewError): | 
| 957 | """Diff3 is not installed on this machine.""" | |
| 1534.7.162
by Aaron Bentley Handle failures creating/deleting the Limbo directory | 958 | |
| 959 | ||
| 960 | class ExistingLimbo(BzrNewError): | |
| 961 | """This tree contains left-over files from a failed operation. | |
| 962 |     Please examine %(limbo_dir)s to see if it contains any files you wish to
 | |
| 963 |     keep, and delete it when you are done.
 | |
| 964 |     """
 | |
| 965 | def __init__(self, limbo_dir): | |
| 966 | BzrNewError.__init__(self) | |
| 967 | self.limbo_dir = limbo_dir | |
| 968 | ||
| 969 | ||
| 970 | class ImmortalLimbo(BzrNewError): | |
| 971 | """Unable to delete transform temporary directory $(limbo_dir)s. | |
| 972 |     Please examine %(limbo_dir)s to see if it contains any files you wish to
 | |
| 973 |     keep, and delete it when you are done.
 | |
| 974 |     """
 | |
| 975 | def __init__(self, limbo_dir): | |
| 976 | BzrNewError.__init__(self) | |
| 977 | self.limbo_dir = limbo_dir | |
| 1534.7.163
by Aaron Bentley Merge from Robert [Fails tests] | 978 | |
| 979 | ||
| 1508.1.22
by Robert Collins implement out of date working tree checks in commit. | 980 | class OutOfDateTree(BzrNewError): | 
| 981 | """Working tree is out of date, please run 'bzr update'.""" | |
| 1508.1.25
by Robert Collins Update per review comments. | 982 | |
| 983 | def __init__(self, tree): | |
| 984 | BzrNewError.__init__(self) | |
| 985 | self.tree = tree | |
| 1534.7.196
by Aaron Bentley Switched to Rio format for merge-modified list | 986 | |
| 1563.2.22
by Robert Collins Move responsibility for repository.has_revision into RevisionStore | 987 | |
| 1534.7.196
by Aaron Bentley Switched to Rio format for merge-modified list | 988 | class MergeModifiedFormatError(BzrNewError): | 
| 989 | """Error in merge modified format""" | |
| 1534.7.200
by Aaron Bentley Merge from mainline | 990 | |
| 991 | ||
| 1534.10.7
by Aaron Bentley Added tests for bad conflict lists | 992 | class ConflictFormatError(BzrNewError): | 
| 993 | """Format error in conflict listings""" | |
| 994 | ||
| 995 | ||
| 1570.1.13
by Robert Collins Check for incorrect revision parentage in the weave during revision access. | 996 | class CorruptRepository(BzrNewError): | 
| 997 | """An error has been detected in the repository %(repo_path)s. | |
| 998 | Please run bzr reconcile on this repository."""
 | |
| 999 | ||
| 1000 | def __init__(self, repo): | |
| 1001 | BzrNewError.__init__(self) | |
| 1002 | self.repo_path = repo.bzrdir.root_transport.base | |
| 1587.1.6
by Robert Collins Update bound branch implementation to 0.8. | 1003 | |
| 1004 | ||
| 1005 | class UpgradeRequired(BzrNewError): | |
| 1006 | """To use this feature you must upgrade your branch at %(path)s.""" | |
| 1007 | ||
| 1008 | def __init__(self, path): | |
| 1009 | BzrNewError.__init__(self) | |
| 1010 | self.path = path | |
| 1011 | ||
| 1587.1.8
by Robert Collins Local commits on unbound branches fail. | 1012 | |
| 1013 | class LocalRequiresBoundBranch(BzrNewError): | |
| 1014 | """Cannot perform local-only commits on unbound branches.""" | |
| 1594.1.1
by Robert Collins Introduce new bzr progress bar api. ui_factory.nested_progress_bar. | 1015 | |
| 1016 | ||
| 1017 | class MissingProgressBarFinish(BzrNewError): | |
| 1018 | """A nested progress bar was not 'finished' correctly.""" | |
| 1534.10.8
by Aaron Bentley Implemented conflict_lines in terms of old system on WorkingTree | 1019 | |
| 1020 | ||
| 1843.3.7
by John Arbash Meinel new env var 'BZR_PROGRESS_BAR' to select the exact progress type | 1021 | class InvalidProgressBarType(BzrNewError): | 
| 1022 | """Environment variable BZR_PROGRESS_BAR='%(bar_type)s is not a supported type | |
| 1023 | Select one of: %(valid_types)s"""
 | |
| 1024 | ||
| 1025 | def __init__(self, bar_type, valid_types): | |
| 1026 | BzrNewError.__init__(self, bar_type=bar_type, valid_types=valid_types) | |
| 1027 | ||
| 1028 | ||
| 1534.10.8
by Aaron Bentley Implemented conflict_lines in terms of old system on WorkingTree | 1029 | class UnsupportedOperation(BzrNewError): | 
| 1030 | """The method %(mname)s is not supported on objects of type %(tname)s.""" | |
| 1031 | def __init__(self, method, method_self): | |
| 1032 | self.method = method | |
| 1033 | self.mname = method.__name__ | |
| 1034 | self.tname = type(method_self).__name__ | |
| 1558.15.1
by Aaron Bentley Add text_file function | 1035 | |
| 1036 | ||
| 1037 | class BinaryFile(BzrNewError): | |
| 1038 | """File is binary but should be text.""" | |
| 1551.2.55
by abentley Fix fileid involed tests on win32 (by skipping them for unescaped weave formats) | 1039 | |
| 1040 | ||
| 1041 | class IllegalPath(BzrNewError): | |
| 1042 | """The path %(path)s is not permitted on this platform""" | |
| 1043 | ||
| 1044 | def __init__(self, path): | |
| 1045 | BzrNewError.__init__(self) | |
| 1046 | self.path = path | |
| 1185.82.118
by Aaron Bentley Ensure that StrictTestament handles execute bit differences | 1047 | |
| 1048 | ||
| 1049 | class TestamentMismatch(BzrNewError): | |
| 1050 | """Testament did not match expected value. | |
| 1051 |        For revision_id {%(revision_id)s}, expected {%(expected)s}, measured 
 | |
| 1052 |        {%(measured)s}
 | |
| 1053 |     """
 | |
| 1054 | def __init__(self, revision_id, expected, measured): | |
| 1055 | self.revision_id = revision_id | |
| 1056 | self.expected = expected | |
| 1057 | self.measured = measured | |
| 1185.82.131
by Aaron Bentley Move BadBundle error (and subclasses) to errors.py | 1058 | |
| 1059 | ||
| 1185.82.139
by Aaron Bentley Raise NotABundle when a non-bundle is supplied | 1060 | class NotABundle(BzrNewError): | 
| 1061 | """Not a bzr revision-bundle: %(text)r""" | |
| 1185.82.142
by Aaron Bentley Update for review comments | 1062 | |
| 1185.82.139
by Aaron Bentley Raise NotABundle when a non-bundle is supplied | 1063 | def __init__(self, text): | 
| 1064 | self.text = text | |
| 1065 | ||
| 1066 | ||
| 1185.82.131
by Aaron Bentley Move BadBundle error (and subclasses) to errors.py | 1067 | class BadBundle(Exception): pass | 
| 1068 | ||
| 1069 | ||
| 1070 | class MalformedHeader(BadBundle): pass | |
| 1071 | ||
| 1072 | ||
| 1073 | class MalformedPatches(BadBundle): pass | |
| 1074 | ||
| 1075 | ||
| 1076 | class MalformedFooter(BadBundle): pass |