~abentley/bzrtools/bzrtools.dev

« back to all changes in this revision

Viewing changes to errors.py

  • Committer: Aaron Bentley
  • Date: 2006-12-04 14:32:43 UTC
  • Revision ID: abentley@panoramicfeedback.com-20061204143243-i28ph41mdgbsofev
Fixed handling of pipe errors when writing to patch

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
# Copyright (C) 2005 Aaron Bentley, 2006 Michael Ellerman
2
 
# <aaron@aaronbentley.com>
 
2
# <aaron.bentley@utoronto.ca>
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.")
20
23
try:
21
24
    from bzrlib.errors import BzrCommandError as CommandError
22
25
    from bzrlib.errors import BzrError
24
27
    class CommandError(Exception):
25
28
        pass
26
29
 
27
 
class PatchFailed(BzrError):
28
 
 
29
 
    _fmt = """Patch application failed"""
 
30
class PatchFailed(Exception):
 
31
    """Failed applying patch!"""
30
32
 
31
33
 
32
34
class PatchInvokeError(BzrError):
33
35
 
34
 
    _fmt = """Error invoking patch: %(errstr)s%(stderr)s"""
 
36
    _fmt = """Error invoking patch: %(errstr)s\n%(stderr)s"""
35
37
    internal_error = False
36
38
 
37
 
    def __init__(self, e, stderr=''):
 
39
    def __init__(self, e, stderr):
38
40
        self.exception = e
39
41
        self.errstr = os.strerror(e.errno)
40
 
        self.stderr = '\n' + stderr
 
42
        self.stderr = stderr
41
43
 
42
44
 
43
45
class NoColor(Exception):
61
63
class ParentMissingRevisions(CommandError):
62
64
    """The parent branch is missing revisions."""
63
65
    def __init__(self, parent):
64
 
        CommandError.__init__(self,
65
 
            "The parent branch %s is missing revisions from this branch." %
 
66
        CommandError.__init__(self, 
 
67
            "The parent branch %s is missing revisions from this branch." % 
66
68
            parent)
67
69
        self.parent = parent
68
70
 
70
72
    def __init__(self):
71
73
        CommandError.__init__(self, "There is no parent, so deleting the"
72
74
                                    " 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)