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):
752
783
_fmt = 'File "%(path)s" is not in branch %(branch_base)s.'
785
# use PathNotChild instead
786
@symbol_versioning.deprecated_method(symbol_versioning.deprecated_in((2, 3, 0)))
754
787
def __init__(self, branch, path):
755
788
BzrError.__init__(self)
756
789
self.branch = branch
785
818
class IncompatibleRepositories(BzrError):
819
"""Report an error that two repositories are not compatible.
821
Note that the source and target repositories are permitted to be strings:
822
this exception is thrown from the smart server and may refer to a
823
repository the client hasn't opened.
787
826
_fmt = "%(target)s\n" \
788
827
"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):
1895
1925
_fmt = "Moving the root directory is not supported at this time"
1928
class TransformRenameFailed(BzrError):
1930
_fmt = "Failed to rename %(from_path)s to %(to_path)s: %(why)s"
1932
def __init__(self, from_path, to_path, why, errno):
1933
self.from_path = from_path
1934
self.to_path = to_path
1898
1939
class BzrMoveFailedError(BzrError):
1900
1941
_fmt = "Could not move %(from_path)s%(operator)s %(to_path)s%(extra)s"
2005
2046
class BadConversionTarget(BzrError):
2007
_fmt = "Cannot convert to format %(format)s. %(problem)s"
2048
_fmt = "Cannot convert from format %(from_format)s to format %(format)s." \
2009
def __init__(self, problem, format):
2051
def __init__(self, problem, format, from_format=None):
2010
2052
BzrError.__init__(self)
2011
2053
self.problem = problem
2012
2054
self.format = format
2055
self.from_format = from_format or '(unspecified)'
2015
2058
class NoDiffFound(BzrError):
2092
2135
class OutOfDateTree(BzrError):
2094
_fmt = "Working tree is out of date, please run 'bzr update'."
2137
_fmt = "Working tree is out of date, please run 'bzr update'.%(more)s"
2096
def __init__(self, tree):
2139
def __init__(self, tree, more=None):
2097
2144
BzrError.__init__(self)
2098
2145
self.tree = tree
2101
2149
class PublicBranchOutOfDate(BzrError):
2140
2188
def __init__(self, repo):
2141
2189
BzrError.__init__(self)
2142
self.repo_path = repo.bzrdir.root_transport.base
2190
self.repo_path = repo.user_url
2145
2193
class InconsistentDelta(BzrError):
2155
2203
self.reason = reason
2206
class InconsistentDeltaDelta(InconsistentDelta):
2207
"""Used when we get a delta that is not valid."""
2209
_fmt = ("An inconsistent delta was supplied: %(delta)r"
2210
"\nreason: %(reason)s")
2212
def __init__(self, delta, reason):
2213
BzrError.__init__(self)
2215
self.reason = reason
2158
2218
class UpgradeRequired(BzrError):
2160
2220
_fmt = "To use this feature you must upgrade your branch at %(path)s."
2169
2229
_fmt = "To use this feature you must upgrade your repository at %(path)s."
2232
class RichRootUpgradeRequired(UpgradeRequired):
2234
_fmt = ("To use this feature you must upgrade your branch at %(path)s to"
2235
" a format which supports rich roots.")
2172
2238
class LocalRequiresBoundBranch(BzrError):
2174
2240
_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
2243
class UnsupportedOperation(BzrError):
2188
2245
_fmt = ("The method %(mname)s is not supported on"
2709
2766
def __init__(self, bzrdir):
2710
2767
import bzrlib.urlutils as urlutils
2711
display_url = urlutils.unescape_for_display(bzrdir.root_transport.base,
2768
display_url = urlutils.unescape_for_display(bzrdir.user_url,
2713
2770
BzrError.__init__(self, bzrdir=bzrdir, display_url=display_url)
2780
2837
class UncommittedChanges(BzrError):
2782
_fmt = 'Working tree "%(display_url)s" has uncommitted changes.'
2839
_fmt = ('Working tree "%(display_url)s" has uncommitted changes'
2840
' (See bzr status).%(more)s')
2784
def __init__(self, tree):
2842
def __init__(self, tree, more=None):
2785
2847
import bzrlib.urlutils as urlutils
2786
2848
display_url = urlutils.unescape_for_display(
2787
tree.bzrdir.root_transport.base, 'ascii')
2788
BzrError.__init__(self, tree=tree, display_url=display_url)
2849
tree.user_url, 'ascii')
2850
BzrError.__init__(self, tree=tree, display_url=display_url, more=more)
2853
class ShelvedChanges(UncommittedChanges):
2855
_fmt = ('Working tree "%(display_url)s" has shelved changes'
2856
' (See bzr shelve --list).%(more)s')
2791
2859
class MissingTemplateVariable(BzrError):
2902
2965
_fmt = 'Cannot bind address "%(host)s:%(port)i": %(orig_error)s.'
2904
2967
def __init__(self, host, port, orig_error):
2968
# nb: in python2.4 socket.error doesn't have a useful repr
2905
2969
BzrError.__init__(self, host=host, port=port,
2906
orig_error=orig_error[1])
2970
orig_error=repr(orig_error.args))
2909
2973
class UnknownRules(BzrError):
2917
2981
class HookFailed(BzrError):
2918
2982
"""Raised when a pre_change_branch_tip hook function fails anything other
2919
2983
than TipChangeRejected.
2985
Note that this exception is no longer raised, and the import is only left
2986
to be nice to code which might catch it in a plugin.
2922
2989
_fmt = ("Hook '%(hook_name)s' during %(hook_stage)s failed:\n"
2923
2990
"%(traceback_text)s%(exc_value)s")
2925
def __init__(self, hook_stage, hook_name, exc_info):
2992
def __init__(self, hook_stage, hook_name, exc_info, warn=True):
2994
symbol_versioning.warn("BzrError HookFailed has been deprecated "
2995
"as of bzrlib 2.1.", DeprecationWarning, stacklevel=2)
2926
2996
import traceback
2927
2997
self.hook_stage = hook_stage
2928
2998
self.hook_name = hook_name
2965
3035
BzrError.__init__(self, invalid_id=invalid_id)
3038
class JailBreak(BzrError):
3040
_fmt = "An attempt to access a url outside the server jail was made: '%(url)s'."
3042
def __init__(self, url):
3043
BzrError.__init__(self, url=url)
2968
3046
class UserAbort(BzrError):
2970
3048
_fmt = 'The user aborted the operation.'
3031
3109
def __init__(self, repository):
3032
3110
self.repository = repository
3113
class LossyPushToSameVCS(BzrError):
3115
_fmt = ("Lossy push not possible between %(source_branch)r and "
3116
"%(target_branch)r that are in the same VCS.")
3118
internal_error = True
3120
def __init__(self, source_branch, target_branch):
3121
self.source_branch = source_branch
3122
self.target_branch = target_branch
3125
class NoRoundtrippingSupport(BzrError):
3127
_fmt = ("Roundtripping is not supported between %(source_branch)r and "
3128
"%(target_branch)r.")
3130
internal_error = True
3132
def __init__(self, source_branch, target_branch):
3133
self.source_branch = source_branch
3134
self.target_branch = target_branch
3137
class FileTimestampUnavailable(BzrError):
3139
_fmt = "The filestamp for %(path)s is not available."
3141
internal_error = True
3143
def __init__(self, path):
3147
class NoColocatedBranchSupport(BzrError):
3149
_fmt = ("%(bzrdir)r does not support co-located branches.")
3151
def __init__(self, bzrdir):
3152
self.bzrdir = bzrdir
3154
class NoWhoami(BzrError):
3156
_fmt = ('Unable to determine your name.\n'
3157
"Please, set your name with the 'whoami' command.\n"
3158
'E.g. bzr whoami "Your Name <name@example.com>"')
3160
class InvalidPattern(BzrError):
3162
_fmt = ('Invalid pattern(s) found. %(msg)s')
3164
def __init__(self, msg):