/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:
17
17
"""Converters, etc for going between Bazaar and Git ids."""
18
18
 
19
19
from bzrlib import errors, foreign
 
20
from bzrlib.inventory import ROOT_ID
20
21
from bzrlib.foreign import (
 
22
        ForeignVcs, 
 
23
        VcsMappingRegistry, 
21
24
        ForeignRevision,
22
25
        )
23
26
 
34
37
    """Class that maps between Git and Bazaar semantics."""
35
38
    experimental = False
36
39
 
37
 
    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):
38
45
        """Convert a git revision id handle to a Bazaar revision id."""
39
 
        return "%s:%s" % (self.revid_prefix, git_rev_id)
 
46
        return "%s:%s" % (cls.revid_prefix, git_rev_id)
40
47
 
41
 
    def revision_id_bzr_to_foreign(self, bzr_rev_id):
 
48
    @classmethod
 
49
    def revision_id_bzr_to_foreign(cls, bzr_rev_id):
42
50
        """Convert a Bazaar revision id to a git revision id handle."""
43
 
        if not bzr_rev_id.startswith("%s:" % self.revid_prefix):
44
 
            raise errors.InvalidRevisionId(bzr_rev_id, self)
45
 
        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()
46
54
 
47
 
    def show_foreign_revid(self, foreign_revid):
 
55
    @classmethod
 
56
    def show_foreign_revid(cls, foreign_revid):
48
57
        return { "git commit": foreign_revid }
49
58
 
50
59
    def generate_file_id(self, path):
 
60
        if path == "":
 
61
            return ROOT_ID
51
62
        return escape_file_id(path.encode('utf-8'))
52
63
 
53
64
    def import_commit(self, commit):
68
79
        return rev
69
80
 
70
81
 
71
 
class BzrGitMappingExperimental(BzrGitMapping):
 
82
class BzrGitMappingv1(BzrGitMapping):
 
83
    revid_prefix = 'git-v1'
 
84
    experimental = False
 
85
 
 
86
 
 
87
class BzrGitMappingExperimental(BzrGitMappingv1):
72
88
    revid_prefix = 'git-experimental'
73
89
    experimental = True
74
90
 
75
91
 
76
 
default_mapping = BzrGitMappingExperimental()
 
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
 
 
118
default_mapping = BzrGitMappingv1()
 
119
foreign_git = ForeignGit()