/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 errors.py

  • Committer: Jelmer Vernooij
  • Date: 2018-04-02 14:59:43 UTC
  • mto: (0.200.1913 work)
  • mto: This revision was merged to the branch mainline in revision 6960.
  • Revision ID: jelmer@jelmer.uk-20180402145943-s5jmpbvvf1x42pao
Just don't touch the URL if it's already a valid URL.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2007 Canonical Ltd
 
2
# Copyright (C) 2018 Jelmer Vernooij <jelmer@jelmer.uk>
 
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
17
 
 
18
 
 
19
"""A grouping of Exceptions for bzr-git"""
 
20
 
 
21
from __future__ import absolute_import
 
22
 
 
23
from dulwich import errors as git_errors
 
24
 
 
25
from ... import errors as bzr_errors
 
26
 
 
27
 
 
28
class BzrGitError(bzr_errors.BzrError):
 
29
    """The base-level exception for bzr-git errors."""
 
30
 
 
31
 
 
32
class NoSuchRef(BzrGitError):
 
33
    """Raised when a ref can not be found."""
 
34
 
 
35
    _fmt = "The ref %(ref)s was not found in the repository at %(location)s."
 
36
 
 
37
    def __init__(self, ref, location, present_refs=None):
 
38
        self.ref = ref
 
39
        self.location = location
 
40
        self.present_refs = present_refs
 
41
 
 
42
 
 
43
def convert_dulwich_error(error):
 
44
    """Convert a Dulwich error to a Bazaar error."""
 
45
 
 
46
    if isinstance(error, git_errors.HangupException):
 
47
        raise bzr_errors.ConnectionReset(error.msg, "")
 
48
    raise error
 
49
 
 
50
 
 
51
class NoPushSupport(bzr_errors.BzrError):
 
52
    _fmt = "Push is not yet supported from %(source)r to %(target)r using %(mapping)r for %(revision_id)r. Try dpush instead."
 
53
 
 
54
    def __init__(self, source, target, mapping, revision_id=None):
 
55
        self.source = source
 
56
        self.target = target
 
57
        self.mapping = mapping
 
58
        self.revision_id = revision_id
 
59
 
 
60
 
 
61
class GitSmartRemoteNotSupported(bzr_errors.UnsupportedOperation):
 
62
    _fmt = "This operation is not supported by the Git smart server protocol."
 
63
 
 
64
 
 
65
class UnknownCommitExtra(bzr_errors.BzrError):
 
66
    _fmt = "Unknown extra fields in %(object)r: %(fields)r."
 
67
 
 
68
    def __init__(self, object, fields):
 
69
        bzr_errors.BzrError.__init__(self)
 
70
        self.object = object
 
71
        self.fields = ",".join(fields)
 
72
 
 
73
 
 
74
class UnknownMercurialCommitExtra(bzr_errors.BzrError):
 
75
    _fmt = "Unknown mercurial extra fields in %(object)r: %(fields)r."
 
76
 
 
77
    def __init__(self, object, fields):
 
78
        bzr_errors.BzrError.__init__(self)
 
79
        self.object = object
 
80
        self.fields = ",".join(fields)