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
1178
class InvalidRevisionSpec(BzrError):
1145
_fmt = ("Requested revision: %(spec)r does not exist in branch:"
1180
_fmt = ("Requested revision: '%(spec)s' does not exist in branch:"
1146
1181
" %(branch)s%(extra)s")
1148
1183
def __init__(self, spec, branch, extra=None):
1173
1208
class DivergedBranches(BzrError):
1175
1210
_fmt = ("These branches have diverged."
1176
" Use the merge command to reconcile them.")
1211
" Use the missing command to see how.\n"
1212
"Use the merge command to reconcile them.")
1178
1214
def __init__(self, branch1, branch2):
1179
1215
self.branch1 = branch1
1227
1263
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
1266
class AmbiguousBase(BzrError):
1241
1268
def __init__(self, bases):
1242
warn("BzrError AmbiguousBase has been deprecated as of bzrlib 0.8.",
1269
symbol_versioning.warn("BzrError AmbiguousBase has been deprecated "
1270
"as of bzrlib 0.8.", DeprecationWarning, stacklevel=2)
1244
1271
msg = ("The correct base is unclear, because %s are all equally close"
1245
1272
% ", ".join(bases))
1246
1273
BzrError.__init__(self, msg)
1268
1295
class BoundBranchOutOfDate(BzrError):
1270
1297
_fmt = ("Bound branch %(branch)s is out of date with master branch"
1298
" %(master)s.%(extra_help)s")
1273
1300
def __init__(self, branch, master):
1274
1301
BzrError.__init__(self)
1275
1302
self.branch = branch
1276
1303
self.master = master
1304
self.extra_help = ''
1279
1307
class CommitToDoubleBoundBranch(BzrError):
1895
1923
_fmt = "Moving the root directory is not supported at this time"
1926
class TransformRenameFailed(BzrError):
1928
_fmt = "Failed to rename %(from_path)s to %(to_path)s: %(why)s"
1930
def __init__(self, from_path, to_path, why, errno):
1931
self.from_path = from_path
1932
self.to_path = to_path
1898
1937
class BzrMoveFailedError(BzrError):
1900
1939
_fmt = "Could not move %(from_path)s%(operator)s %(to_path)s%(extra)s"
2005
2044
class BadConversionTarget(BzrError):
2007
_fmt = "Cannot convert to format %(format)s. %(problem)s"
2046
_fmt = "Cannot convert from format %(from_format)s to format %(format)s." \
2009
def __init__(self, problem, format):
2049
def __init__(self, problem, format, from_format=None):
2010
2050
BzrError.__init__(self)
2011
2051
self.problem = problem
2012
2052
self.format = format
2053
self.from_format = from_format or '(unspecified)'
2015
2056
class NoDiffFound(BzrError):
2092
2133
class OutOfDateTree(BzrError):
2094
_fmt = "Working tree is out of date, please run 'bzr update'."
2135
_fmt = "Working tree is out of date, please run 'bzr update'.%(more)s"
2096
def __init__(self, tree):
2137
def __init__(self, tree, more=None):
2097
2142
BzrError.__init__(self)
2098
2143
self.tree = tree
2101
2147
class PublicBranchOutOfDate(BzrError):
2140
2186
def __init__(self, repo):
2141
2187
BzrError.__init__(self)
2142
self.repo_path = repo.bzrdir.root_transport.base
2188
self.repo_path = repo.user_url
2145
2191
class InconsistentDelta(BzrError):
2155
2201
self.reason = reason
2204
class InconsistentDeltaDelta(InconsistentDelta):
2205
"""Used when we get a delta that is not valid."""
2207
_fmt = ("An inconsistent delta was supplied: %(delta)r"
2208
"\nreason: %(reason)s")
2210
def __init__(self, delta, reason):
2211
BzrError.__init__(self)
2213
self.reason = reason
2158
2216
class UpgradeRequired(BzrError):
2160
2218
_fmt = "To use this feature you must upgrade your branch at %(path)s."
2169
2227
_fmt = "To use this feature you must upgrade your repository at %(path)s."
2230
class RichRootUpgradeRequired(UpgradeRequired):
2232
_fmt = ("To use this feature you must upgrade your branch at %(path)s to"
2233
" a format which supports rich roots.")
2172
2236
class LocalRequiresBoundBranch(BzrError):
2174
2238
_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
2241
class UnsupportedOperation(BzrError):
2188
2243
_fmt = ("The method %(mname)s is not supported on"
2709
2764
def __init__(self, bzrdir):
2710
2765
import bzrlib.urlutils as urlutils
2711
display_url = urlutils.unescape_for_display(bzrdir.root_transport.base,
2766
display_url = urlutils.unescape_for_display(bzrdir.user_url,
2713
2768
BzrError.__init__(self, bzrdir=bzrdir, display_url=display_url)
2780
2835
class UncommittedChanges(BzrError):
2782
_fmt = 'Working tree "%(display_url)s" has uncommitted changes.'
2837
_fmt = ('Working tree "%(display_url)s" has uncommitted changes'
2838
' (See bzr status).%(more)s')
2784
def __init__(self, tree):
2840
def __init__(self, tree, more=None):
2785
2845
import bzrlib.urlutils as urlutils
2786
2846
display_url = urlutils.unescape_for_display(
2787
tree.bzrdir.root_transport.base, 'ascii')
2788
BzrError.__init__(self, tree=tree, display_url=display_url)
2847
tree.user_url, 'ascii')
2848
BzrError.__init__(self, tree=tree, display_url=display_url, more=more)
2851
class ShelvedChanges(UncommittedChanges):
2853
_fmt = ('Working tree "%(display_url)s" has shelved changes'
2854
' (See bzr shelve --list).%(more)s')
2791
2857
class MissingTemplateVariable(BzrError):
2902
2963
_fmt = 'Cannot bind address "%(host)s:%(port)i": %(orig_error)s.'
2904
2965
def __init__(self, host, port, orig_error):
2966
# nb: in python2.4 socket.error doesn't have a useful repr
2905
2967
BzrError.__init__(self, host=host, port=port,
2906
orig_error=orig_error[1])
2968
orig_error=repr(orig_error.args))
2909
2971
class UnknownRules(BzrError):
2917
2979
class HookFailed(BzrError):
2918
2980
"""Raised when a pre_change_branch_tip hook function fails anything other
2919
2981
than TipChangeRejected.
2983
Note that this exception is no longer raised, and the import is only left
2984
to be nice to code which might catch it in a plugin.
2922
2987
_fmt = ("Hook '%(hook_name)s' during %(hook_stage)s failed:\n"
2923
2988
"%(traceback_text)s%(exc_value)s")
2925
def __init__(self, hook_stage, hook_name, exc_info):
2990
def __init__(self, hook_stage, hook_name, exc_info, warn=True):
2992
symbol_versioning.warn("BzrError HookFailed has been deprecated "
2993
"as of bzrlib 2.1.", DeprecationWarning, stacklevel=2)
2926
2994
import traceback
2927
2995
self.hook_stage = hook_stage
2928
2996
self.hook_name = hook_name
2965
3033
BzrError.__init__(self, invalid_id=invalid_id)
3036
class JailBreak(BzrError):
3038
_fmt = "An attempt to access a url outside the server jail was made: '%(url)s'."
3040
def __init__(self, url):
3041
BzrError.__init__(self, url=url)
2968
3044
class UserAbort(BzrError):
2970
3046
_fmt = 'The user aborted the operation.'
3031
3107
def __init__(self, repository):
3032
3108
self.repository = repository
3111
class LossyPushToSameVCS(BzrError):
3113
_fmt = ("Lossy push not possible between %(source_branch)r and "
3114
"%(target_branch)r that are in the same VCS.")
3116
internal_error = True
3118
def __init__(self, source_branch, target_branch):
3119
self.source_branch = source_branch
3120
self.target_branch = target_branch
3123
class NoRoundtrippingSupport(BzrError):
3125
_fmt = ("Roundtripping is not supported between %(source_branch)r and "
3126
"%(target_branch)r.")
3128
internal_error = True
3130
def __init__(self, source_branch, target_branch):
3131
self.source_branch = source_branch
3132
self.target_branch = target_branch
3135
class FileTimestampUnavailable(BzrError):
3137
_fmt = "The filestamp for %(path)s is not available."
3139
internal_error = True
3141
def __init__(self, path):
3145
class NoColocatedBranchSupport(BzrError):
3147
_fmt = ("%(bzrdir)r does not support co-located branches.")
3149
def __init__(self, bzrdir):
3150
self.bzrdir = bzrdir
3152
class NoWhoami(BzrError):
3154
_fmt = ('Unable to determine your name.\n'
3155
"Please, set your name with the 'whoami' command.\n"
3156
'E.g. bzr whoami "Your Name <name@example.com>"')