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.
72
72
arguments can be given. The first is for generic "user" errors which
73
73
are not intended to be caught and so do not need a specific subclass.
74
74
The second case is for use with subclasses that provide a _fmt format
75
string to print the arguments.
75
string to print the arguments.
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
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
82
82
:param msg: If given, this is the literal complete text for the error,
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):
1004
1020
class LockContention(LockError):
1006
_fmt = 'Could not acquire lock "%(lock)s"'
1022
_fmt = 'Could not acquire lock "%(lock)s": %(msg)s'
1007
1023
# TODO: show full url for lock, combining the transport and relative
1010
1026
internal_error = False
1012
def __init__(self, lock):
1028
def __init__(self, lock, msg=''):
1013
1029
self.lock = lock
1016
1033
class LockBroken(LockError):
1226
1244
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
1247
class AmbiguousBase(BzrError):
1240
1249
def __init__(self, bases):
1241
warn("BzrError AmbiguousBase has been deprecated as of bzrlib 0.8.",
1250
symbol_versioning.warn("BzrError AmbiguousBase has been deprecated "
1251
"as of bzrlib 0.8.", DeprecationWarning, stacklevel=2)
1243
1252
msg = ("The correct base is unclear, because %s are all equally close"
1244
1253
% ", ".join(bases))
1245
1254
BzrError.__init__(self, msg)
2002
2013
class BadConversionTarget(BzrError):
2004
_fmt = "Cannot convert to format %(format)s. %(problem)s"
2015
_fmt = "Cannot convert from format %(from_format)s to format %(format)s." \
2006
def __init__(self, problem, format):
2018
def __init__(self, problem, format, from_format=None):
2007
2019
BzrError.__init__(self)
2008
2020
self.problem = problem
2009
2021
self.format = format
2022
self.from_format = from_format or '(unspecified)'
2012
2025
class NoDiffFound(BzrError):
2166
2196
_fmt = "To use this feature you must upgrade your repository at %(path)s."
2199
class RichRootUpgradeRequired(UpgradeRequired):
2201
_fmt = ("To use this feature you must upgrade your branch at %(path)s to"
2202
" a format which supports rich roots.")
2169
2205
class LocalRequiresBoundBranch(BzrError):
2171
2207
_fmt = "Cannot perform local-only commits on unbound branches."
2174
class InvalidProgressBarType(BzrError):
2176
_fmt = ("Environment variable BZR_PROGRESS_BAR='%(bar_type)s"
2177
" is not a supported type Select one of: %(valid_types)s")
2179
def __init__(self, bar_type, valid_types):
2180
BzrError.__init__(self, bar_type=bar_type, valid_types=valid_types)
2183
2210
class UnsupportedOperation(BzrError):
2185
2212
_fmt = ("The method %(mname)s is not supported on"
2245
2272
self.text = text
2248
class MalformedHeader(BadBundle):
2275
class MalformedHeader(BadBundle):
2250
2277
_fmt = "Malformed bzr revision-bundle header: %(text)r"
2253
class MalformedPatches(BadBundle):
2280
class MalformedPatches(BadBundle):
2255
2282
_fmt = "Malformed patches in bzr revision-bundle: %(text)r"
2258
class MalformedFooter(BadBundle):
2285
class MalformedFooter(BadBundle):
2260
2287
_fmt = "Malformed footer in bzr revision-bundle: %(text)r"
2263
2290
class UnsupportedEOLMarker(BadBundle):
2265
_fmt = "End of line marker was not \\n in bzr revision-bundle"
2292
_fmt = "End of line marker was not \\n in bzr revision-bundle"
2267
2294
def __init__(self):
2268
# XXX: BadBundle's constructor assumes there's explanatory text,
2295
# XXX: BadBundle's constructor assumes there's explanatory text,
2269
2296
# but for this there is not
2270
2297
BzrError.__init__(self)
2273
2300
class IncompatibleBundleFormat(BzrError):
2275
2302
_fmt = "Bundle format %(bundle_format)s is incompatible with %(other)s"
2277
2304
def __init__(self, bundle_format, other):
2528
2547
self.branch = branch
2550
class InvalidLineInBugsProperty(BzrError):
2552
_fmt = ("Invalid line in bugs property: '%(line)s'")
2554
def __init__(self, line):
2558
class InvalidBugStatus(BzrError):
2560
_fmt = ("Invalid bug status: '%(status)s'")
2562
def __init__(self, status):
2563
self.status = status
2531
2566
class UnexpectedSmartServerResponse(BzrError):
2533
2568
_fmt = "Could not understand response from smart server: %(response_tuple)r"
2757
2804
class UncommittedChanges(BzrError):
2759
_fmt = 'Working tree "%(display_url)s" has uncommitted changes.'
2806
_fmt = ('Working tree "%(display_url)s" has uncommitted changes'
2807
' (See bzr status).%(more)s')
2761
def __init__(self, tree):
2809
def __init__(self, tree, more=None):
2762
2814
import bzrlib.urlutils as urlutils
2763
2815
display_url = urlutils.unescape_for_display(
2764
2816
tree.bzrdir.root_transport.base, 'ascii')
2765
BzrError.__init__(self, tree=tree, display_url=display_url)
2817
BzrError.__init__(self, tree=tree, display_url=display_url, more=more)
2768
2820
class MissingTemplateVariable(BzrError):
2805
2857
class CommandAvailableInPlugin(StandardError):
2807
2859
internal_error = False
2809
2861
def __init__(self, cmd_name, plugin_metadata, provider):
2811
2863
self.plugin_metadata = plugin_metadata
2812
2864
self.cmd_name = cmd_name
2813
2865
self.provider = provider
2815
2867
def __str__(self):
2817
_fmt = ('"%s" is not a standard bzr command. \n'
2869
_fmt = ('"%s" is not a standard bzr command. \n'
2818
2870
'However, the following official plugin provides this command: %s\n'
2819
2871
'You can install it by going to: %s'
2820
% (self.cmd_name, self.plugin_metadata['name'],
2872
% (self.cmd_name, self.plugin_metadata['name'],
2821
2873
self.plugin_metadata['url']))
2826
2878
class NoPluginAvailable(BzrError):
2830
class NotATerminal(BzrError):
2832
_fmt = 'Unable to ask for a password without real terminal.'
2835
2882
class UnableEncodePath(BzrError):
2879
2926
_fmt = 'Cannot bind address "%(host)s:%(port)i": %(orig_error)s.'
2881
2928
def __init__(self, host, port, orig_error):
2929
# nb: in python2.4 socket.error doesn't have a useful repr
2882
2930
BzrError.__init__(self, host=host, port=port,
2883
orig_error=orig_error[1])
2931
orig_error=repr(orig_error.args))
2886
2934
class UnknownRules(BzrError):
2894
2942
class HookFailed(BzrError):
2895
2943
"""Raised when a pre_change_branch_tip hook function fails anything other
2896
2944
than TipChangeRejected.
2946
Note that this exception is no longer raised, and the import is only left
2947
to be nice to code which might catch it in a plugin.
2899
2950
_fmt = ("Hook '%(hook_name)s' during %(hook_stage)s failed:\n"
2900
2951
"%(traceback_text)s%(exc_value)s")
2902
def __init__(self, hook_stage, hook_name, exc_info):
2953
def __init__(self, hook_stage, hook_name, exc_info, warn=True):
2955
symbol_versioning.warn("BzrError HookFailed has been deprecated "
2956
"as of bzrlib 2.1.", DeprecationWarning, stacklevel=2)
2903
2957
import traceback
2904
2958
self.hook_stage = hook_stage
2905
2959
self.hook_name = hook_name
2934
2988
BzrError.__init__(self, shelf_id=shelf_id)
2991
class InvalidShelfId(BzrError):
2993
_fmt = '"%(invalid_id)s" is not a valid shelf id, try a number instead.'
2995
def __init__(self, invalid_id):
2996
BzrError.__init__(self, invalid_id=invalid_id)
2999
class JailBreak(BzrError):
3001
_fmt = "An attempt to access a url outside the server jail was made: '%(url)s'."
3003
def __init__(self, url):
3004
BzrError.__init__(self, url=url)
2937
3007
class UserAbort(BzrError):
2939
3009
_fmt = 'The user aborted the operation.'
3012
class MustHaveWorkingTree(BzrError):
3014
_fmt = ("Branching '%(url)s'(%(format)s) must create a working tree.")
3016
def __init__(self, format, url):
3017
BzrError.__init__(self, format=format, url=url)
3020
class NoSuchView(BzrError):
3021
"""A view does not exist.
3024
_fmt = u"No such view: %(view_name)s."
3026
def __init__(self, view_name):
3027
self.view_name = view_name
3030
class ViewsNotSupported(BzrError):
3031
"""Views are not supported by a tree format.
3034
_fmt = ("Views are not supported by %(tree)s;"
3035
" use 'bzr upgrade' to change your tree to a later format.")
3037
def __init__(self, tree):
3041
class FileOutsideView(BzrError):
3043
_fmt = ('Specified file "%(file_name)s" is outside the current view: '
3046
def __init__(self, file_name, view_files):
3047
self.file_name = file_name
3048
self.view_str = ", ".join(view_files)
3051
class UnresumableWriteGroup(BzrError):
3053
_fmt = ("Repository %(repository)s cannot resume write group "
3054
"%(write_groups)r: %(reason)s")
3056
internal_error = True
3058
def __init__(self, repository, write_groups, reason):
3059
self.repository = repository
3060
self.write_groups = write_groups
3061
self.reason = reason
3064
class UnsuspendableWriteGroup(BzrError):
3066
_fmt = ("Repository %(repository)s cannot suspend a write group.")
3068
internal_error = True
3070
def __init__(self, repository):
3071
self.repository = repository
3074
class LossyPushToSameVCS(BzrError):
3076
_fmt = ("Lossy push not possible between %(source_branch)r and "
3077
"%(target_branch)r that are in the same VCS.")
3079
internal_error = True
3081
def __init__(self, source_branch, target_branch):
3082
self.source_branch = source_branch
3083
self.target_branch = target_branch
3086
class NoRoundtrippingSupport(BzrError):
3088
_fmt = ("Roundtripping is not supported between %(source_branch)r and "
3089
"%(target_branch)r.")
3091
internal_error = True
3093
def __init__(self, source_branch, target_branch):
3094
self.source_branch = source_branch
3095
self.target_branch = target_branch