/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to breezy/git/errors.py

  • Committer: Jelmer Vernooij
  • Date: 2019-06-03 23:48:08 UTC
  • mfrom: (7316 work)
  • mto: This revision was merged to the branch mainline in revision 7328.
  • Revision ID: jelmer@jelmer.uk-20190603234808-15yk5c7054tj8e2b
Merge trunk.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
# Copyright (C) 2007 Canonical Ltd
 
2
# Copyright (C) 2018 Jelmer Vernooij <jelmer@jelmer.uk>
2
3
#
3
4
# This program is free software; you can redistribute it and/or modify
4
5
# it under the terms of the GNU General Public License as published by
12
13
#
13
14
# You should have received a copy of the GNU General Public License
14
15
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
16
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
17
 
17
18
 
18
19
"""A grouping of Exceptions for bzr-git"""
19
20
 
 
21
from __future__ import absolute_import
20
22
 
21
23
from dulwich import errors as git_errors
22
24
 
23
 
from bzrlib import errors as bzr_errors
24
 
 
25
 
 
26
 
class BzrGitError(bzr_errors.BzrError):
 
25
from .. import errors as brz_errors
 
26
 
 
27
 
 
28
class BzrGitError(brz_errors.BzrError):
27
29
    """The base-level exception for bzr-git errors."""
28
30
 
29
31
 
30
32
class NoSuchRef(BzrGitError):
31
33
    """Raised when a ref can not be found."""
32
34
 
33
 
    _fmt = "The ref %(ref)s was not found."
 
35
    _fmt = "The ref %(ref)s was not found in the repository at %(location)s."
34
36
 
35
 
    def __init__(self, ref, present_refs=None):
 
37
    def __init__(self, ref, location, present_refs=None):
36
38
        self.ref = ref
 
39
        self.location = location
37
40
        self.present_refs = present_refs
38
41
 
39
42
 
41
44
    """Convert a Dulwich error to a Bazaar error."""
42
45
 
43
46
    if isinstance(error, git_errors.HangupException):
44
 
        raise bzr_errors.ConnectionReset(error.msg, "")
 
47
        raise brz_errors.ConnectionReset(error.msg, "")
45
48
    raise error
46
49
 
47
50
 
48
 
class NoPushSupport(bzr_errors.BzrError):
49
 
    _fmt = "Push is not yet supported for bzr-git. Try dpush instead."
50
 
 
51
 
 
52
 
class GitSmartRemoteNotSupported(bzr_errors.BzrError):
 
51
class NoPushSupport(brz_errors.BzrError):
 
52
    _fmt = ("Push is not yet supported from %(source)r to %(target)r "
 
53
            "using %(mapping)r for %(revision_id)r. Try dpush instead.")
 
54
 
 
55
    def __init__(self, source, target, mapping, revision_id=None):
 
56
        self.source = source
 
57
        self.target = target
 
58
        self.mapping = mapping
 
59
        self.revision_id = revision_id
 
60
 
 
61
 
 
62
class GitSmartRemoteNotSupported(brz_errors.UnsupportedOperation):
53
63
    _fmt = "This operation is not supported by the Git smart server protocol."
 
64
 
 
65
 
 
66
class UnknownCommitExtra(brz_errors.BzrError):
 
67
    _fmt = "Unknown extra fields in %(object)r: %(fields)r."
 
68
 
 
69
    def __init__(self, object, fields):
 
70
        brz_errors.BzrError.__init__(self)
 
71
        self.object = object
 
72
        self.fields = ",".join(fields)
 
73
 
 
74
 
 
75
class UnknownMercurialCommitExtra(brz_errors.BzrError):
 
76
    _fmt = "Unknown mercurial extra fields in %(object)r: %(fields)r."
 
77
 
 
78
    def __init__(self, object, fields):
 
79
        brz_errors.BzrError.__init__(self)
 
80
        self.object = object
 
81
        self.fields = b",".join(fields)