13
13
# You should have received a copy of the GNU General Public License
14
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
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
17
"""Exceptions for bzr, and reporting of them.
21
20
from bzrlib import (
73
72
arguments can be given. The first is for generic "user" errors which
74
73
are not intended to be caught and so do not need a specific subclass.
75
74
The second case is for use with subclasses that provide a _fmt format
76
string to print the arguments.
75
string to print the arguments.
78
Keyword arguments are taken as parameters to the error, which can
79
be inserted into the format string template. It's recommended
80
that subclasses override the __init__ method to require specific
77
Keyword arguments are taken as parameters to the error, which can
78
be inserted into the format string template. It's recommended
79
that subclasses override the __init__ method to require specific
83
82
:param msg: If given, this is the literal complete text for the error,
84
not subject to expansion.
83
not subject to expansion. 'msg' is used instead of 'message' because
84
python evolved and, in 2.6, forbids the use of 'message'.
86
86
StandardError.__init__(self)
87
87
if msg is not None:
486
486
# XXX: Should be unified with TransportError; they seem to represent the
488
488
# RBC 20060929: I think that unifiying with TransportError would be a mistake
489
# - this is finer than a TransportError - and more useful as such. It
489
# - this is finer than a TransportError - and more useful as such. It
490
490
# differentiates between 'transport has failed' and 'operation on a transport
492
492
class PathError(BzrError):
494
494
_fmt = "Generic path error: %(path)r%(extra)s)"
496
496
def __init__(self, path, extra=None):
1226
1238
not_ancestor_id=not_ancestor_id)
1229
class InstallFailed(BzrError):
1231
def __init__(self, revisions):
1232
revision_str = ", ".join(str(r) for r in revisions)
1233
msg = "Could not install revisions:\n%s" % revision_str
1234
BzrError.__init__(self, msg)
1235
self.revisions = revisions
1238
1241
class AmbiguousBase(BzrError):
1240
1243
def __init__(self, bases):
1432
class SHA1KnitCorrupt(KnitCorrupt):
1434
_fmt = ("Knit %(filename)s corrupt: sha-1 of reconstructed text does not "
1435
"match expected sha-1. key %(key)s expected sha %(expected)s actual "
1438
def __init__(self, filename, actual, expected, key, content):
1439
KnitError.__init__(self)
1440
self.filename = filename
1441
self.actual = actual
1442
self.expected = expected
1444
self.content = content
1429
1447
class KnitDataStreamIncompatible(KnitError):
1430
1448
# Not raised anymore, as we can convert data streams. In future we may
1431
1449
# need it again for more exotic cases, so we're keeping it around for now.
1470
1488
self.options = options
1491
class RetryWithNewPacks(BzrError):
1492
"""Raised when we realize that the packs on disk have changed.
1494
This is meant as more of a signaling exception, to trap between where a
1495
local error occurred and the code that can actually handle the error and
1496
code that can retry appropriately.
1499
internal_error = True
1501
_fmt = ("Pack files have changed, reload and retry. context: %(context)s"
1504
def __init__(self, context, reload_occurred, exc_info):
1505
"""create a new RetryWithNewPacks error.
1507
:param reload_occurred: Set to True if we know that the packs have
1508
already been reloaded, and we are failing because of an in-memory
1509
cache miss. If set to True then we will ignore if a reload says
1510
nothing has changed, because we assume it has already reloaded. If
1511
False, then a reload with nothing changed will force an error.
1512
:param exc_info: The original exception traceback, so if there is a
1513
problem we can raise the original error (value from sys.exc_info())
1515
BzrError.__init__(self)
1516
self.reload_occurred = reload_occurred
1517
self.exc_info = exc_info
1518
self.orig_error = exc_info[1]
1519
# TODO: The global error handler should probably treat this by
1520
# raising/printing the original exception with a bit about
1521
# RetryWithNewPacks also not being caught
1524
class RetryAutopack(RetryWithNewPacks):
1525
"""Raised when we are autopacking and we find a missing file.
1527
Meant as a signaling exception, to tell the autopack code it should try
1531
internal_error = True
1533
_fmt = ("Pack files have changed, reload and try autopack again."
1534
" context: %(context)s %(orig_error)s")
1473
1537
class NoSuchExportFormat(BzrError):
1475
1539
_fmt = "Export format %(format)r not supported"
1477
1541
def __init__(self, format):
1532
1596
class SmartMessageHandlerError(InternalBzrError):
1534
_fmt = "The message handler raised an exception: %(exc_value)s."
1598
_fmt = ("The message handler raised an exception:\n"
1599
"%(traceback_text)s")
1536
1601
def __init__(self, exc_info):
1537
self.exc_type, self.exc_value, self.tb = exc_info
1603
self.exc_type, self.exc_value, self.exc_tb = exc_info
1604
self.exc_info = exc_info
1605
traceback_strings = traceback.format_exception(
1606
self.exc_type, self.exc_value, self.exc_tb)
1607
self.traceback_text = ''.join(traceback_strings)
1540
1610
# A set of semi-meaningful errors which can be thrown
1541
1611
class TransportNotPossible(TransportError):
1614
1686
_fmt = '%(source)s is%(permanently)s redirected to %(target)s'
1616
def __init__(self, source, target, is_permanent=False, qual_proto=None):
1688
def __init__(self, source, target, is_permanent=False):
1617
1689
self.source = source
1618
1690
self.target = target
1619
1691
if is_permanent:
1620
1692
self.permanently = ' permanently'
1622
1694
self.permanently = ''
1623
self._qualified_proto = qual_proto
1624
1695
TransportError.__init__(self)
1626
def _requalify_url(self, url):
1627
"""Restore the qualified proto in front of the url"""
1628
# When this exception is raised, source and target are in
1629
# user readable format. But some transports may use a
1630
# different proto (http+urllib:// will present http:// to
1631
# the user. If a qualified proto is specified, the code
1632
# trapping the exception can get the qualified urls to
1633
# properly handle the redirection themself (creating a
1634
# new transport object from the target url for example).
1635
# But checking that the scheme of the original and
1636
# redirected urls are the same can be tricky. (see the
1637
# FIXME in BzrDir.open_from_transport for the unique use
1639
if self._qualified_proto is None:
1642
# The TODO related to NotBranchError mention that doing
1643
# that kind of manipulation on the urls may not be the
1644
# exception object job. On the other hand, this object is
1645
# the interface between the code and the user so
1646
# presenting the urls in different ways is indeed its
1649
proto, netloc, path, query, fragment = urlparse.urlsplit(url)
1650
return urlparse.urlunsplit((self._qualified_proto, netloc, path,
1653
def get_source_url(self):
1654
return self._requalify_url(self.source)
1656
def get_target_url(self):
1657
return self._requalify_url(self.target)
1660
1698
class TooManyRedirections(TransportError):
1968
2007
class BadConversionTarget(BzrError):
1970
_fmt = "Cannot convert to format %(format)s. %(problem)s"
2009
_fmt = "Cannot convert from format %(from_format)s to format %(format)s." \
1972
def __init__(self, problem, format):
2012
def __init__(self, problem, format, from_format=None):
1973
2013
BzrError.__init__(self)
1974
2014
self.problem = problem
1975
2015
self.format = format
2016
self.from_format = from_format or '(unspecified)'
1978
2019
class NoDiffFound(BzrError):
2132
2190
_fmt = "To use this feature you must upgrade your repository at %(path)s."
2193
class RichRootUpgradeRequired(UpgradeRequired):
2195
_fmt = ("To use this feature you must upgrade your branch at %(path)s to"
2196
" a format which supports rich roots.")
2135
2199
class LocalRequiresBoundBranch(BzrError):
2137
2201
_fmt = "Cannot perform local-only commits on unbound branches."
2140
class MissingProgressBarFinish(BzrError):
2142
_fmt = "A nested progress bar was not 'finished' correctly."
2145
class InvalidProgressBarType(BzrError):
2147
_fmt = ("Environment variable BZR_PROGRESS_BAR='%(bar_type)s"
2148
" is not a supported type Select one of: %(valid_types)s")
2150
def __init__(self, bar_type, valid_types):
2151
BzrError.__init__(self, bar_type=bar_type, valid_types=valid_types)
2154
2204
class UnsupportedOperation(BzrError):
2156
2206
_fmt = ("The method %(mname)s is not supported on"
2216
2266
self.text = text
2219
class MalformedHeader(BadBundle):
2269
class MalformedHeader(BadBundle):
2221
2271
_fmt = "Malformed bzr revision-bundle header: %(text)r"
2224
class MalformedPatches(BadBundle):
2274
class MalformedPatches(BadBundle):
2226
2276
_fmt = "Malformed patches in bzr revision-bundle: %(text)r"
2229
class MalformedFooter(BadBundle):
2279
class MalformedFooter(BadBundle):
2231
2281
_fmt = "Malformed footer in bzr revision-bundle: %(text)r"
2234
2284
class UnsupportedEOLMarker(BadBundle):
2236
_fmt = "End of line marker was not \\n in bzr revision-bundle"
2286
_fmt = "End of line marker was not \\n in bzr revision-bundle"
2238
2288
def __init__(self):
2239
# XXX: BadBundle's constructor assumes there's explanatory text,
2289
# XXX: BadBundle's constructor assumes there's explanatory text,
2240
2290
# but for this there is not
2241
2291
BzrError.__init__(self)
2244
2294
class IncompatibleBundleFormat(BzrError):
2246
2296
_fmt = "Bundle format %(bundle_format)s is incompatible with %(other)s"
2248
2298
def __init__(self, bundle_format, other):
2499
2541
self.branch = branch
2544
class InvalidLineInBugsProperty(BzrError):
2546
_fmt = ("Invalid line in bugs property: '%(line)s'")
2548
def __init__(self, line):
2552
class InvalidBugStatus(BzrError):
2554
_fmt = ("Invalid bug status: '%(status)s'")
2556
def __init__(self, status):
2557
self.status = status
2502
2560
class UnexpectedSmartServerResponse(BzrError):
2504
2562
_fmt = "Could not understand response from smart server: %(response_tuple)r"
2728
2798
class UncommittedChanges(BzrError):
2730
_fmt = 'Working tree "%(display_url)s" has uncommitted changes.'
2800
_fmt = ('Working tree "%(display_url)s" has uncommitted changes'
2801
' (See bzr status).%(more)s')
2732
def __init__(self, tree):
2803
def __init__(self, tree, more=None):
2733
2808
import bzrlib.urlutils as urlutils
2734
2809
display_url = urlutils.unescape_for_display(
2735
2810
tree.bzrdir.root_transport.base, 'ascii')
2736
BzrError.__init__(self, tree=tree, display_url=display_url)
2811
BzrError.__init__(self, tree=tree, display_url=display_url, more=more)
2739
2814
class MissingTemplateVariable(BzrError):
2776
2851
class CommandAvailableInPlugin(StandardError):
2778
2853
internal_error = False
2780
2855
def __init__(self, cmd_name, plugin_metadata, provider):
2782
2857
self.plugin_metadata = plugin_metadata
2783
2858
self.cmd_name = cmd_name
2784
2859
self.provider = provider
2786
2861
def __str__(self):
2788
_fmt = ('"%s" is not a standard bzr command. \n'
2863
_fmt = ('"%s" is not a standard bzr command. \n'
2789
2864
'However, the following official plugin provides this command: %s\n'
2790
2865
'You can install it by going to: %s'
2791
% (self.cmd_name, self.plugin_metadata['name'],
2866
% (self.cmd_name, self.plugin_metadata['name'],
2792
2867
self.plugin_metadata['url']))
2797
2872
class NoPluginAvailable(BzrError):
2801
class NotATerminal(BzrError):
2803
_fmt = 'Unable to ask for a password without real terminal.'
2806
2876
class UnableEncodePath(BzrError):
2849
2920
_fmt = 'Cannot bind address "%(host)s:%(port)i": %(orig_error)s.'
2851
2922
def __init__(self, host, port, orig_error):
2923
# nb: in python2.4 socket.error doesn't have a useful repr
2852
2924
BzrError.__init__(self, host=host, port=port,
2853
orig_error=orig_error[1])
2925
orig_error=repr(orig_error.args))
2856
2928
class UnknownRules(BzrError):
2884
2956
"""A pre_change_branch_tip hook function may raise this to cleanly and
2885
2957
explicitly abort a change to a branch tip.
2888
2960
_fmt = u"Tip change rejected: %(msg)s"
2890
2962
def __init__(self, msg):
2966
class ShelfCorrupt(BzrError):
2968
_fmt = "Shelf corrupt."
2971
class NoSuchShelfId(BzrError):
2973
_fmt = 'No changes are shelved with id "%(shelf_id)d".'
2975
def __init__(self, shelf_id):
2976
BzrError.__init__(self, shelf_id=shelf_id)
2979
class InvalidShelfId(BzrError):
2981
_fmt = '"%(invalid_id)s" is not a valid shelf id, try a number instead.'
2983
def __init__(self, invalid_id):
2984
BzrError.__init__(self, invalid_id=invalid_id)
2987
class JailBreak(BzrError):
2989
_fmt = "An attempt to access a url outside the server jail was made: '%(url)s'."
2991
def __init__(self, url):
2992
BzrError.__init__(self, url=url)
2995
class UserAbort(BzrError):
2997
_fmt = 'The user aborted the operation.'
3000
class MustHaveWorkingTree(BzrError):
3002
_fmt = ("Branching '%(url)s'(%(format)s) must create a working tree.")
3004
def __init__(self, format, url):
3005
BzrError.__init__(self, format=format, url=url)
3008
class NoSuchView(BzrError):
3009
"""A view does not exist.
3012
_fmt = u"No such view: %(view_name)s."
3014
def __init__(self, view_name):
3015
self.view_name = view_name
3018
class ViewsNotSupported(BzrError):
3019
"""Views are not supported by a tree format.
3022
_fmt = ("Views are not supported by %(tree)s;"
3023
" use 'bzr upgrade' to change your tree to a later format.")
3025
def __init__(self, tree):
3029
class FileOutsideView(BzrError):
3031
_fmt = ('Specified file "%(file_name)s" is outside the current view: '
3034
def __init__(self, file_name, view_files):
3035
self.file_name = file_name
3036
self.view_str = ", ".join(view_files)
3039
class UnresumableWriteGroup(BzrError):
3041
_fmt = ("Repository %(repository)s cannot resume write group "
3042
"%(write_groups)r: %(reason)s")
3044
internal_error = True
3046
def __init__(self, repository, write_groups, reason):
3047
self.repository = repository
3048
self.write_groups = write_groups
3049
self.reason = reason
3052
class UnsuspendableWriteGroup(BzrError):
3054
_fmt = ("Repository %(repository)s cannot suspend a write group.")
3056
internal_error = True
3058
def __init__(self, repository):
3059
self.repository = repository
3062
class LossyPushToSameVCS(BzrError):
3064
_fmt = ("Lossy push not possible between %(source_branch)r and "
3065
"%(target_branch)r that are in the same VCS.")
3067
internal_error = True
3069
def __init__(self, source_branch, target_branch):
3070
self.source_branch = source_branch
3071
self.target_branch = target_branch