1
# Copyright (C) 2005-2010 Canonical Ltd
1
# Copyright (C) 2005, 2006, 2007, 2008 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
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17
17
"""Exceptions for bzr, and reporting of them.
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
649
639
class UnstackableRepositoryFormat(BzrError):
651
641
_fmt = ("The repository '%(url)s'(%(format)s) is not a stackable format. "
702
692
# TODO: Probably this behavior of should be a common superclass
703
693
class NotBranchError(PathError):
705
_fmt = 'Not a branch: "%(path)s"%(detail)s.'
695
_fmt = 'Not a branch: "%(path)s".'
707
def __init__(self, path, detail=None, bzrdir=None):
697
def __init__(self, path):
708
698
import bzrlib.urlutils as urlutils
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)
699
self.path = urlutils.unescape_for_display(path, 'ascii')
733
702
class NoSubmitBranch(PathError):
783
752
_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)))
787
754
def __init__(self, branch, path):
788
755
BzrError.__init__(self)
789
756
self.branch = branch
818
785
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.
826
787
_fmt = "%(target)s\n" \
827
788
"is not compatible with\n" \
949
910
# original exception is available as e.original_error
951
912
# New code should prefer to raise specific subclasses
952
def __init__(self, msg):
913
def __init__(self, message):
914
# Python 2.5 uses a slot for StandardError.message,
915
# so use a different variable name. We now work around this in
916
# BzrError.__str__, but this member name is kept for compatability.
956
920
class LockActive(LockError):
1040
1004
class LockContention(LockError):
1042
_fmt = 'Could not acquire lock "%(lock)s": %(msg)s'
1006
_fmt = 'Could not acquire lock "%(lock)s"'
1007
# TODO: show full url for lock, combining the transport and relative
1044
1010
internal_error = False
1046
def __init__(self, lock, msg=''):
1012
def __init__(self, lock):
1047
1013
self.lock = lock
1051
1016
class LockBroken(LockError):
1177
1142
class InvalidRevisionSpec(BzrError):
1179
_fmt = ("Requested revision: '%(spec)s' does not exist in branch:"
1180
" %(branch_url)s%(extra)s")
1144
_fmt = ("Requested revision: %(spec)r does not exist in branch:"
1145
" %(branch)s%(extra)s")
1182
1147
def __init__(self, spec, branch, extra=None):
1183
1148
BzrError.__init__(self, branch=branch, spec=spec)
1184
self.branch_url = getattr(branch, 'user_url', str(branch))
1186
1150
self.extra = '\n' + str(extra)
1208
1172
class DivergedBranches(BzrError):
1210
1174
_fmt = ("These branches have diverged."
1211
" Use the missing command to see how.\n"
1212
"Use the merge command to reconcile them.")
1175
" Use the merge command to reconcile them.")
1214
1177
def __init__(self, branch1, branch2):
1215
1178
self.branch1 = branch1
1263
1226
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
1266
1238
class AmbiguousBase(BzrError):
1268
1240
def __init__(self, bases):
1269
symbol_versioning.warn("BzrError AmbiguousBase has been deprecated "
1270
"as of bzrlib 0.8.", DeprecationWarning, stacklevel=2)
1241
warn("BzrError AmbiguousBase has been deprecated as of bzrlib 0.8.",
1271
1243
msg = ("The correct base is unclear, because %s are all equally close"
1272
1244
% ", ".join(bases))
1273
1245
BzrError.__init__(self, msg)
1295
1267
class BoundBranchOutOfDate(BzrError):
1297
1269
_fmt = ("Bound branch %(branch)s is out of date with master branch"
1298
" %(master)s.%(extra_help)s")
1300
1272
def __init__(self, branch, master):
1301
1273
BzrError.__init__(self)
1302
1274
self.branch = branch
1303
1275
self.master = master
1304
self.extra_help = ''
1307
1278
class CommitToDoubleBoundBranch(BzrError):
1379
1350
class WeaveParentMismatch(WeaveError):
1381
_fmt = "Parents are mismatched between two revisions. %(msg)s"
1352
_fmt = "Parents are mismatched between two revisions. %(message)s"
1384
1355
class WeaveInvalidChecksum(WeaveError):
1386
_fmt = "Text did not match it's checksum: %(msg)s"
1357
_fmt = "Text did not match it's checksum: %(message)s"
1389
1360
class WeaveTextDiffers(WeaveError):
1923
1894
_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
1937
1897
class BzrMoveFailedError(BzrError):
1939
1899
_fmt = "Could not move %(from_path)s%(operator)s %(to_path)s%(extra)s"
1984
1944
"Use --keep to not delete them, or --force to delete them regardless.")
1986
1946
def __init__(self, tree_delta):
1987
symbol_versioning.warn(symbol_versioning.deprecated_in((2, 3, 0)) %
1988
"BzrRemoveChangedFilesError", DeprecationWarning, stacklevel=2)
1989
1947
BzrError.__init__(self)
1990
1948
self.changes_as_text = tree_delta.get_changes_as_text()
1991
1949
#self.paths_as_string = '\n'.join(changed_files)
2046
2004
class BadConversionTarget(BzrError):
2048
_fmt = "Cannot convert from format %(from_format)s to format %(format)s." \
2006
_fmt = "Cannot convert to format %(format)s. %(problem)s"
2051
def __init__(self, problem, format, from_format=None):
2008
def __init__(self, problem, format):
2052
2009
BzrError.__init__(self)
2053
2010
self.problem = problem
2054
2011
self.format = format
2055
self.from_format = from_format or '(unspecified)'
2058
2014
class NoDiffFound(BzrError):
2135
2091
class OutOfDateTree(BzrError):
2137
_fmt = "Working tree is out of date, please run 'bzr update'.%(more)s"
2093
_fmt = "Working tree is out of date, please run 'bzr update'."
2139
def __init__(self, tree, more=None):
2095
def __init__(self, tree):
2144
2096
BzrError.__init__(self)
2145
2097
self.tree = tree
2149
2100
class PublicBranchOutOfDate(BzrError):
2188
2139
def __init__(self, repo):
2189
2140
BzrError.__init__(self)
2190
self.repo_path = repo.user_url
2141
self.repo_path = repo.bzrdir.root_transport.base
2193
2144
class InconsistentDelta(BzrError):
2203
2154
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
2218
2157
class UpgradeRequired(BzrError):
2220
2159
_fmt = "To use this feature you must upgrade your branch at %(path)s."
2229
2168
_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.")
2238
2171
class LocalRequiresBoundBranch(BzrError):
2240
2173
_fmt = "Cannot perform local-only commits on unbound branches."
2176
class InvalidProgressBarType(BzrError):
2178
_fmt = ("Environment variable BZR_PROGRESS_BAR='%(bar_type)s"
2179
" is not a supported type Select one of: %(valid_types)s")
2181
def __init__(self, bar_type, valid_types):
2182
BzrError.__init__(self, bar_type=bar_type, valid_types=valid_types)
2243
2185
class UnsupportedOperation(BzrError):
2245
2187
_fmt = ("The method %(mname)s is not supported on"
2366
2308
self.transport = transport
2311
class NoSmartServer(NotBranchError):
2313
_fmt = "No smart server available at %(url)s"
2315
@symbol_versioning.deprecated_method(symbol_versioning.one_four)
2316
def __init__(self, url):
2369
2320
class UnknownSSH(BzrError):
2371
2322
_fmt = "Unrecognised value for BZR_SSH environment variable: %(vendor)s"
2553
2504
class MalformedBugIdentifier(BzrError):
2555
_fmt = ('Did not understand bug identifier %(bug_id)s: %(reason)s. '
2556
'See "bzr help bugs" for more information on this feature.')
2506
_fmt = "Did not understand bug identifier %(bug_id)s: %(reason)s"
2558
2508
def __init__(self, bug_id, reason):
2559
2509
self.bug_id = bug_id
2580
2530
self.branch = branch
2583
class InvalidLineInBugsProperty(BzrError):
2585
_fmt = ("Invalid line in bugs property: '%(line)s'")
2587
def __init__(self, line):
2591
class InvalidBugStatus(BzrError):
2593
_fmt = ("Invalid bug status: '%(status)s'")
2595
def __init__(self, status):
2596
self.status = status
2599
2533
class UnexpectedSmartServerResponse(BzrError):
2601
2535
_fmt = "Could not understand response from smart server: %(response_tuple)r"
2766
2700
def __init__(self, bzrdir):
2767
2701
import bzrlib.urlutils as urlutils
2768
display_url = urlutils.unescape_for_display(bzrdir.user_url,
2702
display_url = urlutils.unescape_for_display(bzrdir.root_transport.base,
2770
2704
BzrError.__init__(self, bzrdir=bzrdir, display_url=display_url)
2837
2771
class UncommittedChanges(BzrError):
2839
_fmt = ('Working tree "%(display_url)s" has uncommitted changes'
2840
' (See bzr status).%(more)s')
2773
_fmt = 'Working tree "%(display_url)s" has uncommitted changes.'
2842
def __init__(self, tree, more=None):
2775
def __init__(self, tree):
2847
2776
import bzrlib.urlutils as urlutils
2848
user_url = getattr(tree, "user_url", None)
2849
if user_url is None:
2850
display_url = str(tree)
2852
display_url = urlutils.unescape_for_display(user_url, 'ascii')
2853
BzrError.__init__(self, tree=tree, display_url=display_url, more=more)
2856
class ShelvedChanges(UncommittedChanges):
2858
_fmt = ('Working tree "%(display_url)s" has shelved changes'
2859
' (See bzr shelve --list).%(more)s')
2777
display_url = urlutils.unescape_for_display(
2778
tree.bzrdir.root_transport.base, 'ascii')
2779
BzrError.__init__(self, tree=tree, display_url=display_url)
2862
2782
class MissingTemplateVariable(BzrError):
2968
2893
_fmt = 'Cannot bind address "%(host)s:%(port)i": %(orig_error)s.'
2970
2895
def __init__(self, host, port, orig_error):
2971
# nb: in python2.4 socket.error doesn't have a useful repr
2972
2896
BzrError.__init__(self, host=host, port=port,
2973
orig_error=repr(orig_error.args))
2897
orig_error=orig_error[1])
2976
2900
class UnknownRules(BzrError):
2984
2908
class HookFailed(BzrError):
2985
2909
"""Raised when a pre_change_branch_tip hook function fails anything other
2986
2910
than TipChangeRejected.
2988
Note that this exception is no longer raised, and the import is only left
2989
to be nice to code which might catch it in a plugin.
2992
2913
_fmt = ("Hook '%(hook_name)s' during %(hook_stage)s failed:\n"
2993
2914
"%(traceback_text)s%(exc_value)s")
2995
def __init__(self, hook_stage, hook_name, exc_info, warn=True):
2997
symbol_versioning.warn("BzrError HookFailed has been deprecated "
2998
"as of bzrlib 2.1.", DeprecationWarning, stacklevel=2)
2916
def __init__(self, hook_stage, hook_name, exc_info):
2999
2917
import traceback
3000
2918
self.hook_stage = hook_stage
3001
2919
self.hook_name = hook_name
3038
2956
BzrError.__init__(self, invalid_id=invalid_id)
3041
class JailBreak(BzrError):
3043
_fmt = "An attempt to access a url outside the server jail was made: '%(url)s'."
3045
def __init__(self, url):
3046
BzrError.__init__(self, url=url)
3049
2959
class UserAbort(BzrError):
3051
2961
_fmt = 'The user aborted the operation.'
3112
3022
def __init__(self, repository):
3113
3023
self.repository = repository
3116
class LossyPushToSameVCS(BzrError):
3118
_fmt = ("Lossy push not possible between %(source_branch)r and "
3119
"%(target_branch)r that are in the same VCS.")
3121
internal_error = True
3123
def __init__(self, source_branch, target_branch):
3124
self.source_branch = source_branch
3125
self.target_branch = target_branch
3128
class NoRoundtrippingSupport(BzrError):
3130
_fmt = ("Roundtripping is not supported between %(source_branch)r and "
3131
"%(target_branch)r.")
3133
internal_error = True
3135
def __init__(self, source_branch, target_branch):
3136
self.source_branch = source_branch
3137
self.target_branch = target_branch
3140
class FileTimestampUnavailable(BzrError):
3142
_fmt = "The filestamp for %(path)s is not available."
3144
internal_error = True
3146
def __init__(self, path):
3150
class NoColocatedBranchSupport(BzrError):
3152
_fmt = ("%(bzrdir)r does not support co-located branches.")
3154
def __init__(self, bzrdir):
3155
self.bzrdir = bzrdir
3158
class NoWhoami(BzrError):
3160
_fmt = ('Unable to determine your name.\n'
3161
"Please, set your name with the 'whoami' command.\n"
3162
'E.g. bzr whoami "Your Name <name@example.com>"')
3165
class InvalidPattern(BzrError):
3167
_fmt = ('Invalid pattern(s) found. %(msg)s')
3169
def __init__(self, msg):
3173
class RecursiveBind(BzrError):
3175
_fmt = ('Branch "%(branch_url)s" appears to be bound to itself. '
3176
'Please use `bzr unbind` to fix.')
3178
def __init__(self, branch_url):
3179
self.branch_url = branch_url