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

More work on roundtrip push support.

Show diffs side-by-side

added added

removed removed

Lines of Context:
23
23
    Tree,
24
24
    )
25
25
 
 
26
from bzrlib import (
 
27
    annotate,
 
28
    )
 
29
 
26
30
from bzrlib.versionedfile import (
27
31
    AbsentContentFactory,
28
 
    FulltextContentFactory,
 
32
    ChunkedContentFactory,
29
33
    VersionedFiles,
30
34
    )
31
35
 
32
36
 
33
37
class GitRevisions(VersionedFiles):
34
38
 
35
 
    def __init__(self, object_store):
 
39
    def __init__(self, repository, object_store):
 
40
        self.repository = repository
36
41
        self.object_store = object_store
37
42
 
38
43
    def check(self, progressbar=None):
39
44
        return True
40
45
 
 
46
    def get_annotator(self):
 
47
        return annotate.Annotator(self)
 
48
 
41
49
    def iterkeys(self):
42
50
        for sha in self.object_store:
43
51
            if type(sha) == Commit:
51
59
 
52
60
    def get_record_stream(self, keys, ordering, include_delta_closure):
53
61
        for key in keys:
54
 
            (sha,) = key
 
62
            (revid,) = key
 
63
            (commit_id, mapping) = self.repository.lookup_bzr_revision_id(revid)
55
64
            try:
56
 
                text = self.object_store.get_raw(sha)
 
65
                commit = self.object_store[commit_id]
57
66
            except KeyError:
58
67
                yield AbsentContentFactory(key)
59
68
            else:
60
 
                yield FulltextContentFactory(key, None, None, text)
 
69
                yield ChunkedContentFactory(key, 
 
70
                    tuple([(self.repository.lookup_foreign_revision_id(p, mapping),) for p in commit.parents]), None, 
 
71
                    commit.as_raw_chunks())
61
72
 
62
73
    def get_parent_map(self, keys):
63
74
        ret = {}
64
 
        for (key,) in keys:
 
75
        for (revid,) in keys:
 
76
            (commit_id, mapping) = self.repository.lookup_bzr_revision_id(revid)
65
77
            try:
66
 
                ret[(key,)] = [(p,) for p in self.object_store[key].parents]
 
78
                ret[(revid,)] = [(self.repository.lookup_foreign_revision_id(p, mapping),) for p in self.object_store[commit_id].parents]
67
79
            except KeyError:
68
 
                ret[(key,)] = None
 
80
                ret[(revid,)] = None
69
81
        return ret
70
82
 
71
83
 
79
91
    def check(self, progressbar=None):
80
92
        return True
81
93
 
 
94
    def get_annotator(self):
 
95
        return annotate.Annotator(self)
 
96
 
82
97
    def add_mpdiffs(self, records):
83
98
        raise NotImplementedError(self.add_mpdiffs)
84
99
 
85
100
    def get_record_stream(self, keys, ordering, include_delta_closure):
86
101
        for key in keys:
87
102
            (fileid, revid) = key
88
 
            (foreign_revid, mapping) = self.repository.lookup_git_revid(revid)
89
 
            root_tree = self.object_store[foreign_revid].tree
 
103
            (commit_id, mapping) = self.repository.lookup_bzr_revision_id(revid)
 
104
            root_tree = self.object_store[commit_id].tree
90
105
            path = mapping.parse_file_id(fileid)
91
106
            try:
92
 
                obj = tree_lookup_path(self.object_store.__getitem__, 
93
 
                                       root_tree, path)
 
107
                obj = tree_lookup_path(
 
108
                    self.object_store.__getitem__, root_tree, path)
 
109
                if isinstance(obj, tuple):
 
110
                    (mode, item_id) = obj
 
111
                    obj = self.object_store[item_id]
94
112
            except KeyError:
95
113
                yield AbsentContentFactory(key)
96
114
            else:
97
115
                if isinstance(obj, Tree):
98
 
                    yield FulltextContentFactory(key, None, None, "")
 
116
                    yield ChunkedContentFactory(key, None, None, [])
99
117
                elif isinstance(obj, Blob):
100
 
                    yield FulltextContentFactory(key, None, None, obj._text)
 
118
                    yield ChunkedContentFactory(key, None, None, obj.chunked)
101
119
                else:
102
 
                    yield AbsentContentFactory(key)
 
120
                    raise AssertionError("file text resolved to %r" % obj)
103
121
 
104
122
    def get_parent_map(self, keys):
105
123
        raise NotImplementedError(self.get_parent_map)