1791
2452
self.extra = ''
1794
class InvalidImportLine(BzrError):
2455
class InvalidImportLine(InternalBzrError):
1796
2457
_fmt = "Not a valid import statement: %(msg)\n%(text)s"
1798
internal_error = True
1800
2459
def __init__(self, text, msg):
1801
2460
BzrError.__init__(self)
1802
2461
self.text = text
1806
class ImportNameCollision(BzrError):
1808
_fmt = "Tried to import an object to the same name as an existing object. %(name)s"
1810
internal_error = True
1812
def __init__(self, name):
1813
BzrError.__init__(self)
2465
class ImportNameCollision(InternalBzrError):
2467
_fmt = ("Tried to import an object to the same name as"
2468
" an existing object. %(name)s")
2470
def __init__(self, name):
2471
BzrError.__init__(self)
2475
class NotAMergeDirective(BzrError):
2476
"""File starting with %(firstline)r is not a merge directive"""
2477
def __init__(self, firstline):
2478
BzrError.__init__(self, firstline=firstline)
2481
class NoMergeSource(BzrError):
2482
"""Raise if no merge source was specified for a merge directive"""
2484
_fmt = "A merge directive must provide either a bundle or a public"\
2488
class IllegalMergeDirectivePayload(BzrError):
2489
"""A merge directive contained something other than a patch or bundle"""
2491
_fmt = "Bad merge directive payload %(start)r"
2493
def __init__(self, start):
2498
class PatchVerificationFailed(BzrError):
2499
"""A patch from a merge directive could not be verified"""
2501
_fmt = "Preview patch does not match requested changes."
2504
class PatchMissing(BzrError):
2505
"""Raise a patch type was specified but no patch supplied"""
2507
_fmt = "Patch_type was %(patch_type)s, but no patch was supplied."
2509
def __init__(self, patch_type):
2510
BzrError.__init__(self)
2511
self.patch_type = patch_type
2514
class TargetNotBranch(BzrError):
2515
"""A merge directive's target branch is required, but isn't a branch"""
2517
_fmt = ("Your branch does not have all of the revisions required in "
2518
"order to merge this merge directive and the target "
2519
"location specified in the merge directive is not a branch: "
2522
def __init__(self, location):
2523
BzrError.__init__(self)
2524
self.location = location
2527
class UnsupportedInventoryKind(BzrError):
2529
_fmt = """Unsupported entry kind %(kind)s"""
2531
def __init__(self, kind):
2535
class BadSubsumeSource(BzrError):
2537
_fmt = "Can't subsume %(other_tree)s into %(tree)s. %(reason)s"
2539
def __init__(self, tree, other_tree, reason):
2541
self.other_tree = other_tree
2542
self.reason = reason
2545
class SubsumeTargetNeedsUpgrade(BzrError):
2547
_fmt = """Subsume target %(other_tree)s needs to be upgraded."""
2549
def __init__(self, other_tree):
2550
self.other_tree = other_tree
2553
class BadReferenceTarget(InternalBzrError):
2555
_fmt = "Can't add reference to %(other_tree)s into %(tree)s." \
2558
def __init__(self, tree, other_tree, reason):
2560
self.other_tree = other_tree
2561
self.reason = reason
2564
class NoSuchTag(BzrError):
2566
_fmt = "No such tag: %(tag_name)s"
2568
def __init__(self, tag_name):
2569
self.tag_name = tag_name
2572
class TagsNotSupported(BzrError):
2574
_fmt = ("Tags not supported by %(branch)s;"
2575
" you may be able to use bzr upgrade.")
2577
def __init__(self, branch):
2578
self.branch = branch
2581
class TagAlreadyExists(BzrError):
2583
_fmt = "Tag %(tag_name)s already exists."
2585
def __init__(self, tag_name):
2586
self.tag_name = tag_name
2589
class MalformedBugIdentifier(BzrError):
2591
_fmt = ('Did not understand bug identifier %(bug_id)s: %(reason)s. '
2592
'See "bzr help bugs" for more information on this feature.')
2594
def __init__(self, bug_id, reason):
2595
self.bug_id = bug_id
2596
self.reason = reason
2599
class InvalidBugTrackerURL(BzrError):
2601
_fmt = ("The URL for bug tracker \"%(abbreviation)s\" doesn't "
2602
"contain {id}: %(url)s")
2604
def __init__(self, abbreviation, url):
2605
self.abbreviation = abbreviation
2609
class UnknownBugTrackerAbbreviation(BzrError):
2611
_fmt = ("Cannot find registered bug tracker called %(abbreviation)s "
2614
def __init__(self, abbreviation, branch):
2615
self.abbreviation = abbreviation
2616
self.branch = branch
2619
class InvalidLineInBugsProperty(BzrError):
2621
_fmt = ("Invalid line in bugs property: '%(line)s'")
2623
def __init__(self, line):
2627
class InvalidBugStatus(BzrError):
2629
_fmt = ("Invalid bug status: '%(status)s'")
2631
def __init__(self, status):
2632
self.status = status
2635
class UnexpectedSmartServerResponse(BzrError):
2637
_fmt = "Could not understand response from smart server: %(response_tuple)r"
2639
def __init__(self, response_tuple):
2640
self.response_tuple = response_tuple
2643
class ErrorFromSmartServer(BzrError):
2644
"""An error was received from a smart server.
2646
:seealso: UnknownErrorFromSmartServer
2649
_fmt = "Error received from smart server: %(error_tuple)r"
2651
internal_error = True
2653
def __init__(self, error_tuple):
2654
self.error_tuple = error_tuple
2656
self.error_verb = error_tuple[0]
2658
self.error_verb = None
2659
self.error_args = error_tuple[1:]
2662
class UnknownErrorFromSmartServer(BzrError):
2663
"""An ErrorFromSmartServer could not be translated into a typical bzrlib
2666
This is distinct from ErrorFromSmartServer so that it is possible to
2667
distinguish between the following two cases:
2668
- ErrorFromSmartServer was uncaught. This is logic error in the client
2669
and so should provoke a traceback to the user.
2670
- ErrorFromSmartServer was caught but its error_tuple could not be
2671
translated. This is probably because the server sent us garbage, and
2672
should not provoke a traceback.
2675
_fmt = "Server sent an unexpected error: %(error_tuple)r"
2677
internal_error = False
2679
def __init__(self, error_from_smart_server):
2682
:param error_from_smart_server: An ErrorFromSmartServer instance.
2684
self.error_from_smart_server = error_from_smart_server
2685
self.error_tuple = error_from_smart_server.error_tuple
2688
class ContainerError(BzrError):
2689
"""Base class of container errors."""
2692
class UnknownContainerFormatError(ContainerError):
2694
_fmt = "Unrecognised container format: %(container_format)r"
2696
def __init__(self, container_format):
2697
self.container_format = container_format
2700
class UnexpectedEndOfContainerError(ContainerError):
2702
_fmt = "Unexpected end of container stream"
2705
class UnknownRecordTypeError(ContainerError):
2707
_fmt = "Unknown record type: %(record_type)r"
2709
def __init__(self, record_type):
2710
self.record_type = record_type
2713
class InvalidRecordError(ContainerError):
2715
_fmt = "Invalid record: %(reason)s"
2717
def __init__(self, reason):
2718
self.reason = reason
2721
class ContainerHasExcessDataError(ContainerError):
2723
_fmt = "Container has data after end marker: %(excess)r"
2725
def __init__(self, excess):
2726
self.excess = excess
2729
class DuplicateRecordNameError(ContainerError):
2731
_fmt = "Container has multiple records with the same name: %(name)s"
2733
def __init__(self, name):
2737
class NoDestinationAddress(InternalBzrError):
2739
_fmt = "Message does not have a destination address."
2742
class RepositoryDataStreamError(BzrError):
2744
_fmt = "Corrupt or incompatible data stream: %(reason)s"
2746
def __init__(self, reason):
2747
self.reason = reason
2750
class SMTPError(BzrError):
2752
_fmt = "SMTP error: %(error)s"
2754
def __init__(self, error):
2758
class NoMessageSupplied(BzrError):
2760
_fmt = "No message supplied."
2763
class NoMailAddressSpecified(BzrError):
2765
_fmt = "No mail-to address (--mail-to) or output (-o) specified."
2768
class UnknownMailClient(BzrError):
2770
_fmt = "Unknown mail client: %(mail_client)s"
2772
def __init__(self, mail_client):
2773
BzrError.__init__(self, mail_client=mail_client)
2776
class MailClientNotFound(BzrError):
2778
_fmt = "Unable to find mail client with the following names:"\
2779
" %(mail_command_list_string)s"
2781
def __init__(self, mail_command_list):
2782
mail_command_list_string = ', '.join(mail_command_list)
2783
BzrError.__init__(self, mail_command_list=mail_command_list,
2784
mail_command_list_string=mail_command_list_string)
2786
class SMTPConnectionRefused(SMTPError):
2788
_fmt = "SMTP connection to %(host)s refused"
2790
def __init__(self, error, host):
2795
class DefaultSMTPConnectionRefused(SMTPConnectionRefused):
2797
_fmt = "Please specify smtp_server. No server at default %(host)s."
2800
class BzrDirError(BzrError):
2802
def __init__(self, bzrdir):
2803
import bzrlib.urlutils as urlutils
2804
display_url = urlutils.unescape_for_display(bzrdir.user_url,
2806
BzrError.__init__(self, bzrdir=bzrdir, display_url=display_url)
2809
class UnsyncedBranches(BzrDirError):
2811
_fmt = ("'%(display_url)s' is not in sync with %(target_url)s. See"
2812
" bzr help sync-for-reconfigure.")
2814
def __init__(self, bzrdir, target_branch):
2815
BzrDirError.__init__(self, bzrdir)
2816
import bzrlib.urlutils as urlutils
2817
self.target_url = urlutils.unescape_for_display(target_branch.base,
2821
class AlreadyBranch(BzrDirError):
2823
_fmt = "'%(display_url)s' is already a branch."
2826
class AlreadyTree(BzrDirError):
2828
_fmt = "'%(display_url)s' is already a tree."
2831
class AlreadyCheckout(BzrDirError):
2833
_fmt = "'%(display_url)s' is already a checkout."
2836
class AlreadyLightweightCheckout(BzrDirError):
2838
_fmt = "'%(display_url)s' is already a lightweight checkout."
2841
class AlreadyUsingShared(BzrDirError):
2843
_fmt = "'%(display_url)s' is already using a shared repository."
2846
class AlreadyStandalone(BzrDirError):
2848
_fmt = "'%(display_url)s' is already standalone."
2851
class AlreadyWithTrees(BzrDirError):
2853
_fmt = ("Shared repository '%(display_url)s' already creates "
2857
class AlreadyWithNoTrees(BzrDirError):
2859
_fmt = ("Shared repository '%(display_url)s' already doesn't create "
2863
class ReconfigurationNotSupported(BzrDirError):
2865
_fmt = "Requested reconfiguration of '%(display_url)s' is not supported."
2868
class NoBindLocation(BzrDirError):
2870
_fmt = "No location could be found to bind to at %(display_url)s."
2873
class UncommittedChanges(BzrError):
2875
_fmt = ('Working tree "%(display_url)s" has uncommitted changes'
2876
' (See bzr status).%(more)s')
2878
def __init__(self, tree, more=None):
2883
import bzrlib.urlutils as urlutils
2884
user_url = getattr(tree, "user_url", None)
2885
if user_url is None:
2886
display_url = str(tree)
2888
display_url = urlutils.unescape_for_display(user_url, 'ascii')
2889
BzrError.__init__(self, tree=tree, display_url=display_url, more=more)
2892
class ShelvedChanges(UncommittedChanges):
2894
_fmt = ('Working tree "%(display_url)s" has shelved changes'
2895
' (See bzr shelve --list).%(more)s')
2898
class MissingTemplateVariable(BzrError):
2900
_fmt = 'Variable {%(name)s} is not available.'
2902
def __init__(self, name):
2906
class NoTemplate(BzrError):
2908
_fmt = 'No template specified.'
2911
class UnableCreateSymlink(BzrError):
2913
_fmt = 'Unable to create symlink %(path_str)son this platform'
2915
def __init__(self, path=None):
2919
path_str = repr(str(path))
2920
except UnicodeEncodeError:
2921
path_str = repr(path)
2923
self.path_str = path_str
2926
class UnsupportedTimezoneFormat(BzrError):
2928
_fmt = ('Unsupported timezone format "%(timezone)s", '
2929
'options are "utc", "original", "local".')
2931
def __init__(self, timezone):
2932
self.timezone = timezone
2935
class CommandAvailableInPlugin(StandardError):
2937
internal_error = False
2939
def __init__(self, cmd_name, plugin_metadata, provider):
2941
self.plugin_metadata = plugin_metadata
2942
self.cmd_name = cmd_name
2943
self.provider = provider
2947
_fmt = ('"%s" is not a standard bzr command. \n'
2948
'However, the following official plugin provides this command: %s\n'
2949
'You can install it by going to: %s'
2950
% (self.cmd_name, self.plugin_metadata['name'],
2951
self.plugin_metadata['url']))
2956
class NoPluginAvailable(BzrError):
2960
class UnableEncodePath(BzrError):
2962
_fmt = ('Unable to encode %(kind)s path %(path)r in '
2963
'user encoding %(user_encoding)s')
2965
def __init__(self, path, kind):
2966
from bzrlib.osutils import get_user_encoding
2969
self.user_encoding = osutils.get_user_encoding()
2972
class NoSuchConfig(BzrError):
2974
_fmt = ('The "%(config_id)s" configuration does not exist.')
2976
def __init__(self, config_id):
2977
BzrError.__init__(self, config_id=config_id)
2980
class NoSuchConfigOption(BzrError):
2982
_fmt = ('The "%(option_name)s" configuration option does not exist.')
2984
def __init__(self, option_name):
2985
BzrError.__init__(self, option_name=option_name)
2988
class NoSuchAlias(BzrError):
2990
_fmt = ('The alias "%(alias_name)s" does not exist.')
2992
def __init__(self, alias_name):
2993
BzrError.__init__(self, alias_name=alias_name)
2996
class DirectoryLookupFailure(BzrError):
2997
"""Base type for lookup errors."""
3002
class InvalidLocationAlias(DirectoryLookupFailure):
3004
_fmt = '"%(alias_name)s" is not a valid location alias.'
3006
def __init__(self, alias_name):
3007
DirectoryLookupFailure.__init__(self, alias_name=alias_name)
3010
class UnsetLocationAlias(DirectoryLookupFailure):
3012
_fmt = 'No %(alias_name)s location assigned.'
3014
def __init__(self, alias_name):
3015
DirectoryLookupFailure.__init__(self, alias_name=alias_name[1:])
3018
class CannotBindAddress(BzrError):
3020
_fmt = 'Cannot bind address "%(host)s:%(port)i": %(orig_error)s.'
3022
def __init__(self, host, port, orig_error):
3023
# nb: in python2.4 socket.error doesn't have a useful repr
3024
BzrError.__init__(self, host=host, port=port,
3025
orig_error=repr(orig_error.args))
3028
class UnknownRules(BzrError):
3030
_fmt = ('Unknown rules detected: %(unknowns_str)s.')
3032
def __init__(self, unknowns):
3033
BzrError.__init__(self, unknowns_str=", ".join(unknowns))
3036
class HookFailed(BzrError):
3037
"""Raised when a pre_change_branch_tip hook function fails anything other
3038
than TipChangeRejected.
3040
Note that this exception is no longer raised, and the import is only left
3041
to be nice to code which might catch it in a plugin.
3044
_fmt = ("Hook '%(hook_name)s' during %(hook_stage)s failed:\n"
3045
"%(traceback_text)s%(exc_value)s")
3047
def __init__(self, hook_stage, hook_name, exc_info, warn=True):
3049
symbol_versioning.warn("BzrError HookFailed has been deprecated "
3050
"as of bzrlib 2.1.", DeprecationWarning, stacklevel=2)
3052
self.hook_stage = hook_stage
3053
self.hook_name = hook_name
3054
self.exc_info = exc_info
3055
self.exc_type = exc_info[0]
3056
self.exc_value = exc_info[1]
3057
self.exc_tb = exc_info[2]
3058
self.traceback_text = ''.join(traceback.format_tb(self.exc_tb))
3061
class TipChangeRejected(BzrError):
3062
"""A pre_change_branch_tip hook function may raise this to cleanly and
3063
explicitly abort a change to a branch tip.
3066
_fmt = u"Tip change rejected: %(msg)s"
3068
def __init__(self, msg):
3072
class ShelfCorrupt(BzrError):
3074
_fmt = "Shelf corrupt."
3077
class NoSuchShelfId(BzrError):
3079
_fmt = 'No changes are shelved with id "%(shelf_id)d".'
3081
def __init__(self, shelf_id):
3082
BzrError.__init__(self, shelf_id=shelf_id)
3085
class InvalidShelfId(BzrError):
3087
_fmt = '"%(invalid_id)s" is not a valid shelf id, try a number instead.'
3089
def __init__(self, invalid_id):
3090
BzrError.__init__(self, invalid_id=invalid_id)
3093
class JailBreak(BzrError):
3095
_fmt = "An attempt to access a url outside the server jail was made: '%(url)s'."
3097
def __init__(self, url):
3098
BzrError.__init__(self, url=url)
3101
class UserAbort(BzrError):
3103
_fmt = 'The user aborted the operation.'
3106
class MustHaveWorkingTree(BzrError):
3108
_fmt = ("Branching '%(url)s'(%(format)s) must create a working tree.")
3110
def __init__(self, format, url):
3111
BzrError.__init__(self, format=format, url=url)
3114
class NoSuchView(BzrError):
3115
"""A view does not exist.
3118
_fmt = u"No such view: %(view_name)s."
3120
def __init__(self, view_name):
3121
self.view_name = view_name
3124
class ViewsNotSupported(BzrError):
3125
"""Views are not supported by a tree format.
3128
_fmt = ("Views are not supported by %(tree)s;"
3129
" use 'bzr upgrade' to change your tree to a later format.")
3131
def __init__(self, tree):
3135
class FileOutsideView(BzrError):
3137
_fmt = ('Specified file "%(file_name)s" is outside the current view: '
3140
def __init__(self, file_name, view_files):
3141
self.file_name = file_name
3142
self.view_str = ", ".join(view_files)
3145
class UnresumableWriteGroup(BzrError):
3147
_fmt = ("Repository %(repository)s cannot resume write group "
3148
"%(write_groups)r: %(reason)s")
3150
internal_error = True
3152
def __init__(self, repository, write_groups, reason):
3153
self.repository = repository
3154
self.write_groups = write_groups
3155
self.reason = reason
3158
class UnsuspendableWriteGroup(BzrError):
3160
_fmt = ("Repository %(repository)s cannot suspend a write group.")
3162
internal_error = True
3164
def __init__(self, repository):
3165
self.repository = repository
3168
class LossyPushToSameVCS(BzrError):
3170
_fmt = ("Lossy push not possible between %(source_branch)r and "
3171
"%(target_branch)r that are in the same VCS.")
3173
internal_error = True
3175
def __init__(self, source_branch, target_branch):
3176
self.source_branch = source_branch
3177
self.target_branch = target_branch
3180
class NoRoundtrippingSupport(BzrError):
3182
_fmt = ("Roundtripping is not supported between %(source_branch)r and "
3183
"%(target_branch)r.")
3185
internal_error = True
3187
def __init__(self, source_branch, target_branch):
3188
self.source_branch = source_branch
3189
self.target_branch = target_branch
3192
class FileTimestampUnavailable(BzrError):
3194
_fmt = "The filestamp for %(path)s is not available."
3196
internal_error = True
3198
def __init__(self, path):
3202
class NoColocatedBranchSupport(BzrError):
3204
_fmt = ("%(bzrdir)r does not support co-located branches.")
3206
def __init__(self, bzrdir):
3207
self.bzrdir = bzrdir
3210
class NoWhoami(BzrError):
3212
_fmt = ('Unable to determine your name.\n'
3213
"Please, set your name with the 'whoami' command.\n"
3214
'E.g. bzr whoami "Your Name <name@example.com>"')
3217
class InvalidPattern(BzrError):
3219
_fmt = ('Invalid pattern(s) found. %(msg)s')
3221
def __init__(self, msg):
3225
class RecursiveBind(BzrError):
3227
_fmt = ('Branch "%(branch_url)s" appears to be bound to itself. '
3228
'Please use `bzr unbind` to fix.')
3230
def __init__(self, branch_url):
3231
self.branch_url = branch_url
3234
# FIXME: I would prefer to define the config related exception classes in
3235
# config.py but the lazy import mechanism proscribes this -- vila 20101222
3236
class OptionExpansionLoop(BzrError):
3238
_fmt = 'Loop involving %(refs)r while expanding "%(string)s".'
3240
def __init__(self, string, refs):
3241
self.string = string
3242
self.refs = '->'.join(refs)
3245
class ExpandingUnknownOption(BzrError):
3247
_fmt = 'Option %(name)s is not defined while expanding "%(string)s".'
3249
def __init__(self, name, string):
3251
self.string = string