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

  • Committer: Jelmer Vernooij
  • Date: 2020-05-24 00:39:50 UTC
  • mto: This revision was merged to the branch mainline in revision 7504.
  • Revision ID: jelmer@jelmer.uk-20200524003950-bbc545r76vc5yajg
Add github action.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2009 Jelmer Vernooij <jelmer@samba.org>
 
1
# Copyright (C) 2009-2018 Jelmer Vernooij <jelmer@jelmer.uk>
2
2
 
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
5
 
# the Free Software Foundation; either version 3 of the License, or
 
5
# the Free Software Foundation; either version 2 of the License, or
6
6
# (at your option) any later version.
7
 
 
 
7
#
8
8
# This program is distributed in the hope that it will be useful,
9
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
11
# GNU General Public License for more details.
12
 
 
 
12
#
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
16
 
16
17
"""Custom revision specifier for Subversion."""
17
18
 
18
 
from bzrlib.errors import BzrError, InvalidRevisionSpec, NoSuchRevision
19
 
from bzrlib.revisionspec import RevisionSpec, RevisionInfo
20
 
 
21
 
from bzrlib.plugins.git import lazy_check_versions
 
19
# Please note that imports are delayed as much as possible here since
 
20
# if DWIM revspecs are supported this module is imported by __init__.py.
 
21
 
 
22
from ..errors import (
 
23
    InvalidRevisionId,
 
24
    )
 
25
from ..revision import (
 
26
    NULL_REVISION,
 
27
)
 
28
from ..revisionspec import (
 
29
    InvalidRevisionSpec,
 
30
    RevisionInfo,
 
31
    RevisionSpec,
 
32
    )
 
33
 
 
34
 
 
35
def valid_git_sha1(hex):
 
36
    """Check if `hex` is a validly formatted Git SHA1.
 
37
 
 
38
    :param hex: Hex string to validate
 
39
    :return: Boolean
 
40
    """
 
41
    try:
 
42
        int(hex, 16)
 
43
    except ValueError:
 
44
        return False
 
45
    else:
 
46
        return True
 
47
 
22
48
 
23
49
class RevisionSpec_git(RevisionSpec):
24
 
    """Selects a revision using a Subversion revision number."""
25
 
 
26
 
    help_txt = """Selects a revision using a Git revision sha1.
 
50
    """Selects a revision using a Git commit SHA1."""
 
51
 
 
52
    help_txt = """Selects a revision using a Git commit SHA1.
 
53
 
 
54
    Selects a revision using a Git commit SHA1, short or long.
 
55
 
 
56
    This works for both native Git repositories and Git revisions
 
57
    imported into Bazaar repositories.
27
58
    """
28
 
    
 
59
 
29
60
    prefix = 'git:'
 
61
    wants_revision_history = False
 
62
 
 
63
    def _lookup_git_sha1(self, branch, sha1):
 
64
        from .errors import (
 
65
            GitSmartRemoteNotSupported,
 
66
            )
 
67
        from .mapping import (
 
68
            default_mapping,
 
69
            )
 
70
 
 
71
        bzr_revid = getattr(branch.repository, "lookup_foreign_revision_id",
 
72
                            default_mapping.revision_id_foreign_to_bzr)(sha1)
 
73
        try:
 
74
            if branch.repository.has_revision(bzr_revid):
 
75
                return RevisionInfo.from_revision_id(branch, bzr_revid)
 
76
        except GitSmartRemoteNotSupported:
 
77
            return RevisionInfo(branch, None, bzr_revid)
 
78
        raise InvalidRevisionSpec(self.user_spec, branch)
 
79
 
 
80
    def __nonzero__(self):
 
81
        # The default implementation uses branch.repository.has_revision()
 
82
        if self.rev_id is None:
 
83
            return False
 
84
        if self.rev_id == NULL_REVISION:
 
85
            return False
 
86
        return True
 
87
 
 
88
    def _find_short_git_sha1(self, branch, sha1):
 
89
        from .mapping import (
 
90
            ForeignGit,
 
91
            mapping_registry,
 
92
            )
 
93
        parse_revid = getattr(branch.repository, "lookup_bzr_revision_id",
 
94
                              mapping_registry.parse_revision_id)
 
95
        with branch.repository.lock_read():
 
96
            graph = branch.repository.get_graph()
 
97
            for revid, _ in graph.iter_ancestry([branch.last_revision()]):
 
98
                if revid == NULL_REVISION:
 
99
                    continue
 
100
                try:
 
101
                    foreign_revid, mapping = parse_revid(revid)
 
102
                except InvalidRevisionId:
 
103
                    continue
 
104
                if not isinstance(mapping.vcs, ForeignGit):
 
105
                    continue
 
106
                if foreign_revid.startswith(sha1):
 
107
                    return RevisionInfo.from_revision_id(branch, revid)
 
108
            raise InvalidRevisionSpec(self.user_spec, branch)
30
109
 
31
110
    def _match_on(self, branch, revs):
 
111
        loc = self.spec.find(':')
 
112
        git_sha1 = self.spec[loc + 1:].encode("utf-8")
 
113
        if (len(git_sha1) > 40 or len(git_sha1) < 4 or
 
114
                not valid_git_sha1(git_sha1)):
 
115
            raise InvalidRevisionSpec(self.user_spec, branch)
 
116
        from . import (
 
117
            lazy_check_versions,
 
118
            )
32
119
        lazy_check_versions()
33
 
        loc = self.spec.find(':')
34
 
        git_sha1 = self.spec[loc+1:].encode("utf-8")
35
 
        bzr_revid = branch.mapping.revision_id_foreign_to_bzr(git_sha1)
36
 
        if branch.repository.has_revision(bzr_revid):
37
 
            history = list(branch.repository.iter_reverse_revision_history(bzr_revid))
38
 
            history.reverse()
39
 
            return RevisionInfo.from_revision_id(branch, bzr_revid, history)
40
 
        raise InvalidRevisionSpec(self.user_spec, branch)
 
120
        if len(git_sha1) == 40:
 
121
            return self._lookup_git_sha1(branch, git_sha1)
 
122
        else:
 
123
            return self._find_short_git_sha1(branch, git_sha1)
41
124
 
42
125
    def needs_branch(self):
43
126
        return True