~abentley/bzrtools/bzrtools.dev

« back to all changes in this revision

Viewing changes to errors.py

  • Committer: Aaron Bentley
  • Date: 2011-04-12 04:51:37 UTC
  • Revision ID: aaron@aaronbentley.com-20110412045137-ni3eart33v4wnlst
Allow zap --branch --store if no uncommitted changes.

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
17
17
 
18
18
import os
19
19
 
20
 
class NoPyBaz(Exception):
21
 
    def __init__(self):
22
 
        Exception.__init__(self, "PyBaz is not installed.")
23
20
try:
24
21
    from bzrlib.errors import BzrCommandError as CommandError
25
22
    from bzrlib.errors import BzrError
27
24
    class CommandError(Exception):
28
25
        pass
29
26
 
30
 
class PatchFailed(Exception):
31
 
    """Failed applying patch!"""
 
27
class PatchFailed(BzrError):
 
28
 
 
29
    _fmt = """Patch application failed"""
32
30
 
33
31
 
34
32
class PatchInvokeError(BzrError):
35
33
 
36
 
    _fmt = """Error invoking patch: %(errstr)s\n%(stderr)s"""
 
34
    _fmt = """Error invoking patch: %(errstr)s%(stderr)s"""
37
35
    internal_error = False
38
36
 
39
 
    def __init__(self, e, stderr):
 
37
    def __init__(self, e, stderr=''):
40
38
        self.exception = e
41
39
        self.errstr = os.strerror(e.errno)
42
 
        self.stderr = stderr
 
40
        self.stderr = '\n' + stderr
43
41
 
44
42
 
45
43
class NoColor(Exception):
72
70
    def __init__(self):
73
71
        CommandError.__init__(self, "There is no parent, so deleting the"
74
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)