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.
33
33
# TODO: is there any value in providing the .args field used by standard
34
# python exceptions? A list of values with no names seems less useful
34
# python exceptions? A list of values with no names seems less useful
37
# TODO: Perhaps convert the exception to a string at the moment it's
37
# TODO: Perhaps convert the exception to a string at the moment it's
38
38
# constructed to make sure it will succeed. But that says nothing about
39
39
# exceptions that are never raised.
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):
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. "
690
700
# TODO: This is given a URL; we try to unescape it but doing that from inside
691
701
# the exception object is a bit undesirable.
692
# TODO: Probably this behavior of should be a common superclass
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):
1004
1041
class LockContention(LockError):
1006
_fmt = 'Could not acquire lock "%(lock)s"'
1043
_fmt = 'Could not acquire lock "%(lock)s": %(msg)s'
1007
1044
# TODO: show full url for lock, combining the transport and relative
1010
1047
internal_error = False
1012
def __init__(self, lock):
1049
def __init__(self, lock, msg=''):
1013
1050
self.lock = lock
1016
1054
class LockBroken(LockError):
1226
1265
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
1268
class AmbiguousBase(BzrError):
1240
1270
def __init__(self, bases):
1241
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)
1243
1273
msg = ("The correct base is unclear, because %s are all equally close"
1244
1274
% ", ".join(bases))
1245
1275
BzrError.__init__(self, msg)
2002
2035
class BadConversionTarget(BzrError):
2004
_fmt = "Cannot convert to format %(format)s. %(problem)s"
2037
_fmt = "Cannot convert from format %(from_format)s to format %(format)s." \
2006
def __init__(self, problem, format):
2040
def __init__(self, problem, format, from_format=None):
2007
2041
BzrError.__init__(self)
2008
2042
self.problem = problem
2009
2043
self.format = format
2044
self.from_format = from_format or '(unspecified)'
2012
2047
class NoDiffFound(BzrError):
2089
2124
class OutOfDateTree(BzrError):
2091
_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"
2093
def __init__(self, tree):
2128
def __init__(self, tree, more=None):
2094
2133
BzrError.__init__(self)
2095
2134
self.tree = tree
2098
2138
class PublicBranchOutOfDate(BzrError):
2166
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.")
2169
2227
class LocalRequiresBoundBranch(BzrError):
2171
2229
_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
2232
class UnsupportedOperation(BzrError):
2185
2234
_fmt = ("The method %(mname)s is not supported on"
2245
2294
self.text = text
2248
class MalformedHeader(BadBundle):
2297
class MalformedHeader(BadBundle):
2250
2299
_fmt = "Malformed bzr revision-bundle header: %(text)r"
2253
class MalformedPatches(BadBundle):
2302
class MalformedPatches(BadBundle):
2255
2304
_fmt = "Malformed patches in bzr revision-bundle: %(text)r"
2258
class MalformedFooter(BadBundle):
2307
class MalformedFooter(BadBundle):
2260
2309
_fmt = "Malformed footer in bzr revision-bundle: %(text)r"
2263
2312
class UnsupportedEOLMarker(BadBundle):
2265
_fmt = "End of line marker was not \\n in bzr revision-bundle"
2314
_fmt = "End of line marker was not \\n in bzr revision-bundle"
2267
2316
def __init__(self):
2268
# XXX: BadBundle's constructor assumes there's explanatory text,
2317
# XXX: BadBundle's constructor assumes there's explanatory text,
2269
2318
# but for this there is not
2270
2319
BzrError.__init__(self)
2273
2322
class IncompatibleBundleFormat(BzrError):
2275
2324
_fmt = "Bundle format %(bundle_format)s is incompatible with %(other)s"
2277
2326
def __init__(self, bundle_format, other):
2528
2569
self.branch = branch
2572
class InvalidLineInBugsProperty(BzrError):
2574
_fmt = ("Invalid line in bugs property: '%(line)s'")
2576
def __init__(self, line):
2580
class InvalidBugStatus(BzrError):
2582
_fmt = ("Invalid bug status: '%(status)s'")
2584
def __init__(self, status):
2585
self.status = status
2531
2588
class UnexpectedSmartServerResponse(BzrError):
2533
2590
_fmt = "Could not understand response from smart server: %(response_tuple)r"
2698
2755
def __init__(self, bzrdir):
2699
2756
import bzrlib.urlutils as urlutils
2700
display_url = urlutils.unescape_for_display(bzrdir.root_transport.base,
2757
display_url = urlutils.unescape_for_display(bzrdir.user_url,
2702
2759
BzrError.__init__(self, bzrdir=bzrdir, display_url=display_url)
2769
2826
class UncommittedChanges(BzrError):
2771
_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')
2773
def __init__(self, tree):
2831
def __init__(self, tree, more=None):
2774
2836
import bzrlib.urlutils as urlutils
2775
2837
display_url = urlutils.unescape_for_display(
2776
tree.bzrdir.root_transport.base, 'ascii')
2777
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)
2780
2842
class MissingTemplateVariable(BzrError):
2817
2879
class CommandAvailableInPlugin(StandardError):
2819
2881
internal_error = False
2821
2883
def __init__(self, cmd_name, plugin_metadata, provider):
2823
2885
self.plugin_metadata = plugin_metadata
2824
2886
self.cmd_name = cmd_name
2825
2887
self.provider = provider
2827
2889
def __str__(self):
2829
_fmt = ('"%s" is not a standard bzr command. \n'
2891
_fmt = ('"%s" is not a standard bzr command. \n'
2830
2892
'However, the following official plugin provides this command: %s\n'
2831
2893
'You can install it by going to: %s'
2832
% (self.cmd_name, self.plugin_metadata['name'],
2894
% (self.cmd_name, self.plugin_metadata['name'],
2833
2895
self.plugin_metadata['url']))
2838
2900
class NoPluginAvailable(BzrError):
2842
class NotATerminal(BzrError):
2844
_fmt = 'Unable to ask for a password without real terminal.'
2847
2904
class UnableEncodePath(BzrError):
2891
2948
_fmt = 'Cannot bind address "%(host)s:%(port)i": %(orig_error)s.'
2893
2950
def __init__(self, host, port, orig_error):
2951
# nb: in python2.4 socket.error doesn't have a useful repr
2894
2952
BzrError.__init__(self, host=host, port=port,
2895
orig_error=orig_error[1])
2953
orig_error=repr(orig_error.args))
2898
2956
class UnknownRules(BzrError):
2906
2964
class HookFailed(BzrError):
2907
2965
"""Raised when a pre_change_branch_tip hook function fails anything other
2908
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.
2911
2972
_fmt = ("Hook '%(hook_name)s' during %(hook_stage)s failed:\n"
2912
2973
"%(traceback_text)s%(exc_value)s")
2914
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)
2915
2979
import traceback
2916
2980
self.hook_stage = hook_stage
2917
2981
self.hook_name = hook_name
2966
3038
def __init__(self, format, url):
2967
3039
BzrError.__init__(self, format=format, url=url)
3042
class NoSuchView(BzrError):
3043
"""A view does not exist.
3046
_fmt = u"No such view: %(view_name)s."
3048
def __init__(self, view_name):
3049
self.view_name = view_name
3052
class ViewsNotSupported(BzrError):
3053
"""Views are not supported by a tree format.
3056
_fmt = ("Views are not supported by %(tree)s;"
3057
" use 'bzr upgrade' to change your tree to a later format.")
3059
def __init__(self, tree):
3063
class FileOutsideView(BzrError):
3065
_fmt = ('Specified file "%(file_name)s" is outside the current view: '
3068
def __init__(self, file_name, view_files):
3069
self.file_name = file_name
3070
self.view_str = ", ".join(view_files)
3073
class UnresumableWriteGroup(BzrError):
3075
_fmt = ("Repository %(repository)s cannot resume write group "
3076
"%(write_groups)r: %(reason)s")
3078
internal_error = True
3080
def __init__(self, repository, write_groups, reason):
3081
self.repository = repository
3082
self.write_groups = write_groups
3083
self.reason = reason
3086
class UnsuspendableWriteGroup(BzrError):
3088
_fmt = ("Repository %(repository)s cannot suspend a write group.")
3090
internal_error = True
3092
def __init__(self, repository):
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