25
25
class BzrError(StandardError):
28
29
class BzrCheckError(BzrError):
34
def bailout(msg, explanation=[]):
35
ex = BzrError(msg, explanation)
37
trace._tracefile.write('* raising %s\n' % ex)
33
class InvalidRevisionNumber(BzrError):
34
def __init__(self, revno):
38
return 'invalid revision number: %r' % self.args[0]
41
class InvalidRevisionId(BzrError):
45
class BzrCommandError(BzrError):
46
# Error from malformed user command
50
class NotBranchError(BzrError):
51
"""Specified path is not in a branch"""
55
class NotVersionedError(BzrError):
56
"""Specified object is not versioned."""
59
class BadFileKindError(BzrError):
60
"""Specified file is of a kind that cannot be added.
62
(For example a symlink or device file.)"""
66
class ForbiddenFileError(BzrError):
67
"""Cannot operate on a file because it is a control file."""
71
class LockError(Exception):
72
"""All exceptions from the lock/unlock functions should be from
73
this exception class. They will be translated as necessary. The
74
original exception is available as e.original_error
76
def __init__(self, e=None):
77
self.original_error = e
79
Exception.__init__(self, e)
81
Exception.__init__(self)
84
class PointlessCommit(Exception):
85
"""Commit failed because nothing was changed."""
88
class NoSuchRevision(BzrError):
89
def __init__(self, branch, revision):
91
self.revision = revision
92
msg = "Branch %s has no revision %s" % (branch, revision)
93
BzrError.__init__(self, msg)
96
class DivergedBranches(BzrError):
97
def __init__(self, branch1, branch2):
98
BzrError.__init__(self, "These branches have diverged.")
99
self.branch1 = branch1
100
self.branch2 = branch2
102
class UnrelatedBranches(BzrCommandError):
104
msg = "Branches have no common ancestor, and no base revision"\
106
BzrCommandError.__init__(self, msg)
108
class NoCommonAncestor(BzrError):
109
def __init__(self, revision_a, revision_b):
110
msg = "Revisions have no common ancestor: %s %s." \
111
% (revision_a, revision_b)
112
BzrError.__init__(self, msg)
114
class NoCommonRoot(BzrError):
115
def __init__(self, revision_a, revision_b):
116
msg = "Revisions are not derived from the same root: %s %s." \
117
% (revision_a, revision_b)
118
BzrError.__init__(self, msg)
120
class NotAncestor(BzrError):
121
def __init__(self, rev_id, not_ancestor_id):
122
msg = "Revision %s is not an ancestor of %s" % (not_ancestor_id,
124
BzrError.__init__(self, msg)
126
self.not_ancestor_id = not_ancestor_id
129
class InstallFailed(BzrError):
130
def __init__(self, revisions):
131
msg = "Could not install revisions:\n%s" % " ,".join(revisions)
132
BzrError.__init__(self, msg)
133
self.revisions = revisions
136
class AmbiguousBase(BzrError):
137
def __init__(self, bases):
138
msg = "The correct base is unclear, becase %s are all equally close" %\
140
BzrError.__init__(self, msg)
143
class NoCommits(BzrError):
144
def __init__(self, branch):
145
msg = "Branch %s has no commits." % branch
146
BzrError.__init__(self, msg)