~bzr-pqm/bzr/bzr.dev

1 by mbp at sourcefrog
import from baz patch-364
1
#! /usr/bin/env python
2
# -*- coding: UTF-8 -*-
3
4
# This program is free software; you can redistribute it and/or modify
5
# it under the terms of the GNU General Public License as published by
6
# the Free Software Foundation; either version 2 of the License, or
7
# (at your option) any later version.
8
9
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
# GNU General Public License for more details.
13
14
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
17
18
19
__copyright__ = "Copyright (C) 2005 Canonical Ltd."
20
__author__ = "Martin Pool <mbp@canonical.com>"
21
22
23
######################################################################
24
# exceptions 
25
class BzrError(StandardError):
1193 by Martin Pool
- better string formatting of BzrErrors with explanation
26
    def __str__(self):
1195 by Martin Pool
- better error display
27
        if len(self.args) == 1:
28
            return self.args[0]
29
        elif len(self.args) == 2:
1193 by Martin Pool
- better string formatting of BzrErrors with explanation
30
            # further explanation or suggestions
31
            return '\n  '.join([self.args[0]] + self.args[1])
32
        else:
33
            return `self.args`
34
1 by mbp at sourcefrog
import from baz patch-364
35
36
class BzrCheckError(BzrError):
37
    pass
38
39
974.1.26 by aaron.bentley at utoronto
merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472
40
class InvalidRevisionNumber(BzrError):
41
    def __str__(self):
42
        return 'invalid revision number: %r' % self.args[0]
43
44
45
class InvalidRevisionId(BzrError):
46
    pass
47
48
329 by Martin Pool
- refactor command functions into command classes
49
class BzrCommandError(BzrError):
50
    # Error from malformed user command
51
    pass
1 by mbp at sourcefrog
import from baz patch-364
52
53
573 by Martin Pool
- new exception NotBranchError
54
class NotBranchError(BzrError):
55
    """Specified path is not in a branch"""
56
    pass
57
58
753 by Martin Pool
- new exception NotVersionedError
59
class NotVersionedError(BzrError):
60
    """Specified object is not versioned."""
61
62
599 by Martin Pool
- better error reporting from smart_add
63
class BadFileKindError(BzrError):
64
    """Specified file is of a kind that cannot be added.
65
66
    (For example a symlink or device file.)"""
67
    pass
68
69
70
class ForbiddenFileError(BzrError):
71
    """Cannot operate on a file because it is a control file."""
72
    pass
73
74
614 by Martin Pool
- unify two defintions of LockError
75
class LockError(Exception):
76
    """All exceptions from the lock/unlock functions should be from
77
    this exception class.  They will be translated as necessary. The
78
    original exception is available as e.original_error
79
    """
80
    def __init__(self, e=None):
81
        self.original_error = e
82
        if e:
83
            Exception.__init__(self, e)
84
        else:
85
            Exception.__init__(self)
882 by Martin Pool
- Optionally raise EmptyCommit if there are no changes. Test for this.
86
87
885 by Martin Pool
- commit command refuses unless something is changed or --unchanged is given
88
class PointlessCommit(Exception):
882 by Martin Pool
- Optionally raise EmptyCommit if there are no changes. Test for this.
89
    """Commit failed because nothing was changed."""
974.1.26 by aaron.bentley at utoronto
merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472
90
91
92
class NoSuchRevision(BzrError):
93
    def __init__(self, branch, revision):
94
        self.branch = branch
95
        self.revision = revision
96
        msg = "Branch %s has no revision %s" % (branch, revision)
97
        BzrError.__init__(self, msg)
98
1034 by Martin Pool
- merge bzrlib.revision.is_ancestor from aaron
99
1192 by Martin Pool
- clean up code for retrieving stored inventories
100
class HistoryMissing(BzrError):
101
    def __init__(self, branch, object_type, object_id):
102
        self.branch = branch
103
        BzrError.__init__(self,
104
                          '%s is missing %s {%s}'
105
                          % (branch, object_type, object_id))
106
107
1105 by Martin Pool
- expose 'find-merge-base' as a new expert command,
108
class UnrelatedBranches(BzrCommandError):
109
    def __init__(self):
110
        msg = "Branches have no common ancestor, and no base revision"\
111
            " specified."
112
        BzrCommandError.__init__(self, msg)
113
114
974.2.7 by aaron.bentley at utoronto
Merged from bzr.24
115
class NotAncestor(BzrError):
116
    def __init__(self, rev_id, not_ancestor_id):
117
        self.rev_id = rev_id
118
        self.not_ancestor_id = not_ancestor_id
119
        msg = "Revision %s is not an ancestor of %s" % (not_ancestor_id, 
120
                                                        rev_id)
121
        BzrError.__init__(self, msg)
974.1.42 by Aaron Bentley
Initial 'intervening revisions' implementation
122
1092.1.42 by Robert Collins
merge from abentley
123
974.1.30 by aaron.bentley at utoronto
Changed copy_multi to permit failure and return a tuple, tested missing required revisions
124
class InstallFailed(BzrError):
125
    def __init__(self, revisions):
126
        self.revisions = revisions
127
        msg = "Could not install revisions:\n%s" % " ,".join(revisions)
128
        BzrError.__init__(self, msg)
1154 by Martin Pool
- fix imports for moved errors
129
130
131
class AmbiguousBase(BzrError):
132
    def __init__(self, bases):
133
        msg = "The correct base is unclear, becase %s are all equally close" %\
134
            ", ".join(bases)
135
        BzrError.__init__(self, msg)
136
        self.bases = bases
137