/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

Return mapping in revision_id_bzr_to_foreign() as required by the interface.

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
 
35
37
    """Class that maps between Git and Bazaar semantics."""
36
38
    experimental = False
37
39
 
38
 
    def revision_id_foreign_to_bzr(self, git_rev_id):
 
40
    def __eq__(self, other):
 
41
        return type(self) == type(other) and self.revid_prefix == other.revid_prefix
 
42
 
 
43
    @classmethod
 
44
    def revision_id_foreign_to_bzr(cls, git_rev_id):
39
45
        """Convert a git revision id handle to a Bazaar revision id."""
40
 
        return "%s:%s" % (self.revid_prefix, git_rev_id)
 
46
        return "%s:%s" % (cls.revid_prefix, git_rev_id)
41
47
 
42
 
    def revision_id_bzr_to_foreign(self, bzr_rev_id):
 
48
    @classmethod
 
49
    def revision_id_bzr_to_foreign(cls, bzr_rev_id):
43
50
        """Convert a Bazaar revision id to a git revision id handle."""
44
 
        if not bzr_rev_id.startswith("%s:" % self.revid_prefix):
45
 
            raise errors.InvalidRevisionId(bzr_rev_id, self)
46
 
        return bzr_rev_id[len(self.revid_prefix)+1:]
 
51
        if not bzr_rev_id.startswith("%s:" % cls.revid_prefix):
 
52
            raise errors.InvalidRevisionId(bzr_rev_id, cls)
 
53
        return bzr_rev_id[len(cls.revid_prefix)+1:], cls()
47
54
 
48
 
    def show_foreign_revid(self, foreign_revid):
 
55
    @classmethod
 
56
    def show_foreign_revid(cls, foreign_revid):
49
57
        return { "git commit": foreign_revid }
50
58
 
51
59
    def generate_file_id(self, path):
81
89
    experimental = True
82
90
 
83
91
 
 
92
class GitMappingRegistry(VcsMappingRegistry):
 
93
 
 
94
    def revision_id_bzr_to_foreign(self, bzr_revid):
 
95
        if not bzr_revid.startswith("git-"):
 
96
            raise errors.InvalidRevisionId(bzr_revid, None)
 
97
        (mapping_version, git_sha) = bzr_revid.split(":", 1)
 
98
        mapping = self.get(mapping_version)
 
99
        return mapping.revision_id_bzr_to_foreign(bzr_revid)
 
100
 
 
101
    parse_revision_id = revision_id_bzr_to_foreign
 
102
 
 
103
 
 
104
mapping_registry = GitMappingRegistry()
 
105
mapping_registry.register_lazy('git-v1', "bzrlib.plugins.git.mapping",
 
106
                                   "BzrGitMappingv1")
 
107
mapping_registry.register_lazy('git-experimental', "bzrlib.plugins.git.mapping",
 
108
                                   "BzrGitMappingExperimental")
 
109
 
 
110
 
 
111
class ForeignGit(ForeignVcs):
 
112
    """Foreign Git."""
 
113
 
 
114
    def __init__(self):
 
115
        super(ForeignGit, self).__init__(mapping_registry)
 
116
 
 
117
 
84
118
default_mapping = BzrGitMappingv1()
 
119
foreign_git = ForeignGit()