1
# Copyright (C) 2005, 2006, 2007, 2008 Canonical Ltd
1
# Copyright (C) 2005-2010 Canonical Ltd
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
639
class UnstackableLocationError(BzrError):
641
_fmt = "The branch '%(branch_url)s' cannot be stacked on '%(target_url)s'."
643
def __init__(self, branch_url, target_url):
644
BzrError.__init__(self)
645
self.branch_url = branch_url
646
self.target_url = target_url
639
649
class UnstackableRepositoryFormat(BzrError):
641
651
_fmt = ("The repository '%(url)s'(%(format)s) is not a stackable format. "
692
702
# TODO: Probably this behavior of should be a common superclass
693
703
class NotBranchError(PathError):
695
_fmt = 'Not a branch: "%(path)s".'
705
_fmt = 'Not a branch: "%(path)s"%(detail)s.'
697
def __init__(self, path):
707
def __init__(self, path, detail=None, bzrdir=None):
698
708
import bzrlib.urlutils as urlutils
699
self.path = urlutils.unescape_for_display(path, 'ascii')
709
path = urlutils.unescape_for_display(path, 'ascii')
710
if detail is not None:
711
detail = ': ' + detail
714
PathError.__init__(self, path=path)
717
# XXX: Ideally self.detail would be a property, but Exceptions in
718
# Python 2.4 have to be old-style classes so properties don't work.
719
# Instead we override _format.
720
if self.detail is None:
721
if self.bzrdir is not None:
723
self.bzrdir.open_repository()
724
except NoRepositoryPresent:
727
self.detail = ': location is a repository'
730
return PathError._format(self)
702
733
class NoSubmitBranch(PathError):
785
816
class IncompatibleRepositories(BzrError):
817
"""Report an error that two repositories are not compatible.
819
Note that the source and target repositories are permitted to be strings:
820
this exception is thrown from the smart server and may refer to a
821
repository the client hasn't opened.
787
824
_fmt = "%(target)s\n" \
788
825
"is not compatible with\n" \
1143
1180
class InvalidRevisionSpec(BzrError):
1145
_fmt = ("Requested revision: %(spec)r does not exist in branch:"
1182
_fmt = ("Requested revision: '%(spec)s' does not exist in branch:"
1146
1183
" %(branch)s%(extra)s")
1148
1185
def __init__(self, spec, branch, extra=None):
1173
1210
class DivergedBranches(BzrError):
1175
1212
_fmt = ("These branches have diverged."
1176
" Use the merge command to reconcile them.")
1213
" Use the missing command to see how.\n"
1214
"Use the merge command to reconcile them.")
1178
1216
def __init__(self, branch1, branch2):
1179
1217
self.branch1 = branch1
1227
1265
not_ancestor_id=not_ancestor_id)
1230
class InstallFailed(BzrError):
1232
def __init__(self, revisions):
1233
revision_str = ", ".join(str(r) for r in revisions)
1234
msg = "Could not install revisions:\n%s" % revision_str
1235
BzrError.__init__(self, msg)
1236
self.revisions = revisions
1239
1268
class AmbiguousBase(BzrError):
1241
1270
def __init__(self, bases):
1242
warn("BzrError AmbiguousBase has been deprecated as of bzrlib 0.8.",
1271
symbol_versioning.warn("BzrError AmbiguousBase has been deprecated "
1272
"as of bzrlib 0.8.", DeprecationWarning, stacklevel=2)
1244
1273
msg = ("The correct base is unclear, because %s are all equally close"
1245
1274
% ", ".join(bases))
1246
1275
BzrError.__init__(self, msg)
1268
1297
class BoundBranchOutOfDate(BzrError):
1270
1299
_fmt = ("Bound branch %(branch)s is out of date with master branch"
1300
" %(master)s.%(extra_help)s")
1273
1302
def __init__(self, branch, master):
1274
1303
BzrError.__init__(self)
1275
1304
self.branch = branch
1276
1305
self.master = master
1306
self.extra_help = ''
1279
1309
class CommitToDoubleBoundBranch(BzrError):
2005
2035
class BadConversionTarget(BzrError):
2007
_fmt = "Cannot convert to format %(format)s. %(problem)s"
2037
_fmt = "Cannot convert from format %(from_format)s to format %(format)s." \
2009
def __init__(self, problem, format):
2040
def __init__(self, problem, format, from_format=None):
2010
2041
BzrError.__init__(self)
2011
2042
self.problem = problem
2012
2043
self.format = format
2044
self.from_format = from_format or '(unspecified)'
2015
2047
class NoDiffFound(BzrError):
2092
2124
class OutOfDateTree(BzrError):
2094
_fmt = "Working tree is out of date, please run 'bzr update'."
2126
_fmt = "Working tree is out of date, please run 'bzr update'.%(more)s"
2096
def __init__(self, tree):
2128
def __init__(self, tree, more=None):
2097
2133
BzrError.__init__(self)
2098
2134
self.tree = tree
2101
2138
class PublicBranchOutOfDate(BzrError):
2140
2177
def __init__(self, repo):
2141
2178
BzrError.__init__(self)
2142
self.repo_path = repo.bzrdir.root_transport.base
2179
self.repo_path = repo.user_url
2145
2182
class InconsistentDelta(BzrError):
2155
2192
self.reason = reason
2195
class InconsistentDeltaDelta(InconsistentDelta):
2196
"""Used when we get a delta that is not valid."""
2198
_fmt = ("An inconsistent delta was supplied: %(delta)r"
2199
"\nreason: %(reason)s")
2201
def __init__(self, delta, reason):
2202
BzrError.__init__(self)
2204
self.reason = reason
2158
2207
class UpgradeRequired(BzrError):
2160
2209
_fmt = "To use this feature you must upgrade your branch at %(path)s."
2169
2218
_fmt = "To use this feature you must upgrade your repository at %(path)s."
2221
class RichRootUpgradeRequired(UpgradeRequired):
2223
_fmt = ("To use this feature you must upgrade your branch at %(path)s to"
2224
" a format which supports rich roots.")
2172
2227
class LocalRequiresBoundBranch(BzrError):
2174
2229
_fmt = "Cannot perform local-only commits on unbound branches."
2177
class InvalidProgressBarType(BzrError):
2179
_fmt = ("Environment variable BZR_PROGRESS_BAR='%(bar_type)s"
2180
" is not a supported type Select one of: %(valid_types)s")
2182
def __init__(self, bar_type, valid_types):
2183
BzrError.__init__(self, bar_type=bar_type, valid_types=valid_types)
2186
2232
class UnsupportedOperation(BzrError):
2188
2234
_fmt = ("The method %(mname)s is not supported on"
2709
2755
def __init__(self, bzrdir):
2710
2756
import bzrlib.urlutils as urlutils
2711
display_url = urlutils.unescape_for_display(bzrdir.root_transport.base,
2757
display_url = urlutils.unescape_for_display(bzrdir.user_url,
2713
2759
BzrError.__init__(self, bzrdir=bzrdir, display_url=display_url)
2780
2826
class UncommittedChanges(BzrError):
2782
_fmt = 'Working tree "%(display_url)s" has uncommitted changes.'
2828
_fmt = ('Working tree "%(display_url)s" has uncommitted changes'
2829
' (See bzr status).%(more)s')
2784
def __init__(self, tree):
2831
def __init__(self, tree, more=None):
2785
2836
import bzrlib.urlutils as urlutils
2786
2837
display_url = urlutils.unescape_for_display(
2787
tree.bzrdir.root_transport.base, 'ascii')
2788
BzrError.__init__(self, tree=tree, display_url=display_url)
2838
tree.user_url, 'ascii')
2839
BzrError.__init__(self, tree=tree, display_url=display_url, more=more)
2791
2842
class MissingTemplateVariable(BzrError):
2902
2948
_fmt = 'Cannot bind address "%(host)s:%(port)i": %(orig_error)s.'
2904
2950
def __init__(self, host, port, orig_error):
2951
# nb: in python2.4 socket.error doesn't have a useful repr
2905
2952
BzrError.__init__(self, host=host, port=port,
2906
orig_error=orig_error[1])
2953
orig_error=repr(orig_error.args))
2909
2956
class UnknownRules(BzrError):
2917
2964
class HookFailed(BzrError):
2918
2965
"""Raised when a pre_change_branch_tip hook function fails anything other
2919
2966
than TipChangeRejected.
2968
Note that this exception is no longer raised, and the import is only left
2969
to be nice to code which might catch it in a plugin.
2922
2972
_fmt = ("Hook '%(hook_name)s' during %(hook_stage)s failed:\n"
2923
2973
"%(traceback_text)s%(exc_value)s")
2925
def __init__(self, hook_stage, hook_name, exc_info):
2975
def __init__(self, hook_stage, hook_name, exc_info, warn=True):
2977
symbol_versioning.warn("BzrError HookFailed has been deprecated "
2978
"as of bzrlib 2.1.", DeprecationWarning, stacklevel=2)
2926
2979
import traceback
2927
2980
self.hook_stage = hook_stage
2928
2981
self.hook_name = hook_name
2965
3018
BzrError.__init__(self, invalid_id=invalid_id)
3021
class JailBreak(BzrError):
3023
_fmt = "An attempt to access a url outside the server jail was made: '%(url)s'."
3025
def __init__(self, url):
3026
BzrError.__init__(self, url=url)
2968
3029
class UserAbort(BzrError):
2970
3031
_fmt = 'The user aborted the operation.'
3031
3092
def __init__(self, repository):
3032
3093
self.repository = repository
3096
class LossyPushToSameVCS(BzrError):
3098
_fmt = ("Lossy push not possible between %(source_branch)r and "
3099
"%(target_branch)r that are in the same VCS.")
3101
internal_error = True
3103
def __init__(self, source_branch, target_branch):
3104
self.source_branch = source_branch
3105
self.target_branch = target_branch
3108
class NoRoundtrippingSupport(BzrError):
3110
_fmt = ("Roundtripping is not supported between %(source_branch)r and "
3111
"%(target_branch)r.")
3113
internal_error = True
3115
def __init__(self, source_branch, target_branch):
3116
self.source_branch = source_branch
3117
self.target_branch = target_branch
3120
class FileTimestampUnavailable(BzrError):
3122
_fmt = "The filestamp for %(path)s is not available."
3124
internal_error = True
3126
def __init__(self, path):
3130
class NoColocatedBranchSupport(BzrError):
3132
_fmt = ("%(bzrdir)r does not support co-located branches.")
3134
def __init__(self, bzrdir):
3135
self.bzrdir = bzrdir
3137
class NoWhoami(BzrError):
3139
_fmt = ('Unable to determine your name.\n'
3140
"Please, set your name with the 'whoami' command.\n"
3141
'E.g. bzr whoami "Your Name <name@example.com>"')