24
25
class BzrError(StandardError):
28
28
class BzrCheckError(BzrError):
32
class InvalidRevisionNumber(BzrError):
33
def __init__(self, revno):
37
return 'invalid revision number: %r' % self.args[0]
40
class InvalidRevisionId(BzrError):
44
class BzrCommandError(BzrError):
45
# Error from malformed user command
49
class NotBranchError(BzrError):
50
"""Specified path is not in a branch"""
54
class NotVersionedError(BzrError):
55
"""Specified object is not versioned."""
58
class BadFileKindError(BzrError):
59
"""Specified file is of a kind that cannot be added.
61
(For example a symlink or device file.)"""
65
class ForbiddenFileError(BzrError):
66
"""Cannot operate on a file because it is a control file."""
70
class LockError(Exception):
71
"""All exceptions from the lock/unlock functions should be from
72
this exception class. They will be translated as necessary. The
73
original exception is available as e.original_error
75
def __init__(self, e=None):
76
self.original_error = e
78
Exception.__init__(self, e)
80
Exception.__init__(self)
83
class PointlessCommit(Exception):
84
"""Commit failed because nothing was changed."""
87
class NoSuchRevision(BzrError):
88
def __init__(self, branch, revision):
90
self.revision = revision
91
msg = "Branch %s has no revision %s" % (branch, revision)
92
BzrError.__init__(self, msg)
95
class DivergedBranches(BzrError):
96
def __init__(self, branch1, branch2):
97
BzrError.__init__(self, "These branches have diverged.")
98
self.branch1 = branch1
99
self.branch2 = branch2
101
class UnrelatedBranches(BzrCommandError):
103
msg = "Branches have no common ancestor, and no base revision"\
105
BzrCommandError.__init__(self, msg)
107
class NoCommonAncestor(BzrError):
108
def __init__(self, revision_a, revision_b):
109
msg = "Revisions have no common ancestor: %s %s." \
110
% (revision_a, revision_b)
111
BzrError.__init__(self, msg)
113
class NoCommonRoot(BzrError):
114
def __init__(self, revision_a, revision_b):
115
msg = "Revisions are not derived from the same root: %s %s." \
116
% (revision_a, revision_b)
117
BzrError.__init__(self, msg)
119
class NotAncestor(BzrError):
120
def __init__(self, rev_id, not_ancestor_id):
121
msg = "Revision %s is not an ancestor of %s" % (not_ancestor_id,
123
BzrError.__init__(self, msg)
125
self.not_ancestor_id = not_ancestor_id
128
class InstallFailed(BzrError):
129
def __init__(self, revisions):
130
msg = "Could not install revisions:\n%s" % " ,".join(revisions)
131
BzrError.__init__(self, msg)
132
self.revisions = revisions
135
class AmbiguousBase(BzrError):
136
def __init__(self, bases):
137
msg = "The correct base is unclear, becase %s are all equally close" %\
139
BzrError.__init__(self, msg)
142
class NoCommits(BzrError):
143
def __init__(self, branch):
144
msg = "Branch %s has no commits." % branch
145
BzrError.__init__(self, msg)
34
def bailout(msg, explanation=[]):
35
ex = BzrError(msg, explanation)
37
trace._tracefile.write('* raising %s\n' % ex)