/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: Gustav Hartvigsson
  • Date: 2021-01-09 21:36:27 UTC
  • Revision ID: gustav.hartvigsson@gmail.com-20210109213627-h1xwcutzy9m7a99b
Added 'Case Preserving Working Tree Use Cases' from Canonical Wiki

* Addod a page from the Canonical Bazaar wiki
  with information on the scmeatics of case
  perserving filesystems an a case insensitive
  filesystem works.
  
  * Needs re-work, but this will do as it is the
    same inforamoton as what was on the linked
    page in the currint documentation.

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 bzr_revid
 
76
        except GitSmartRemoteNotSupported:
 
77
            return 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
        def matches_revid(revid):
 
96
            if revid == NULL_REVISION:
 
97
                return False
 
98
            try:
 
99
                foreign_revid, mapping = parse_revid(revid)
 
100
            except InvalidRevisionId:
 
101
                return False
 
102
            if not isinstance(mapping.vcs, ForeignGit):
 
103
                return False
 
104
            return foreign_revid.startswith(sha1)
 
105
        with branch.repository.lock_read():
 
106
            graph = branch.repository.get_graph()
 
107
            last_revid = branch.last_revision()
 
108
            if matches_revid(last_revid):
 
109
                return last_revid
 
110
            for revid, _ in graph.iter_ancestry([last_revid]):
 
111
                if matches_revid(revid):
 
112
                    return revid
 
113
            raise InvalidRevisionSpec(self.user_spec, branch)
 
114
 
 
115
    def _as_revision_id(self, context_branch):
 
116
        loc = self.spec.find(':')
 
117
        git_sha1 = self.spec[loc + 1:].encode("utf-8")
 
118
        if (len(git_sha1) > 40 or len(git_sha1) < 4 or
 
119
                not valid_git_sha1(git_sha1)):
 
120
            raise InvalidRevisionSpec(self.user_spec, context_branch)
 
121
        from . import (
 
122
            lazy_check_versions,
 
123
            )
 
124
        lazy_check_versions()
 
125
        if len(git_sha1) == 40:
 
126
            return self._lookup_git_sha1(context_branch, git_sha1)
 
127
        else:
 
128
            return self._find_short_git_sha1(context_branch, git_sha1)
30
129
 
31
130
    def _match_on(self, branch, revs):
32
 
        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)
 
131
        revid = self._as_revision_id(branch)
 
132
        return RevisionInfo.from_revision_id(branch, revid)
41
133
 
42
134
    def needs_branch(self):
43
135
        return True