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

MergeĀ upstream

Show diffs side-by-side

added added

removed removed

Lines of Context:
19
19
from bzrlib import errors, foreign
20
20
from bzrlib.inventory import ROOT_ID
21
21
from bzrlib.foreign import (
 
22
        ForeignVcs, 
 
23
        VcsMappingRegistry, 
22
24
        ForeignRevision,
23
25
        )
24
26
 
37
39
    """Class that maps between Git and Bazaar semantics."""
38
40
    experimental = False
39
41
 
40
 
    def revision_id_foreign_to_bzr(self, git_rev_id):
 
42
    def __eq__(self, other):
 
43
        return type(self) == type(other) and self.revid_prefix == other.revid_prefix
 
44
 
 
45
    @classmethod
 
46
    def revision_id_foreign_to_bzr(cls, git_rev_id):
41
47
        """Convert a git revision id handle to a Bazaar revision id."""
42
 
        return "%s:%s" % (self.revid_prefix, git_rev_id)
 
48
        return "%s:%s" % (cls.revid_prefix, git_rev_id)
43
49
 
44
 
    def revision_id_bzr_to_foreign(self, bzr_rev_id):
 
50
    @classmethod
 
51
    def revision_id_bzr_to_foreign(cls, bzr_rev_id):
45
52
        """Convert a Bazaar revision id to a git revision id handle."""
46
 
        if not bzr_rev_id.startswith("%s:" % self.revid_prefix):
47
 
            raise errors.InvalidRevisionId(bzr_rev_id, self)
48
 
        return bzr_rev_id[len(self.revid_prefix)+1:]
 
53
        if not bzr_rev_id.startswith("%s:" % cls.revid_prefix):
 
54
            raise errors.InvalidRevisionId(bzr_rev_id, cls)
 
55
        return bzr_rev_id[len(cls.revid_prefix)+1:], cls()
49
56
 
50
 
    def show_foreign_revid(self, foreign_revid):
 
57
    @classmethod
 
58
    def show_foreign_revid(cls, foreign_revid):
51
59
        return { "git commit": foreign_revid }
52
60
 
53
61
    def generate_file_id(self, path):
103
111
    experimental = True
104
112
 
105
113
 
 
114
class GitMappingRegistry(VcsMappingRegistry):
 
115
 
 
116
    def revision_id_bzr_to_foreign(self, bzr_revid):
 
117
        if not bzr_revid.startswith("git-"):
 
118
            raise errors.InvalidRevisionId(bzr_revid, None)
 
119
        (mapping_version, git_sha) = bzr_revid.split(":", 1)
 
120
        mapping = self.get(mapping_version)
 
121
        return mapping.revision_id_bzr_to_foreign(bzr_revid)
 
122
 
 
123
    parse_revision_id = revision_id_bzr_to_foreign
 
124
 
 
125
 
 
126
mapping_registry = GitMappingRegistry()
 
127
mapping_registry.register_lazy('git-v1', "bzrlib.plugins.git.mapping",
 
128
                                   "BzrGitMappingv1")
 
129
mapping_registry.register_lazy('git-experimental', "bzrlib.plugins.git.mapping",
 
130
                                   "BzrGitMappingExperimental")
 
131
 
 
132
 
 
133
class ForeignGit(ForeignVcs):
 
134
    """Foreign Git."""
 
135
 
 
136
    def __init__(self):
 
137
        super(ForeignGit, self).__init__(mapping_registry)
 
138
 
 
139
 
106
140
default_mapping = BzrGitMappingv1()
 
141
foreign_git = ForeignGit()