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
 | 
| 1
by mbp at sourcefrog import from baz patch-364 | 2 | |
| 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.
 | |
| 7 | ||
| 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.
 | |
| 12 | ||
| 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 | Exceptions are caught at a high level to report errors to the user, and
 | |
| 20 | might also be caught inside the program.  Therefore it needs to be
 | |
| 21 | possible to convert them to a meaningful string, and also for them to be
 | |
| 22 | interrogated by the program.
 | |
| 23 | ||
| 24 | Exceptions are defined such that the arguments given to the constructor
 | |
| 25 | are stored in the object as properties of the same name.  When the
 | |
| 26 | object is printed as a string, the doc string of the class is used as
 | |
| 27 | a format string with the property dictionary available to it.
 | |
| 28 | ||
| 29 | This means that exceptions can used like this:
 | |
| 30 | ||
| 31 | >>> import sys
 | |
| 32 | >>> try:
 | |
| 33 | ...   raise NotBranchError(path='/foo/bar')
 | |
| 34 | ... except:
 | |
| 35 | ...   print sys.exc_type
 | |
| 36 | ...   print sys.exc_value
 | |
| 1185.50.38
by John Arbash Meinel Changed exception traceback route to not use hasattr, which generates its own exception. | 37 | ...   path = getattr(sys.exc_value, 'path')
 | 
| 38 | ...   if path is not None:
 | |
| 39 | ...     print path
 | |
| 1185.16.61
by mbp at sourcefrog - start introducing hct error classes | 40 | bzrlib.errors.NotBranchError
 | 
| 41 | Not a branch: /foo/bar
 | |
| 42 | /foo/bar
 | |
| 43 | ||
| 44 | Therefore:
 | |
| 45 | ||
| 46 |  * create a new exception class for any class of error that can be
 | |
| 47 |    usefully distinguished.
 | |
| 48 | ||
| 49 |  * the printable form of an exception is generated by the base class
 | |
| 50 |    __str__ method
 | |
| 1185.33.7
by Martin Pool Better formatting of builtin errors | 51 | |
| 52 | Exception strings should start with a capital letter and not have a final
 | |
| 53 | fullstop.
 | |
| 1185.16.61
by mbp at sourcefrog - start introducing hct error classes | 54 | """
 | 
| 55 | ||
| 56 | # based on Scott James Remnant's hct error classes
 | |
| 57 | ||
| 1185.16.62
by mbp at sourcefrog - convert NotBranchError to new exception base | 58 | # TODO: is there any value in providing the .args field used by standard
 | 
| 59 | # python exceptions?   A list of values with no names seems less useful 
 | |
| 60 | # to me.
 | |
| 61 | ||
| 1185.16.63
by Martin Pool - more error conversion | 62 | # TODO: Perhaps convert the exception to a string at the moment it's 
 | 
| 63 | # constructed to make sure it will succeed.  But that says nothing about
 | |
| 64 | # exceptions that are never raised.
 | |
| 65 | ||
| 66 | # TODO: Convert all the other error classes here to BzrNewError, and eliminate
 | |
| 67 | # the old one.
 | |
| 1185.16.62
by mbp at sourcefrog - convert NotBranchError to new exception base | 68 | |
| 1185.16.61
by mbp at sourcefrog - start introducing hct error classes | 69 | |
| 1
by mbp at sourcefrog import from baz patch-364 | 70 | class BzrError(StandardError): | 
| 1193
by Martin Pool - better string formatting of BzrErrors with explanation | 71 | def __str__(self): | 
| 1393.1.64
by Martin Pool - improved display of some errors, including NotBranchError | 72 |         # XXX: Should we show the exception class in 
 | 
| 73 |         # exceptions that don't provide their own message?  
 | |
| 74 |         # maybe it should be done at a higher level
 | |
| 75 |         ## n = self.__class__.__name__ + ': '
 | |
| 76 | n = '' | |
| 1195
by Martin Pool - better error display | 77 | if len(self.args) == 1: | 
| 1449
by Robert Collins teach check about ghosts | 78 | return str(self.args[0]) | 
| 1195
by Martin Pool - better error display | 79 | elif len(self.args) == 2: | 
| 1193
by Martin Pool - better string formatting of BzrErrors with explanation | 80 |             # 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 | 81 | try: | 
| 1393.1.64
by Martin Pool - improved display of some errors, including NotBranchError | 82 | 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 | 83 | except TypeError: | 
| 1393.1.64
by Martin Pool - improved display of some errors, including NotBranchError | 84 | return n + "%r" % self | 
| 1193
by Martin Pool - better string formatting of BzrErrors with explanation | 85 | else: | 
| 1393.1.64
by Martin Pool - improved display of some errors, including NotBranchError | 86 | return n + `self.args` | 
| 1193
by Martin Pool - better string formatting of BzrErrors with explanation | 87 | |
| 1185.1.14
by Robert Collins remove more duplicate merged hunks. Bad MERGE3, BAD. | 88 | |
| 1185.16.62
by mbp at sourcefrog - convert NotBranchError to new exception base | 89 | class BzrNewError(BzrError): | 
| 1185.16.61
by mbp at sourcefrog - start introducing hct error classes | 90 | """bzr error""" | 
| 91 |     # base classes should override the docstring with their human-
 | |
| 92 |     # readable explanation
 | |
| 93 | ||
| 94 | def __init__(self, **kwds): | |
| 95 | for key, value in kwds.items(): | |
| 96 | setattr(self, key, value) | |
| 97 | ||
| 98 | def __str__(self): | |
| 99 | try: | |
| 100 | return self.__doc__ % self.__dict__ | |
| 101 | except (NameError, ValueError, KeyError), e: | |
| 102 | return 'Unprintable exception %s: %s' \ | |
| 103 | % (self.__class__.__name__, str(e)) | |
| 104 | ||
| 105 | ||
| 1185.16.63
by Martin Pool - more error conversion | 106 | class BzrCheckError(BzrNewError): | 
| 107 | """Internal check failed: %(message)s""" | |
| 1508.1.22
by Robert Collins implement out of date working tree checks in commit. | 108 | |
| 1185.16.63
by Martin Pool - more error conversion | 109 | def __init__(self, message): | 
| 1185.16.103
by mbp at sourcefrog Fix up all calls to InvalidRevisionId() to specify parameters. | 110 | BzrNewError.__init__(self) | 
| 1185.16.63
by Martin Pool - more error conversion | 111 | self.message = message | 
| 112 | ||
| 113 | ||
| 114 | class InvalidEntryName(BzrNewError): | |
| 115 | """Invalid entry name: %(name)s""" | |
| 116 | def __init__(self, name): | |
| 1185.16.103
by mbp at sourcefrog Fix up all calls to InvalidRevisionId() to specify parameters. | 117 | BzrNewError.__init__(self) | 
| 1185.16.63
by Martin Pool - more error conversion | 118 | self.name = name | 
| 119 | ||
| 120 | ||
| 121 | class InvalidRevisionNumber(BzrNewError): | |
| 122 | """Invalid revision number %(revno)d""" | |
| 123 | def __init__(self, revno): | |
| 1185.16.103
by mbp at sourcefrog Fix up all calls to InvalidRevisionId() to specify parameters. | 124 | BzrNewError.__init__(self) | 
| 1185.16.63
by Martin Pool - more error conversion | 125 | self.revno = revno | 
| 126 | ||
| 127 | ||
| 128 | class InvalidRevisionId(BzrNewError): | |
| 1185.16.103
by mbp at sourcefrog Fix up all calls to InvalidRevisionId() to specify parameters. | 129 | """Invalid revision-id {%(revision_id)s} in %(branch)s""" | 
| 130 | def __init__(self, revision_id, branch): | |
| 131 | BzrNewError.__init__(self) | |
| 1185.12.90
by Aaron Bentley Fixed InvalidRevisionID handling in Branch.get_revision_xml | 132 | self.revision_id = revision_id | 
| 1185.16.103
by mbp at sourcefrog Fix up all calls to InvalidRevisionId() to specify parameters. | 133 | self.branch = branch | 
| 974.1.26
by aaron.bentley at utoronto merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472 | 134 | |
| 135 | ||
| 1497
by Robert Collins Move Branch.read_working_inventory to WorkingTree. | 136 | class NoWorkingTree(BzrNewError): | 
| 137 | """No WorkingTree exists for %s(base).""" | |
| 138 | ||
| 139 | def __init__(self, base): | |
| 140 | BzrNewError.__init__(self) | |
| 141 | self.base = base | |
| 1506
by Robert Collins Merge Johns current integration work. | 142 | |
| 143 | ||
| 1534.4.42
by Robert Collins add working tree to the BzrDir facilities. | 144 | class NotLocalUrl(BzrNewError): | 
| 145 | """%s(url) is not a local path.""" | |
| 146 | ||
| 147 | def __init__(self, url): | |
| 148 | BzrNewError.__init__(self) | |
| 149 | self.url = url | |
| 150 | ||
| 151 | ||
| 329
by Martin Pool - refactor command functions into command classes | 152 | class BzrCommandError(BzrError): | 
| 153 |     # Error from malformed user command
 | |
| 1495
by Robert Collins Add a --create-prefix to the new push command. | 154 |     # This is being misused as a generic exception
 | 
| 155 |     # pleae subclass. RBC 20051030
 | |
| 1185.54.18
by Aaron Bentley Noted difference of opinion wrt BzrCommandError | 156 |     #
 | 
| 157 |     # I think it's a waste of effort to differentiate between errors that
 | |
| 158 |     # are not intended to be caught anyway.  UI code need not subclass
 | |
| 159 |     # BzrCommandError, and non-UI code should not throw a subclass of
 | |
| 160 |     # BzrCommandError.  ADHB 20051211
 | |
| 1393.1.64
by Martin Pool - improved display of some errors, including NotBranchError | 161 | def __str__(self): | 
| 162 | return self.args[0] | |
| 1
by mbp at sourcefrog import from baz patch-364 | 163 | |
| 1495
by Robert Collins Add a --create-prefix to the new push command. | 164 | |
| 165 | class BzrOptionError(BzrCommandError): | |
| 166 | """Some missing or otherwise incorrect option was supplied.""" | |
| 167 | ||
| 168 | ||
| 1185.16.65
by mbp at sourcefrog - new commit --strict option | 169 | class StrictCommitFailed(Exception): | 
| 170 | """Commit refused because there are unknowns in the tree.""" | |
| 1
by mbp at sourcefrog import from baz patch-364 | 171 | |
| 1185.31.41
by John Arbash Meinel Creating a PathNotChild exception, and using relpath in HTTPTestUtil | 172 | |
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 173 | class PathError(BzrNewError): | 
| 174 | """Generic path error: %(path)r%(extra)s)""" | |
| 175 | def __init__(self, path, extra=None): | |
| 176 | BzrNewError.__init__(self) | |
| 177 | self.path = path | |
| 178 | if extra: | |
| 179 | self.extra = ': ' + str(extra) | |
| 180 | else: | |
| 181 | self.extra = '' | |
| 182 | ||
| 183 | ||
| 184 | class NoSuchFile(PathError): | |
| 185 | """No such file: %(path)r%(extra)s""" | |
| 186 | ||
| 187 | ||
| 188 | class FileExists(PathError): | |
| 189 | """File exists: %(path)r%(extra)s""" | |
| 190 | ||
| 191 | ||
| 1553.5.10
by Martin Pool New DirectoryNotEmpty exception, and raise this from local and memory | 192 | class DirectoryNotEmpty(PathError): | 
| 193 | """Directory not empty: %(path)r%(extra)s""" | |
| 194 | ||
| 195 | ||
| 1558.10.1
by Aaron Bentley Handle lockdirs over NFS properly | 196 | class ResourceBusy(PathError): | 
| 197 | """Device or resource busy: %(path)r%(extra)s""" | |
| 198 | ||
| 199 | ||
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 200 | class PermissionDenied(PathError): | 
| 201 | """Permission denied: %(path)r%(extra)s""" | |
| 202 | ||
| 203 | ||
| 1185.31.41
by John Arbash Meinel Creating a PathNotChild exception, and using relpath in HTTPTestUtil | 204 | class PathNotChild(BzrNewError): | 
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 205 | """Path %(path)r is not a child of path %(base)r%(extra)s""" | 
| 206 | def __init__(self, path, base, extra=None): | |
| 1185.31.41
by John Arbash Meinel Creating a PathNotChild exception, and using relpath in HTTPTestUtil | 207 | BzrNewError.__init__(self) | 
| 208 | self.path = path | |
| 209 | self.base = base | |
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 210 | if extra: | 
| 211 | self.extra = ': ' + str(extra) | |
| 212 | else: | |
| 213 | self.extra = '' | |
| 1185.31.41
by John Arbash Meinel Creating a PathNotChild exception, and using relpath in HTTPTestUtil | 214 | |
| 215 | ||
| 1185.16.62
by mbp at sourcefrog - convert NotBranchError to new exception base | 216 | class NotBranchError(BzrNewError): | 
| 217 | """Not a branch: %(path)s""" | |
| 1185.16.61
by mbp at sourcefrog - start introducing hct error classes | 218 | def __init__(self, path): | 
| 1185.16.62
by mbp at sourcefrog - convert NotBranchError to new exception base | 219 | BzrNewError.__init__(self) | 
| 220 | self.path = path | |
| 221 | ||
| 573
by Martin Pool - new exception NotBranchError | 222 | |
| 1534.4.47
by Robert Collins Split out repository into .bzr/repository | 223 | class NoRepositoryPresent(BzrNewError): | 
| 224 | """Not repository present: %(path)r""" | |
| 225 | def __init__(self, bzrdir): | |
| 226 | BzrNewError.__init__(self) | |
| 227 | self.path = bzrdir.transport.clone('..').base | |
| 228 | ||
| 229 | ||
| 1185.35.32
by Aaron Bentley Fixed handling of files in mixed branches | 230 | class FileInWrongBranch(BzrNewError): | 
| 231 | """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. | 232 | |
| 1185.35.32
by Aaron Bentley Fixed handling of files in mixed branches | 233 | def __init__(self, branch, path): | 
| 234 | BzrNewError.__init__(self) | |
| 235 | self.branch = branch | |
| 236 | self.branch_base = branch.base | |
| 237 | self.path = path | |
| 238 | ||
| 239 | ||
| 1185.1.53
by Robert Collins raise a specific error on unsupported branches so that they can be distinguished from generic errors | 240 | class UnsupportedFormatError(BzrError): | 
| 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. | 241 | """Specified path is a bzr branch that we recognize but cannot read.""" | 
| 1185.1.53
by Robert Collins raise a specific error on unsupported branches so that they can be distinguished from generic errors | 242 | def __str__(self): | 
| 243 | return 'unsupported branch format: %s' % self.args[0] | |
| 244 | ||
| 245 | ||
| 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. | 246 | class UnknownFormatError(BzrError): | 
| 247 | """Specified path is a bzr branch whose format we do not recognize.""" | |
| 248 | def __str__(self): | |
| 249 | return 'unknown branch format: %s' % self.args[0] | |
| 250 | ||
| 251 | ||
| 1534.4.44
by Robert Collins Make a new BzrDir format that uses a versioned branch format in a branch/ subdirectory. | 252 | class IncompatibleFormat(BzrNewError): | 
| 253 | """Format %(format)s is not compatible with .bzr version %(bzrdir)s.""" | |
| 254 | ||
| 255 | def __init__(self, format, bzrdir_format): | |
| 256 | BzrNewError.__init__(self) | |
| 257 | self.format = format | |
| 258 | self.bzrdir = bzrdir_format | |
| 259 | ||
| 260 | ||
| 1185.16.72
by Martin Pool [merge] from robert and fix up tests | 261 | class NotVersionedError(BzrNewError): | 
| 262 | """%(path)s is not versioned""" | |
| 263 | def __init__(self, path): | |
| 264 | BzrNewError.__init__(self) | |
| 265 | self.path = path | |
| 753
by Martin Pool - new exception NotVersionedError | 266 | |
| 267 | ||
| 599
by Martin Pool - better error reporting from smart_add | 268 | class BadFileKindError(BzrError): | 
| 269 | """Specified file is of a kind that cannot be added. | |
| 270 | ||
| 271 |     (For example a symlink or device file.)"""
 | |
| 272 | ||
| 273 | ||
| 274 | class ForbiddenFileError(BzrError): | |
| 275 | """Cannot operate on a file because it is a control file.""" | |
| 276 | ||
| 277 | ||
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 278 | class LockError(BzrNewError): | 
| 279 | """Lock error: %(message)s""" | |
| 1185.16.63
by Martin Pool - more error conversion | 280 |     # All exceptions from the lock/unlock functions should be from
 | 
| 281 |     # this exception class.  They will be translated as necessary. The
 | |
| 282 |     # original exception is available as e.original_error
 | |
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 283 |     #
 | 
| 284 |     # New code should prefer to raise specific subclasses
 | |
| 285 | def __init__(self, message): | |
| 286 | self.message = message | |
| 882
by Martin Pool - Optionally raise EmptyCommit if there are no changes. Test for this. | 287 | |
| 288 | ||
| 1417.1.6
by Robert Collins introduce transactions for grouping actions done to and with branches | 289 | class CommitNotPossible(LockError): | 
| 290 | """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 | 291 | def __init__(self): | 
| 292 |         pass
 | |
| 1417.1.6
by Robert Collins introduce transactions for grouping actions done to and with branches | 293 | |
| 294 | ||
| 295 | class AlreadyCommitted(LockError): | |
| 296 | """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 | 297 | def __init__(self): | 
| 298 |         pass
 | |
| 1417.1.6
by Robert Collins introduce transactions for grouping actions done to and with branches | 299 | |
| 300 | ||
| 1417.1.8
by Robert Collins use transactions in the weave store interface, which enables caching for log | 301 | class ReadOnlyError(LockError): | 
| 1553.5.33
by Martin Pool LockDir review comment fixes | 302 | """A write attempt was made in a read only transaction on %(obj)s""" | 
| 303 | def __init__(self, obj): | |
| 304 | self.obj = obj | |
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 305 | |
| 306 | ||
| 1594.2.21
by Robert Collins Teach versioned files to prevent mutation after finishing. | 307 | class OutSideTransaction(BzrNewError): | 
| 308 | """A transaction related operation was attempted after the transaction finished.""" | |
| 309 | ||
| 310 | ||
| 1553.5.36
by Martin Pool Clean up duplicate BranchNotLocked error and rename to ObjectNotLocked | 311 | class ObjectNotLocked(LockError): | 
| 312 | """%(obj)r is not locked""" | |
| 313 |     # this can indicate that any particular object is not locked; see also
 | |
| 314 |     # LockNotHeld which means that a particular *lock* object is not held by
 | |
| 315 |     # the caller -- perhaps they should be unified.
 | |
| 316 | def __init__(self, obj): | |
| 317 | self.obj = obj | |
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 318 | |
| 319 | ||
| 320 | class ReadOnlyObjectDirtiedError(ReadOnlyError): | |
| 321 | """Cannot change object %(obj)r in read only transaction""" | |
| 322 | def __init__(self, obj): | |
| 323 | self.obj = obj | |
| 324 | ||
| 325 | ||
| 326 | class UnlockableTransport(LockError): | |
| 327 | """Cannot lock: transport is read only: %(transport)s""" | |
| 328 | def __init__(self, transport): | |
| 329 | self.transport = transport | |
| 330 | ||
| 331 | ||
| 332 | class LockContention(LockError): | |
| 333 | """Could not acquire lock %(lock)s""" | |
| 334 |     # TODO: show full url for lock, combining the transport and relative bits?
 | |
| 335 | def __init__(self, lock): | |
| 336 | self.lock = lock | |
| 337 | ||
| 338 | ||
| 1553.5.23
by Martin Pool Start LockDir.confirm method and LockBroken exception | 339 | class LockBroken(LockError): | 
| 1553.5.24
by Martin Pool Warning to check storage when lock was broken | 340 | """Lock was broken while still open: %(lock)s - check storage consistency!""" | 
| 1553.5.23
by Martin Pool Start LockDir.confirm method and LockBroken exception | 341 | def __init__(self, lock): | 
| 342 | self.lock = lock | |
| 343 | ||
| 344 | ||
| 1553.5.27
by Martin Pool Confirm that only the intended holder of a lock was broken. | 345 | class LockBreakMismatch(LockError): | 
| 346 | """Lock was released and re-acquired before being broken: %(lock)s: held by %(holder)r, wanted to break %(target)r""" | |
| 347 | def __init__(self, lock, holder, target): | |
| 348 | self.lock = lock | |
| 349 | self.holder = holder | |
| 350 | self.target = target | |
| 351 | ||
| 352 | ||
| 1553.5.11
by Martin Pool Change some lock and transaction related exceptions to BzrNewException style | 353 | class LockNotHeld(LockError): | 
| 354 | """Lock not held: %(lock)s""" | |
| 355 | def __init__(self, lock): | |
| 356 | self.lock = lock | |
| 357 | ||
| 358 | ||
| 1185.16.63
by Martin Pool - more error conversion | 359 | class PointlessCommit(BzrNewError): | 
| 1185.16.64
by Martin Pool - more error conversions | 360 | """No changes to commit""" | 
| 974.1.26
by aaron.bentley at utoronto merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472 | 361 | |
| 1551.3.1
by Aaron Bentley PEP8 fixes | 362 | |
| 1534.4.13
by Robert Collins Give a reasonable warning on attempts to upgrade a readonly url. | 363 | class UpgradeReadonly(BzrNewError): | 
| 364 | """Upgrade URL cannot work with readonly URL's.""" | |
| 365 | ||
| 366 | ||
| 1534.5.7
by Robert Collins Start factoring out the upgrade policy logic. | 367 | class UpToDateFormat(BzrNewError): | 
| 368 | """The branch format %(format)s is already at the most recent format.""" | |
| 369 | ||
| 370 | def __init__(self, format): | |
| 371 | BzrNewError.__init__(self) | |
| 372 | self.format = format | |
| 373 | ||
| 374 | ||
| 1587.1.6
by Robert Collins Update bound branch implementation to 0.8. | 375 | |
| 1185.22.1
by Michael Ellerman Implement strict commits with --strict flag. | 376 | class StrictCommitFailed(Exception): | 
| 377 | """Commit refused because there are unknowns in the tree.""" | |
| 974.1.26
by aaron.bentley at utoronto merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472 | 378 | |
| 1505.1.2
by John Arbash Meinel (broken) working on implementing bound branches. | 379 | |
| 974.1.26
by aaron.bentley at utoronto merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472 | 380 | class NoSuchRevision(BzrError): | 
| 381 | def __init__(self, branch, revision): | |
| 382 | self.branch = branch | |
| 383 | self.revision = revision | |
| 384 | msg = "Branch %s has no revision %s" % (branch, revision) | |
| 385 | BzrError.__init__(self, msg) | |
| 386 | ||
| 1034
by Martin Pool - merge bzrlib.revision.is_ancestor from aaron | 387 | |
| 1192
by Martin Pool - clean up code for retrieving stored inventories | 388 | class HistoryMissing(BzrError): | 
| 389 | def __init__(self, branch, object_type, object_id): | |
| 390 | self.branch = branch | |
| 391 | BzrError.__init__(self, | |
| 392 | '%s is missing %s {%s}' | |
| 393 | % (branch, object_type, object_id)) | |
| 394 | ||
| 395 | ||
| 1185.2.1
by Lalo Martins moving DivergedBranches from bzrlib.branch to bzrlib.errors, obeying: | 396 | class DivergedBranches(BzrError): | 
| 1649.1.1
by Robert Collins * 'pull' and 'push' now normalise the revision history, so that any two | 397 | |
| 1185.2.1
by Lalo Martins moving DivergedBranches from bzrlib.branch to bzrlib.errors, obeying: | 398 | def __init__(self, branch1, branch2): | 
| 1185.56.1
by Michael Ellerman Simplify handling of DivergedBranches in cmd_pull() | 399 | BzrError.__init__(self, "These branches have diverged. Try merge.") | 
| 1185.2.1
by Lalo Martins moving DivergedBranches from bzrlib.branch to bzrlib.errors, obeying: | 400 | self.branch1 = branch1 | 
| 401 | self.branch2 = branch2 | |
| 402 | ||
| 1390
by Robert Collins pair programming worx... merge integration and weave | 403 | |
| 1105
by Martin Pool - expose 'find-merge-base' as a new expert command, | 404 | class UnrelatedBranches(BzrCommandError): | 
| 405 | def __init__(self): | |
| 406 | msg = "Branches have no common ancestor, and no base revision"\ | |
| 407 |             " specified."
 | |
| 408 | BzrCommandError.__init__(self, msg) | |
| 409 | ||
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 410 | |
| 974.1.80
by Aaron Bentley Improved merge error handling and testing | 411 | class NoCommonAncestor(BzrError): | 
| 412 | def __init__(self, revision_a, revision_b): | |
| 413 | msg = "Revisions have no common ancestor: %s %s." \ | |
| 414 | % (revision_a, revision_b) | |
| 415 | BzrError.__init__(self, msg) | |
| 416 | ||
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 417 | |
| 974.1.80
by Aaron Bentley Improved merge error handling and testing | 418 | class NoCommonRoot(BzrError): | 
| 419 | def __init__(self, revision_a, revision_b): | |
| 420 | msg = "Revisions are not derived from the same root: %s %s." \ | |
| 421 | % (revision_a, revision_b) | |
| 422 | BzrError.__init__(self, msg) | |
| 1105
by Martin Pool - expose 'find-merge-base' as a new expert command, | 423 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 424 | |
| 1587.1.6
by Robert Collins Update bound branch implementation to 0.8. | 425 | |
| 974.2.7
by aaron.bentley at utoronto Merged from bzr.24 | 426 | class NotAncestor(BzrError): | 
| 427 | def __init__(self, rev_id, not_ancestor_id): | |
| 1185.1.14
by Robert Collins remove more duplicate merged hunks. Bad MERGE3, BAD. | 428 | msg = "Revision %s is not an ancestor of %s" % (not_ancestor_id, | 
| 429 | rev_id) | |
| 430 | BzrError.__init__(self, msg) | |
| 431 | self.rev_id = rev_id | |
| 432 | self.not_ancestor_id = not_ancestor_id | |
| 1185.1.12
by Robert Collins merge in lsdiff/filterdiff friendliness | 433 | |
| 434 | ||
| 974.1.30
by aaron.bentley at utoronto Changed copy_multi to permit failure and return a tuple, tested missing required revisions | 435 | class InstallFailed(BzrError): | 
| 436 | def __init__(self, revisions): | |
| 1185.1.14
by Robert Collins remove more duplicate merged hunks. Bad MERGE3, BAD. | 437 | msg = "Could not install revisions:\n%s" % " ,".join(revisions) | 
| 438 | 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 | 439 | self.revisions = revisions | 
| 1154
by Martin Pool - fix imports for moved errors | 440 | |
| 441 | ||
| 442 | class AmbiguousBase(BzrError): | |
| 443 | def __init__(self, bases): | |
| 444 | msg = "The correct base is unclear, becase %s are all equally close" %\ | |
| 445 | ", ".join(bases) | |
| 446 | BzrError.__init__(self, msg) | |
| 447 | self.bases = bases | |
| 448 | ||
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 449 | |
| 974.1.80
by Aaron Bentley Improved merge error handling and testing | 450 | class NoCommits(BzrError): | 
| 451 | def __init__(self, branch): | |
| 452 | msg = "Branch %s has no commits." % branch | |
| 453 | BzrError.__init__(self, msg) | |
| 1185.10.1
by Aaron Bentley Added --basis option to bzr branch | 454 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 455 | |
| 1185.10.1
by Aaron Bentley Added --basis option to bzr branch | 456 | class UnlistableStore(BzrError): | 
| 457 | def __init__(self, store): | |
| 458 | BzrError.__init__(self, "Store %s is not listable" % store) | |
| 459 | ||
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 460 | |
| 1587.1.6
by Robert Collins Update bound branch implementation to 0.8. | 461 | |
| 1185.10.1
by Aaron Bentley Added --basis option to bzr branch | 462 | class UnlistableBranch(BzrError): | 
| 463 | def __init__(self, br): | |
| 464 | BzrError.__init__(self, "Stores for branch %s are not listable" % br) | |
| 1392
by Robert Collins reinstate testfetch test case | 465 | |
| 466 | ||
| 1505.1.24
by John Arbash Meinel Updated commit to handle bound branches. Included test to handle commit after merge | 467 | class BoundBranchOutOfDate(BzrNewError): | 
| 468 | """Bound branch %(branch)s is out of date with master branch %(master)s.""" | |
| 469 | def __init__(self, branch, master): | |
| 470 | BzrNewError.__init__(self) | |
| 471 | self.branch = branch | |
| 472 | self.master = master | |
| 473 | ||
| 474 | ||
| 475 | class CommitToDoubleBoundBranch(BzrNewError): | |
| 476 | """Cannot commit to branch %(branch)s. It is bound to %(master)s, which is bound to %(remote)s.""" | |
| 477 | def __init__(self, branch, master, remote): | |
| 478 | BzrNewError.__init__(self) | |
| 479 | self.branch = branch | |
| 480 | self.master = master | |
| 481 | self.remote = remote | |
| 482 | ||
| 1505.1.25
by John Arbash Meinel Updated pull. Now all paths which call set_revision_history maintain the branch invariant. All tests pass. | 483 | |
| 484 | class OverwriteBoundBranch(BzrNewError): | |
| 485 | """Cannot pull --overwrite to a branch which is bound %(branch)s""" | |
| 486 | def __init__(self, branch): | |
| 487 | BzrNewError.__init__(self) | |
| 488 | self.branch = branch | |
| 489 | ||
| 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 | 490 | |
| 491 | class BoundBranchConnectionFailure(BzrNewError): | |
| 492 | """Unable to connect to target of bound branch %(branch)s => %(target)s: %(error)s""" | |
| 493 | def __init__(self, branch, target, error): | |
| 494 | BzrNewError.__init__(self) | |
| 495 | self.branch = branch | |
| 496 | self.target = target | |
| 497 | self.error = error | |
| 498 | ||
| 499 | ||
| 1185.16.116
by mbp at sourcefrog Move weave errors into bzrlib.errors and make consistent with new system. | 500 | class WeaveError(BzrNewError): | 
| 501 | """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. | 502 | |
| 1185.16.116
by mbp at sourcefrog Move weave errors into bzrlib.errors and make consistent with new system. | 503 | def __init__(self, message=None): | 
| 504 | BzrNewError.__init__(self) | |
| 505 | self.message = message | |
| 506 | ||
| 507 | ||
| 508 | class WeaveRevisionAlreadyPresent(WeaveError): | |
| 509 | """Revision {%(revision_id)s} already present in %(weave)s""" | |
| 510 | 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. | 511 | |
| 1185.16.116
by mbp at sourcefrog Move weave errors into bzrlib.errors and make consistent with new system. | 512 | WeaveError.__init__(self) | 
| 513 | self.revision_id = revision_id | |
| 514 | self.weave = weave | |
| 515 | ||
| 516 | ||
| 517 | class WeaveRevisionNotPresent(WeaveError): | |
| 518 | """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. | 519 | |
| 1185.16.116
by mbp at sourcefrog Move weave errors into bzrlib.errors and make consistent with new system. | 520 | def __init__(self, revision_id, weave): | 
| 521 | WeaveError.__init__(self) | |
| 522 | self.revision_id = revision_id | |
| 523 | self.weave = weave | |
| 524 | ||
| 525 | ||
| 526 | class WeaveFormatError(WeaveError): | |
| 527 | """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. | 528 | |
| 1185.16.116
by mbp at sourcefrog Move weave errors into bzrlib.errors and make consistent with new system. | 529 | def __init__(self, what): | 
| 530 | WeaveError.__init__(self) | |
| 531 | self.what = what | |
| 532 | ||
| 533 | ||
| 534 | class WeaveParentMismatch(WeaveError): | |
| 535 | """Parents are mismatched between two revisions.""" | |
| 536 | ||
| 1393.2.1
by John Arbash Meinel Merged in split-storage-2 branch. Need to cleanup a little bit more still. | 537 | |
| 1185.50.23
by John Arbash Meinel Adding sha1 check when weave extracts a text. | 538 | class WeaveInvalidChecksum(WeaveError): | 
| 539 | """Text did not match it's checksum: %(message)s""" | |
| 540 | ||
| 541 | ||
| 1551.3.11
by Aaron Bentley Merge from Robert | 542 | class WeaveTextDiffers(WeaveError): | 
| 543 | """Weaves differ on text content. Revision: {%(revision_id)s}, %(weave_a)s, %(weave_b)s""" | |
| 544 | ||
| 545 | def __init__(self, revision_id, weave_a, weave_b): | |
| 546 | WeaveError.__init__(self) | |
| 547 | self.revision_id = revision_id | |
| 548 | self.weave_a = weave_a | |
| 549 | self.weave_b = weave_b | |
| 550 | ||
| 551 | ||
| 1534.7.158
by Aaron Bentley Merged John Meinel's integration | 552 | class WeaveTextDiffers(WeaveError): | 
| 553 | """Weaves differ on text content. Revision: {%(revision_id)s}, %(weave_a)s, %(weave_b)s""" | |
| 554 | ||
| 555 | def __init__(self, revision_id, weave_a, weave_b): | |
| 556 | WeaveError.__init__(self) | |
| 557 | self.revision_id = revision_id | |
| 558 | self.weave_a = weave_a | |
| 559 | self.weave_b = weave_b | |
| 560 | ||
| 561 | ||
| 1563.2.1
by Robert Collins Merge in a variation of the versionedfile api from versioned-file. | 562 | class VersionedFileError(BzrNewError): | 
| 563 | """Versioned file error.""" | |
| 564 | ||
| 565 | ||
| 566 | class RevisionNotPresent(VersionedFileError): | |
| 567 | """Revision {%(revision_id)s} not present in %(file_id)s.""" | |
| 568 | ||
| 569 | def __init__(self, revision_id, file_id): | |
| 570 | VersionedFileError.__init__(self) | |
| 571 | self.revision_id = revision_id | |
| 572 | self.file_id = file_id | |
| 573 | ||
| 574 | ||
| 575 | class RevisionAlreadyPresent(VersionedFileError): | |
| 576 | """Revision {%(revision_id)s} already present in %(file_id)s.""" | |
| 577 | ||
| 578 | def __init__(self, revision_id, file_id): | |
| 579 | VersionedFileError.__init__(self) | |
| 580 | self.revision_id = revision_id | |
| 581 | self.file_id = file_id | |
| 582 | ||
| 583 | ||
| 584 | class KnitError(BzrNewError): | |
| 585 | """Knit error""" | |
| 586 | ||
| 587 | ||
| 588 | class KnitHeaderError(KnitError): | |
| 589 | """Knit header error: %(badline)r unexpected""" | |
| 590 | ||
| 591 | def __init__(self, badline): | |
| 592 | KnitError.__init__(self) | |
| 593 | self.badline = badline | |
| 594 | ||
| 595 | ||
| 596 | class KnitCorrupt(KnitError): | |
| 597 | """Knit %(filename)s corrupt: %(how)s""" | |
| 598 | ||
| 599 | def __init__(self, filename, how): | |
| 600 | KnitError.__init__(self) | |
| 601 | self.filename = filename | |
| 602 | self.how = how | |
| 603 | ||
| 604 | ||
| 1185.31.12
by John Arbash Meinel Refactored the export code to make it easier to add new export formats. | 605 | class NoSuchExportFormat(BzrNewError): | 
| 606 | """Export format %(format)r not supported""" | |
| 607 | def __init__(self, format): | |
| 608 | BzrNewError.__init__(self) | |
| 609 | self.format = format | |
| 610 | ||
| 611 | ||
| 1185.11.9
by John Arbash Meinel Most tests pass, some problems with unavailable socket recv | 612 | class TransportError(BzrError): | 
| 613 | """All errors thrown by Transport implementations should derive | |
| 614 |     from this class.
 | |
| 615 |     """
 | |
| 616 | def __init__(self, msg=None, orig_error=None): | |
| 617 | if msg is None and orig_error is not None: | |
| 618 | msg = str(orig_error) | |
| 619 | BzrError.__init__(self, msg) | |
| 620 | self.msg = msg | |
| 621 | self.orig_error = orig_error | |
| 622 | ||
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 623 | |
| 1185.11.9
by John Arbash Meinel Most tests pass, some problems with unavailable socket recv | 624 | # A set of semi-meaningful errors which can be thrown
 | 
| 625 | class TransportNotPossible(TransportError): | |
| 626 | """This is for transports where a specific function is explicitly not | |
| 627 |     possible. Such as pushing files to an HTTP server.
 | |
| 628 |     """
 | |
| 629 |     pass
 | |
| 630 | ||
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 631 | |
| 632 | class ConnectionError(TransportError): | |
| 633 | """A connection problem prevents file retrieval. | |
| 1185.35.31
by Aaron Bentley Throw ConnectionError instead of NoSuchFile except when we get a 404 | 634 |     This does not indicate whether the file exists or not; it indicates that a
 | 
| 635 |     precondition for requesting the file was not met.
 | |
| 636 |     """
 | |
| 1185.31.44
by John Arbash Meinel Cleaned up Exceptions for all transports. | 637 | def __init__(self, msg=None, orig_error=None): | 
| 638 | TransportError.__init__(self, msg=msg, orig_error=orig_error) | |
| 639 | ||
| 1185.11.9
by John Arbash Meinel Most tests pass, some problems with unavailable socket recv | 640 | |
| 641 | class ConnectionReset(TransportError): | |
| 642 | """The connection has been closed.""" | |
| 643 |     pass
 | |
| 644 | ||
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 645 | |
| 1185.14.10
by Aaron Bentley Commit aborts with conflicts in the tree. | 646 | class ConflictsInTree(BzrError): | 
| 647 | def __init__(self): | |
| 648 | BzrError.__init__(self, "Working tree has conflicts.") | |
| 1185.12.49
by Aaron Bentley Switched to ConfigObj | 649 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 650 | |
| 1185.12.49
by Aaron Bentley Switched to ConfigObj | 651 | class ParseConfigError(BzrError): | 
| 652 | def __init__(self, errors, filename): | |
| 653 | if filename is None: | |
| 654 | filename = "" | |
| 655 | message = "Error(s) parsing config file %s:\n%s" % \ | |
| 656 | (filename, ('\n'.join(e.message for e in errors))) | |
| 657 | BzrError.__init__(self, message) | |
| 1185.12.52
by Aaron Bentley Merged more config stuff from Robert | 658 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 659 | |
| 1442.1.58
by Robert Collins gpg signing of content | 660 | class SigningFailed(BzrError): | 
| 661 | def __init__(self, command_line): | |
| 662 | BzrError.__init__(self, "Failed to gpg sign data with command '%s'" | |
| 663 | % command_line) | |
| 1185.12.83
by Aaron Bentley Preliminary weave merge support | 664 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 665 | |
| 1185.12.83
by Aaron Bentley Preliminary weave merge support | 666 | class WorkingTreeNotRevision(BzrError): | 
| 667 | def __init__(self, tree): | |
| 668 | BzrError.__init__(self, "The working tree for %s has changed since" | |
| 669 |                           " last commit, but weave merge requires that it be"
 | |
| 670 | " unchanged." % tree.basedir) | |
| 1185.12.104
by Aaron Bentley Merged Martin's latest | 671 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 672 | |
| 1185.24.1
by Aaron Bentley Got reprocessing working | 673 | class CantReprocessAndShowBase(BzrNewError): | 
| 674 | """Can't reprocess and show base. | |
| 675 | Reprocessing obscures relationship of conflicting lines to base."""
 | |
| 1185.24.2
by Aaron Bentley Merge from mainline | 676 | |
| 1551.2.1
by Aaron Bentley recommit 1527 PEP8 fixes | 677 | |
| 1185.16.114
by mbp at sourcefrog Improved topological sort | 678 | class GraphCycleError(BzrNewError): | 
| 679 | """Cycle in graph %(graph)r""" | |
| 680 | def __init__(self, graph): | |
| 681 | BzrNewError.__init__(self) | |
| 682 | self.graph = graph | |
| 1185.35.1
by Aaron Bentley Implemented conflicts.restore | 683 | |
| 1505.1.23
by John Arbash Meinel Whitespace cleanup of bzrlib.errors | 684 | |
| 1185.35.1
by Aaron Bentley Implemented conflicts.restore | 685 | class NotConflicted(BzrNewError): | 
| 1185.35.4
by Aaron Bentley Implemented remerge | 686 | """File %(filename)s is not conflicted.""" | 
| 1534.3.1
by Robert Collins * bzrlib.osutils.safe_unicode now exists to provide parameter coercion | 687 | |
| 1185.35.1
by Aaron Bentley Implemented conflicts.restore | 688 | def __init__(self, filename): | 
| 689 | BzrNewError.__init__(self) | |
| 690 | self.filename = filename | |
| 1185.35.13
by Aaron Bentley Merged Martin | 691 | |
| 1505.1.23
by John Arbash Meinel Whitespace cleanup of bzrlib.errors | 692 | |
| 1492
by Robert Collins Support decoration of commands. | 693 | class MustUseDecorated(Exception): | 
| 694 | """A decorating function has requested its original command be used. | |
| 695 |     
 | |
| 696 |     This should never escape bzr, so does not need to be printable.
 | |
| 697 |     """
 | |
| 698 | ||
| 1505.1.23
by John Arbash Meinel Whitespace cleanup of bzrlib.errors | 699 | |
| 1185.35.42
by Aaron Bentley Fixed fetch to be safer wrt ghosts and corrupt branches | 700 | class MissingText(BzrNewError): | 
| 701 | """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 | 702 | |
| 1185.35.42
by Aaron Bentley Fixed fetch to be safer wrt ghosts and corrupt branches | 703 | def __init__(self, branch, text_revision, file_id): | 
| 1534.3.1
by Robert Collins * bzrlib.osutils.safe_unicode now exists to provide parameter coercion | 704 | BzrNewError.__init__(self) | 
| 1185.35.42
by Aaron Bentley Fixed fetch to be safer wrt ghosts and corrupt branches | 705 | self.branch = branch | 
| 706 | self.base = branch.base | |
| 707 | self.text_revision = text_revision | |
| 708 | self.file_id = file_id | |
| 1534.7.5
by Aaron Bentley Got unique_add under test | 709 | |
| 1505.1.23
by John Arbash Meinel Whitespace cleanup of bzrlib.errors | 710 | |
| 1534.7.5
by Aaron Bentley Got unique_add under test | 711 | class DuplicateKey(BzrNewError): | 
| 712 | """Key %(key)s is already present in map""" | |
| 1534.7.6
by Aaron Bentley Added conflict handling | 713 | |
| 1587.1.6
by Robert Collins Update bound branch implementation to 0.8. | 714 | |
| 1534.7.6
by Aaron Bentley Added conflict handling | 715 | class MalformedTransform(BzrNewError): | 
| 1534.7.49
by Aaron Bentley Printed conflicts in MalformedTransform | 716 | """Tree transform is malformed %(conflicts)r""" | 
| 1534.7.24
by Aaron Bentley Merge from the mainline | 717 | |
| 1534.3.1
by Robert Collins * bzrlib.osutils.safe_unicode now exists to provide parameter coercion | 718 | |
| 719 | class BzrBadParameter(BzrNewError): | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 720 | """A bad parameter : %(param)s is not usable. | 
| 1534.3.1
by Robert Collins * bzrlib.osutils.safe_unicode now exists to provide parameter coercion | 721 |     
 | 
| 1185.65.29
by Robert Collins Implement final review suggestions. | 722 |     This exception should never be thrown, but it is a base class for all
 | 
| 723 |     parameter-to-function errors.
 | |
| 724 |     """
 | |
| 1534.3.1
by Robert Collins * bzrlib.osutils.safe_unicode now exists to provide parameter coercion | 725 | def __init__(self, param): | 
| 726 | BzrNewError.__init__(self) | |
| 727 | self.param = param | |
| 1534.7.32
by Aaron Bentley Got conflict handling working when conflicts involve existing files | 728 | |
| 1534.4.3
by Robert Collins Implement BranchTestProviderAdapter, so tests now run across all branch formats. | 729 | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 730 | class BzrBadParameterNotUnicode(BzrBadParameter): | 
| 731 | """Parameter %(param)s is neither unicode nor utf8.""" | |
| 1534.7.120
by Aaron Bentley PEP8 fixes | 732 | |
| 733 | ||
| 1534.7.32
by Aaron Bentley Got conflict handling working when conflicts involve existing files | 734 | class ReusingTransform(BzrNewError): | 
| 735 | """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 | 736 | |
| 1534.7.120
by Aaron Bentley PEP8 fixes | 737 | |
| 1534.7.66
by Aaron Bentley Ensured we don't accidentally move the root directory | 738 | class CantMoveRoot(BzrNewError): | 
| 739 | """Moving the root directory is not supported at this time""" | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 740 | |
| 1534.7.120
by Aaron Bentley PEP8 fixes | 741 | |
| 1185.65.29
by Robert Collins Implement final review suggestions. | 742 | class BzrBadParameterNotString(BzrBadParameter): | 
| 743 | """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. | 744 | |
| 745 | ||
| 1534.4.44
by Robert Collins Make a new BzrDir format that uses a versioned branch format in a branch/ subdirectory. | 746 | class BzrBadParameterMissing(BzrBadParameter): | 
| 747 | """Parameter $(param)s is required but not present.""" | |
| 748 | ||
| 749 | ||
| 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. | 750 | class DependencyNotPresent(BzrNewError): | 
| 1540.3.7
by Martin Pool Prepare to select a transport depending on what dependencies can be satisfied. | 751 | """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. | 752 | |
| 753 | def __init__(self, library, error): | |
| 754 | BzrNewError.__init__(self, library=library, error=error) | |
| 755 | ||
| 756 | ||
| 757 | class ParamikoNotPresent(DependencyNotPresent): | |
| 758 | """Unable to import paramiko (required for sftp support): %(error)s""" | |
| 759 | ||
| 760 | def __init__(self, error): | |
| 761 | DependencyNotPresent.__init__(self, 'paramiko', error) | |
| 762 | ||
| 763 | ||
| 1534.4.3
by Robert Collins Implement BranchTestProviderAdapter, so tests now run across all branch formats. | 764 | class UninitializableFormat(BzrNewError): | 
| 765 | """Format %(format)s cannot be initialised by this version of bzr.""" | |
| 766 | ||
| 767 | def __init__(self, format): | |
| 768 | BzrNewError.__init__(self) | |
| 769 | self.format = format | |
| 1551.3.4
by Aaron Bentley Implemented default command options | 770 | |
| 1534.7.156
by Aaron Bentley PEP8 fixes | 771 | |
| 1534.7.130
by Aaron Bentley More conflict handling, test porting | 772 | class NoDiff3(BzrNewError): | 
| 773 | """Diff3 is not installed on this machine.""" | |
| 1534.7.162
by Aaron Bentley Handle failures creating/deleting the Limbo directory | 774 | |
| 775 | ||
| 776 | class ExistingLimbo(BzrNewError): | |
| 777 | """This tree contains left-over files from a failed operation. | |
| 778 |     Please examine %(limbo_dir)s to see if it contains any files you wish to
 | |
| 779 |     keep, and delete it when you are done.
 | |
| 780 |     """
 | |
| 781 | def __init__(self, limbo_dir): | |
| 782 | BzrNewError.__init__(self) | |
| 783 | self.limbo_dir = limbo_dir | |
| 784 | ||
| 785 | ||
| 786 | class ImmortalLimbo(BzrNewError): | |
| 787 | """Unable to delete transform temporary directory $(limbo_dir)s. | |
| 788 |     Please examine %(limbo_dir)s to see if it contains any files you wish to
 | |
| 789 |     keep, and delete it when you are done.
 | |
| 790 |     """
 | |
| 791 | def __init__(self, limbo_dir): | |
| 792 | BzrNewError.__init__(self) | |
| 793 | self.limbo_dir = limbo_dir | |
| 1534.7.163
by Aaron Bentley Merge from Robert [Fails tests] | 794 | |
| 795 | ||
| 1508.1.22
by Robert Collins implement out of date working tree checks in commit. | 796 | class OutOfDateTree(BzrNewError): | 
| 797 | """Working tree is out of date, please run 'bzr update'.""" | |
| 1508.1.25
by Robert Collins Update per review comments. | 798 | |
| 799 | def __init__(self, tree): | |
| 800 | BzrNewError.__init__(self) | |
| 801 | self.tree = tree | |
| 1534.7.196
by Aaron Bentley Switched to Rio format for merge-modified list | 802 | |
| 1563.2.22
by Robert Collins Move responsibility for repository.has_revision into RevisionStore | 803 | |
| 1534.7.196
by Aaron Bentley Switched to Rio format for merge-modified list | 804 | class MergeModifiedFormatError(BzrNewError): | 
| 805 | """Error in merge modified format""" | |
| 1534.7.200
by Aaron Bentley Merge from mainline | 806 | |
| 807 | ||
| 1534.10.7
by Aaron Bentley Added tests for bad conflict lists | 808 | class ConflictFormatError(BzrNewError): | 
| 809 | """Format error in conflict listings""" | |
| 810 | ||
| 811 | ||
| 1570.1.13
by Robert Collins Check for incorrect revision parentage in the weave during revision access. | 812 | class CorruptRepository(BzrNewError): | 
| 813 | """An error has been detected in the repository %(repo_path)s. | |
| 814 | Please run bzr reconcile on this repository."""
 | |
| 815 | ||
| 816 | def __init__(self, repo): | |
| 817 | BzrNewError.__init__(self) | |
| 818 | self.repo_path = repo.bzrdir.root_transport.base | |
| 1587.1.6
by Robert Collins Update bound branch implementation to 0.8. | 819 | |
| 820 | ||
| 821 | class UpgradeRequired(BzrNewError): | |
| 822 | """To use this feature you must upgrade your branch at %(path)s.""" | |
| 823 | ||
| 824 | def __init__(self, path): | |
| 825 | BzrNewError.__init__(self) | |
| 826 | self.path = path | |
| 827 | ||
| 1587.1.8
by Robert Collins Local commits on unbound branches fail. | 828 | |
| 829 | class LocalRequiresBoundBranch(BzrNewError): | |
| 830 | """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. | 831 | |
| 832 | ||
| 833 | class MissingProgressBarFinish(BzrNewError): | |
| 834 | """A nested progress bar was not 'finished' correctly.""" | |
| 1534.10.8
by Aaron Bentley Implemented conflict_lines in terms of old system on WorkingTree | 835 | |
| 836 | ||
| 837 | class UnsupportedOperation(BzrNewError): | |
| 838 | """The method %(mname)s is not supported on objects of type %(tname)s.""" | |
| 839 | def __init__(self, method, method_self): | |
| 840 | self.method = method | |
| 841 | self.mname = method.__name__ | |
| 842 | self.tname = type(method_self).__name__ |