~abentley/bzrtools/bzrtools.dev

« back to all changes in this revision

Viewing changes to errors.py

  • Committer: Aaron Bentley
  • Date: 2011-01-26 01:11:59 UTC
  • Revision ID: aaron@aaronbentley.com-20110126011159-xsh6z4n8bgxy0k9k
Ignore the_kraken changelogs.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
# Copyright (C) 2005 Aaron Bentley, 2006 Michael Ellerman
2
 
# <aaron.bentley@utoronto.ca>
 
2
# <aaron@aaronbentley.com>
3
3
#
4
4
#    This program is free software; you can redistribute it and/or modify
5
5
#    it under the terms of the GNU General Public License as published by
15
15
#    along with this program; if not, write to the Free Software
16
16
#    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
17
17
 
18
 
class NoPyBaz(Exception):
19
 
    def __init__(self):
20
 
        Exception.__init__(self, "PyBaz is not installed.")
 
18
import os
 
19
 
21
20
try:
22
21
    from bzrlib.errors import BzrCommandError as CommandError
 
22
    from bzrlib.errors import BzrError
23
23
except ImportError:
24
24
    class CommandError(Exception):
25
25
        pass
26
26
 
27
 
class PatchFailed(Exception):
28
 
    """Failed applying patch!"""
 
27
class PatchFailed(BzrError):
 
28
 
 
29
    _fmt = """Patch application failed"""
 
30
 
 
31
 
 
32
class PatchInvokeError(BzrError):
 
33
 
 
34
    _fmt = """Error invoking patch: %(errstr)s%(stderr)s"""
 
35
    internal_error = False
 
36
 
 
37
    def __init__(self, e, stderr=''):
 
38
        self.exception = e
 
39
        self.errstr = os.strerror(e.errno)
 
40
        self.stderr = '\n' + stderr
 
41
 
 
42
 
 
43
class NoColor(Exception):
 
44
    """Color not available on this terminal."""
 
45
 
 
46
 
 
47
class NoBzrtoolsColor(Exception):
 
48
    """Bzrtools is required for color display"""
 
49
 
29
50
 
30
51
class NotCheckout(CommandError):
31
52
    """Specified path is not a checkout."""
40
61
class ParentMissingRevisions(CommandError):
41
62
    """The parent branch is missing revisions."""
42
63
    def __init__(self, parent):
43
 
        CommandError.__init__(self, 
44
 
            "The parent branch %s is missing revisions from this branch." % 
 
64
        CommandError.__init__(self,
 
65
            "The parent branch %s is missing revisions from this branch." %
45
66
            parent)
46
67
        self.parent = parent
47
68
 
49
70
    def __init__(self):
50
71
        CommandError.__init__(self, "There is no parent, so deleting the"
51
72
                                    " branch could destroy data.")
 
73
 
 
74
class ChangedBinaryFiles(BzrError):
 
75
 
 
76
    _fmt = 'Changes involve binary files.'
 
77
 
 
78
 
 
79
class NoConflictFiles(CommandError):
 
80
 
 
81
    _fmt = '%(base_name)s does not exist and there are no pending merges.'
 
82
 
 
83
    def __init__(self, base_name):
 
84
        CommandError.__init__(self, base_name=base_name)