/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
4597.9.8 by Vincent Ladeuil
Merge bzr.dev into cleanup
1
# Copyright (C) 2007-2010 Canonical Ltd
2241.1.5 by Martin Pool
Move KnitFormat2 into repofmt
2
#
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
#
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
#
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
4183.7.1 by Sabin Iacob
update FSF mailing address
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
2241.1.5 by Martin Pool
Move KnitFormat2 into repofmt
16
2592.3.24 by Robert Collins
Knit1 disk layout specified.
17
from bzrlib.lazy_import import lazy_import
18
lazy_import(globals(), """
19
from bzrlib import (
2100.3.31 by Aaron Bentley
Merged bzr.dev (17 tests failing)
20
    bzrdir,
2241.1.5 by Martin Pool
Move KnitFormat2 into repofmt
21
    errors,
3224.5.26 by Andrew Bennetts
More minor import tidying suggested by pyflakes.
22
    knit as _mod_knit,
2241.1.5 by Martin Pool
Move KnitFormat2 into repofmt
23
    lockable_files,
24
    lockdir,
2249.5.16 by John Arbash Meinel
[merge] bzr.dev 2283
25
    osutils,
3224.5.26 by Andrew Bennetts
More minor import tidying suggested by pyflakes.
26
    revision as _mod_revision,
5184.1.1 by Vincent Ladeuil
Random cleanups to catch up with copyright updates in trunk.
27
    trace,
3224.5.26 by Andrew Bennetts
More minor import tidying suggested by pyflakes.
28
    transactions,
29
    versionedfile,
30
    xml5,
31
    xml6,
32
    xml7,
33
    )
34
""")
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
35
from bzrlib.decorators import needs_read_lock, needs_write_lock
2241.1.5 by Martin Pool
Move KnitFormat2 into repofmt
36
from bzrlib.repository import (
2889.1.1 by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into
37
    CommitBuilder,
5537.2.1 by Jelmer Vernooij
Move InterWeaveRepo and InterKnitRepo to related repository files.
38
    InterRepository,
39
    InterSameDataRepository,
5199.1.1 by Andrew Bennetts
Allow repositories to support refresh_data during a write group.
40
    IsInWriteGroupError,
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
41
    MetaDirRepository,
42
    MetaDirRepositoryFormat,
2241.1.5 by Martin Pool
Move KnitFormat2 into repofmt
43
    RepositoryFormat,
44
    RootCommitBuilder,
45
    )
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
46
47
2490.2.13 by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept
48
class _KnitParentsProvider(object):
49
50
    def __init__(self, knit):
51
        self._knit = knit
52
2490.2.28 by Aaron Bentley
Fix handling of null revision
53
    def __repr__(self):
54
        return 'KnitParentsProvider(%r)' % self._knit
55
3099.3.1 by John Arbash Meinel
Implement get_parent_map for ParentProviders
56
    def get_parent_map(self, keys):
4379.3.3 by Gary van der Merwe
Rename and add doc string for StackedParentsProvider.
57
        """See graph.StackedParentsProvider.get_parent_map"""
3099.3.1 by John Arbash Meinel
Implement get_parent_map for ParentProviders
58
        parent_map = {}
59
        for revision_id in keys:
3373.5.2 by John Arbash Meinel
Add repository_implementation tests for get_parent_map
60
            if revision_id is None:
61
                raise ValueError('get_parent_map(None) is not valid')
2490.2.13 by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept
62
            if revision_id == _mod_revision.NULL_REVISION:
3146.1.2 by Aaron Bentley
ParentsProviders now provide tuples of parents, never lists
63
                parent_map[revision_id] = ()
2490.2.13 by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept
64
            else:
65
                try:
3146.1.2 by Aaron Bentley
ParentsProviders now provide tuples of parents, never lists
66
                    parents = tuple(
67
                        self._knit.get_parents_with_ghosts(revision_id))
2490.2.13 by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept
68
                except errors.RevisionNotPresent:
3146.1.1 by Aaron Bentley
Fix bad ghost handling in KnitParentsProvider
69
                    continue
2490.2.13 by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept
70
                else:
71
                    if len(parents) == 0:
3146.1.2 by Aaron Bentley
ParentsProviders now provide tuples of parents, never lists
72
                        parents = (_mod_revision.NULL_REVISION,)
3099.3.1 by John Arbash Meinel
Implement get_parent_map for ParentProviders
73
                parent_map[revision_id] = parents
74
        return parent_map
2490.2.13 by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept
75
76
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
77
class _KnitsParentsProvider(object):
78
79
    def __init__(self, knit, prefix=()):
80
        """Create a parent provider for string keys mapped to tuple keys."""
81
        self._knit = knit
82
        self._prefix = prefix
83
84
    def __repr__(self):
85
        return 'KnitsParentsProvider(%r)' % self._knit
86
87
    def get_parent_map(self, keys):
4379.3.3 by Gary van der Merwe
Rename and add doc string for StackedParentsProvider.
88
        """See graph.StackedParentsProvider.get_parent_map"""
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
89
        parent_map = self._knit.get_parent_map(
90
            [self._prefix + (key,) for key in keys])
91
        result = {}
92
        for key, parents in parent_map.items():
93
            revid = key[-1]
94
            if len(parents) == 0:
95
                parents = (_mod_revision.NULL_REVISION,)
96
            else:
97
                parents = tuple(parent[-1] for parent in parents)
98
            result[revid] = parents
99
        for revision_id in keys:
100
            if revision_id == _mod_revision.NULL_REVISION:
101
                result[revision_id] = ()
102
        return result
103
104
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
105
class KnitRepository(MetaDirRepository):
106
    """Knit format repository."""
107
2889.1.2 by Robert Collins
Review feedback.
108
    # These attributes are inherited from the Repository base class. Setting
109
    # them to None ensures that if the constructor is changed to not initialize
110
    # them, or a subclass fails to call the constructor, that an error will
111
    # occur rather than the system working but generating incorrect data.
2889.1.1 by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into
112
    _commit_builder_class = None
113
    _serializer = None
114
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
115
    def __init__(self, _format, a_bzrdir, control_files, _commit_builder_class,
116
        _serializer):
117
        MetaDirRepository.__init__(self, _format, a_bzrdir, control_files)
2889.1.1 by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into
118
        self._commit_builder_class = _commit_builder_class
119
        self._serializer = _serializer
2745.6.16 by Aaron Bentley
Update from review
120
        self._reconcile_fixes_text_parents = True
3830.3.6 by Martin Pool
Document _fetch_uses_delta and make it a class attribute
121
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
122
    @needs_read_lock
123
    def _all_revision_ids(self):
124
        """See Repository.all_revision_ids()."""
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
125
        return [key[0] for key in self.revisions.keys()]
126
127
    def _activate_new_inventory(self):
128
        """Put a replacement inventory.new into use as inventories."""
129
        # Copy the content across
130
        t = self._transport
131
        t.copy('inventory.new.kndx', 'inventory.kndx')
132
        try:
133
            t.copy('inventory.new.knit', 'inventory.knit')
134
        except errors.NoSuchFile:
135
            # empty inventories knit
136
            t.delete('inventory.knit')
137
        # delete the temp inventory
138
        t.delete('inventory.new.kndx')
139
        try:
140
            t.delete('inventory.new.knit')
141
        except errors.NoSuchFile:
142
            # empty inventories knit
143
            pass
144
        # Force index reload (sanity check)
145
        self.inventories._index._reset_cache()
146
        self.inventories.keys()
147
148
    def _backup_inventory(self):
149
        t = self._transport
150
        t.copy('inventory.kndx', 'inventory.backup.kndx')
151
        t.copy('inventory.knit', 'inventory.backup.knit')
152
153
    def _move_file_id(self, from_id, to_id):
154
        t = self._transport.clone('knits')
155
        from_rel_url = self.texts._index._mapper.map((from_id, None))
156
        to_rel_url = self.texts._index._mapper.map((to_id, None))
157
        # We expect both files to always exist in this case.
158
        for suffix in ('.knit', '.kndx'):
159
            t.rename(from_rel_url + suffix, to_rel_url + suffix)
160
161
    def _remove_file_id(self, file_id):
162
        t = self._transport.clone('knits')
163
        rel_url = self.texts._index._mapper.map((file_id, None))
164
        for suffix in ('.kndx', '.knit'):
165
            try:
166
                t.delete(rel_url + suffix)
167
            except errors.NoSuchFile:
168
                pass
169
170
    def _temp_inventories(self):
171
        result = self._format._get_inventories(self._transport, self,
172
            'inventory.new')
173
        # Reconciling when the output has no revisions would result in no
174
        # writes - but we want to ensure there is an inventory for
175
        # compatibility with older clients that don't lazy-load.
176
        result.get_parent_map([('A',)])
177
        return result
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
178
179
    def fileid_involved_between_revs(self, from_revid, to_revid):
180
        """Find file_id(s) which are involved in the changes between revisions.
181
182
        This determines the set of revisions which are involved, and then
183
        finds all file ids affected by those revisions.
184
        """
185
        vf = self._get_revision_vf()
186
        from_set = set(vf.get_ancestry(from_revid))
187
        to_set = set(vf.get_ancestry(to_revid))
188
        changed = to_set.difference(from_set)
189
        return self._fileid_involved_by_set(changed)
190
191
    def fileid_involved(self, last_revid=None):
192
        """Find all file_ids modified in the ancestry of last_revid.
193
194
        :param last_revid: If None, last_revision() will be used.
195
        """
196
        if not last_revid:
197
            changed = set(self.all_revision_ids())
198
        else:
199
            changed = set(self.get_ancestry(last_revid))
200
        if None in changed:
201
            changed.remove(None)
202
        return self._fileid_involved_by_set(changed)
203
204
    @needs_read_lock
205
    def get_revision(self, revision_id):
206
        """Return the Revision object for a named revision"""
2249.5.16 by John Arbash Meinel
[merge] bzr.dev 2283
207
        revision_id = osutils.safe_revision_id(revision_id)
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
208
        return self.get_revision_reconcile(revision_id)
209
4145.1.2 by Robert Collins
Add a refresh_data method on Repository allowing cleaner handling of insertions into RemoteRepository objects with _real_repository instances.
210
    def _refresh_data(self):
211
        if not self.is_locked():
212
            return
5199.1.1 by Andrew Bennetts
Allow repositories to support refresh_data during a write group.
213
        if self.is_in_write_group():
214
            raise IsInWriteGroupError(self)
4145.1.2 by Robert Collins
Add a refresh_data method on Repository allowing cleaner handling of insertions into RemoteRepository objects with _real_repository instances.
215
        # Create a new transaction to force all knits to see the scope change.
216
        # This is safe because we're outside a write group.
217
        self.control_files._finish_transaction()
218
        if self.is_write_locked():
219
            self.control_files._set_write_transaction()
220
        else:
221
            self.control_files._set_read_transaction()
222
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
223
    @needs_write_lock
224
    def reconcile(self, other=None, thorough=False):
225
        """Reconcile this repository."""
226
        from bzrlib.reconcile import KnitReconciler
227
        reconciler = KnitReconciler(self, thorough=thorough)
228
        reconciler.reconcile()
229
        return reconciler
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
230
2490.2.13 by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept
231
    def _make_parents_provider(self):
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
232
        return _KnitsParentsProvider(self.revisions)
2490.2.13 by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept
233
4332.3.16 by Robert Collins
Refactor Repository._find_inconsistent_revision_parents and Repository.get_revisions to a new Repository._iter_revisions which is kinder on memory without needing code duplication.
234
    def _find_inconsistent_revision_parents(self, revisions_iterator=None):
2819.2.1 by Andrew Bennetts
Implement KnitRepository._find_inconsistent_revision_parents.
235
        """Find revisions with different parent lists in the revision object
236
        and in the index graph.
2819.2.2 by Andrew Bennetts
Implement _check_for_inconsistent_revision_parents.
237
4332.3.16 by Robert Collins
Refactor Repository._find_inconsistent_revision_parents and Repository.get_revisions to a new Repository._iter_revisions which is kinder on memory without needing code duplication.
238
        :param revisions_iterator: None, or an iterator of (revid,
239
            Revision-or-None). This iterator controls the revisions checked.
2819.2.2 by Andrew Bennetts
Implement _check_for_inconsistent_revision_parents.
240
        :returns: an iterator yielding tuples of (revison-id, parents-in-index,
241
            parents-in-revision).
2819.2.1 by Andrew Bennetts
Implement KnitRepository._find_inconsistent_revision_parents.
242
        """
3376.2.4 by Martin Pool
Remove every assert statement from bzrlib!
243
        if not self.is_locked():
244
            raise AssertionError()
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
245
        vf = self.revisions
4332.3.16 by Robert Collins
Refactor Repository._find_inconsistent_revision_parents and Repository.get_revisions to a new Repository._iter_revisions which is kinder on memory without needing code duplication.
246
        if revisions_iterator is None:
247
            revisions_iterator = self._iter_revisions(None)
248
        for revid, revision in revisions_iterator:
249
            if revision is None:
250
                pass
251
            parent_map = vf.get_parent_map([(revid,)])
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
252
            parents_according_to_index = tuple(parent[-1] for parent in
4332.3.16 by Robert Collins
Refactor Repository._find_inconsistent_revision_parents and Repository.get_revisions to a new Repository._iter_revisions which is kinder on memory without needing code duplication.
253
                parent_map[(revid,)])
2592.3.214 by Robert Collins
Merge bzr.dev.
254
            parents_according_to_revision = tuple(revision.parent_ids)
2819.2.1 by Andrew Bennetts
Implement KnitRepository._find_inconsistent_revision_parents.
255
            if parents_according_to_index != parents_according_to_revision:
4332.3.16 by Robert Collins
Refactor Repository._find_inconsistent_revision_parents and Repository.get_revisions to a new Repository._iter_revisions which is kinder on memory without needing code duplication.
256
                yield (revid, parents_according_to_index,
2819.2.1 by Andrew Bennetts
Implement KnitRepository._find_inconsistent_revision_parents.
257
                    parents_according_to_revision)
258
2819.2.2 by Andrew Bennetts
Implement _check_for_inconsistent_revision_parents.
259
    def _check_for_inconsistent_revision_parents(self):
260
        inconsistencies = list(self._find_inconsistent_revision_parents())
261
        if inconsistencies:
262
            raise errors.BzrCheckError(
263
                "Revision knit has inconsistent parents.")
264
2819.2.4 by Andrew Bennetts
Add a 'revision_graph_can_have_wrong_parents' method to repository.
265
    def revision_graph_can_have_wrong_parents(self):
266
        # The revision.kndx could potentially claim a revision has a different
267
        # parent to the revision text.
268
        return True
269
2241.1.5 by Martin Pool
Move KnitFormat2 into repofmt
270
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
271
class RepositoryFormatKnit(MetaDirRepositoryFormat):
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
272
    """Bzr repository knit format (generalized).
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
273
274
    This repository format has:
275
     - knits for file texts and inventory
276
     - hash subdirectory based stores.
277
     - knits for revisions and signatures
278
     - TextStores for revisions and signatures.
279
     - a format marker of its own
280
     - an optional 'shared-storage' flag
281
     - an optional 'no-working-trees' flag
282
     - a LockDir lock
283
    """
284
2857.2.2 by Robert Collins
Review feedback.
285
    # Set this attribute in derived classes to control the repository class
286
    # created by open and initialize.
287
    repository_class = None
2889.1.1 by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into
288
    # Set this attribute in derived classes to control the
289
    # _commit_builder_class that the repository objects will have passed to
290
    # their constructor.
291
    _commit_builder_class = None
292
    # Set this attribute in derived clases to control the _serializer that the
293
    # repository objects will have passed to their constructor.
3224.5.1 by Andrew Bennetts
Lots of assorted hackery to reduce the number of imports for common operations. Improves 'rocks', 'st' and 'help' times by ~50ms on my laptop.
294
    @property
295
    def _serializer(self):
296
        return xml5.serializer_v5
2949.1.2 by Robert Collins
* Fetch with pack repositories will no longer read the entire history graph.
297
    # Knit based repositories handle ghosts reasonably well.
298
    supports_ghosts = True
3221.3.1 by Robert Collins
* Repository formats have a new supported-feature attribute
299
    # External lookups are not supported in this format.
300
    supports_external_lookups = False
4246.2.1 by Ian Clatworthy
supports_chks flag on repo formats & log tuning
301
    # No CHK support.
302
    supports_chks = False
4053.1.4 by Robert Collins
Move the fetch control attributes from Repository to RepositoryFormat.
303
    _fetch_order = 'topological'
304
    _fetch_uses_deltas = True
4183.5.1 by Robert Collins
Add RepositoryFormat.fast_deltas to signal fast delta creation.
305
    fast_deltas = False
2857.2.2 by Robert Collins
Review feedback.
306
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
307
    def _get_inventories(self, repo_transport, repo, name='inventory'):
3224.5.26 by Andrew Bennetts
More minor import tidying suggested by pyflakes.
308
        mapper = versionedfile.ConstantMapper(name)
309
        index = _mod_knit._KndxIndex(repo_transport, mapper,
310
            repo.get_transaction, repo.is_write_locked, repo.is_locked)
311
        access = _mod_knit._KnitKeyAccess(repo_transport, mapper)
312
        return _mod_knit.KnitVersionedFiles(index, access, annotated=False)
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
313
314
    def _get_revisions(self, repo_transport, repo):
3224.5.26 by Andrew Bennetts
More minor import tidying suggested by pyflakes.
315
        mapper = versionedfile.ConstantMapper('revisions')
316
        index = _mod_knit._KndxIndex(repo_transport, mapper,
317
            repo.get_transaction, repo.is_write_locked, repo.is_locked)
318
        access = _mod_knit._KnitKeyAccess(repo_transport, mapper)
319
        return _mod_knit.KnitVersionedFiles(index, access, max_delta_chain=0,
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
320
            annotated=False)
321
322
    def _get_signatures(self, repo_transport, repo):
3224.5.26 by Andrew Bennetts
More minor import tidying suggested by pyflakes.
323
        mapper = versionedfile.ConstantMapper('signatures')
324
        index = _mod_knit._KndxIndex(repo_transport, mapper,
325
            repo.get_transaction, repo.is_write_locked, repo.is_locked)
326
        access = _mod_knit._KnitKeyAccess(repo_transport, mapper)
327
        return _mod_knit.KnitVersionedFiles(index, access, max_delta_chain=0,
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
328
            annotated=False)
329
330
    def _get_texts(self, repo_transport, repo):
3224.5.26 by Andrew Bennetts
More minor import tidying suggested by pyflakes.
331
        mapper = versionedfile.HashEscapedPrefixMapper()
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
332
        base_transport = repo_transport.clone('knits')
3224.5.26 by Andrew Bennetts
More minor import tidying suggested by pyflakes.
333
        index = _mod_knit._KndxIndex(base_transport, mapper,
334
            repo.get_transaction, repo.is_write_locked, repo.is_locked)
335
        access = _mod_knit._KnitKeyAccess(base_transport, mapper)
336
        return _mod_knit.KnitVersionedFiles(index, access, max_delta_chain=200,
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
337
            annotated=True)
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
338
339
    def initialize(self, a_bzrdir, shared=False):
340
        """Create a knit format 1 repository.
341
342
        :param a_bzrdir: bzrdir to contain the new repository; must already
343
            be initialized.
344
        :param shared: If true the repository will be initialized as a shared
345
                       repository.
346
        """
5184.1.1 by Vincent Ladeuil
Random cleanups to catch up with copyright updates in trunk.
347
        trace.mutter('creating repository in %s.', a_bzrdir.transport.base)
2592.3.60 by Robert Collins
Nuke per-fileid indices for a single unified index.
348
        dirs = ['knits']
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
349
        files = []
350
        utf8_files = [('format', self.get_format_string())]
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
351
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
352
        self._upload_blank_content(a_bzrdir, dirs, files, utf8_files, shared)
353
        repo_transport = a_bzrdir.get_repository_transport(None)
354
        control_files = lockable_files.LockableFiles(repo_transport,
355
                                'lock', lockdir.LockDir)
356
        transaction = transactions.WriteTransaction()
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
357
        result = self.open(a_bzrdir=a_bzrdir, _found=True)
358
        result.lock_write()
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
359
        # the revision id here is irrelevant: it will not be stored, and cannot
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
360
        # already exist, we do this to create files on disk for older clients.
361
        result.inventories.get_parent_map([('A',)])
362
        result.revisions.get_parent_map([('A',)])
363
        result.signatures.get_parent_map([('A',)])
364
        result.unlock()
5107.3.1 by Marco Pantaleoni
Added the new hooks 'post_branch', 'post_switch' and 'post_repo_init',
365
        self._run_post_repo_init_hooks(result, a_bzrdir, shared)
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
366
        return result
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
367
368
    def open(self, a_bzrdir, _found=False, _override_transport=None):
369
        """See RepositoryFormat.open().
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
370
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
371
        :param _override_transport: INTERNAL USE ONLY. Allows opening the
372
                                    repository at a slightly different url
373
                                    than normal. I.e. during 'upgrade'.
374
        """
375
        if not _found:
376
            format = RepositoryFormat.find_format(a_bzrdir)
377
        if _override_transport is not None:
378
            repo_transport = _override_transport
379
        else:
380
            repo_transport = a_bzrdir.get_repository_transport(None)
381
        control_files = lockable_files.LockableFiles(repo_transport,
382
                                'lock', lockdir.LockDir)
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
383
        repo = self.repository_class(_format=self,
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
384
                              a_bzrdir=a_bzrdir,
385
                              control_files=control_files,
2889.1.1 by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into
386
                              _commit_builder_class=self._commit_builder_class,
387
                              _serializer=self._serializer)
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
388
        repo.revisions = self._get_revisions(repo_transport, repo)
389
        repo.signatures = self._get_signatures(repo_transport, repo)
390
        repo.inventories = self._get_inventories(repo_transport, repo)
391
        repo.texts = self._get_texts(repo_transport, repo)
4246.2.1 by Ian Clatworthy
supports_chks flag on repo formats & log tuning
392
        repo.chk_bytes = None
3350.6.4 by Robert Collins
First cut at pluralised VersionedFiles. Some rather massive API incompatabilities, primarily because of the difficulty of coherence among competing stores.
393
        repo._transport = repo_transport
394
        return repo
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
395
396
397
class RepositoryFormatKnit1(RepositoryFormatKnit):
398
    """Bzr repository knit format 1.
399
400
    This repository format has:
401
     - knits for file texts and inventory
402
     - hash subdirectory based stores.
403
     - knits for revisions and signatures
404
     - TextStores for revisions and signatures.
405
     - a format marker of its own
406
     - an optional 'shared-storage' flag
407
     - an optional 'no-working-trees' flag
408
     - a LockDir lock
409
410
    This format was introduced in bzr 0.8.
411
    """
2241.1.11 by Martin Pool
Get rid of RepositoryFormat*_instance objects. Instead the format
412
2592.3.22 by Robert Collins
Add new experimental repository formats.
413
    repository_class = KnitRepository
2889.1.1 by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into
414
    _commit_builder_class = CommitBuilder
3224.5.1 by Andrew Bennetts
Lots of assorted hackery to reduce the number of imports for common operations. Improves 'rocks', 'st' and 'help' times by ~50ms on my laptop.
415
    @property
416
    def _serializer(self):
417
        return xml5.serializer_v5
2592.3.22 by Robert Collins
Add new experimental repository formats.
418
2100.3.35 by Aaron Bentley
equality operations on bzrdir
419
    def __ne__(self, other):
2100.3.31 by Aaron Bentley
Merged bzr.dev (17 tests failing)
420
        return self.__class__ is not other.__class__
421
2241.1.6 by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and
422
    def get_format_string(self):
423
        """See RepositoryFormat.get_format_string()."""
424
        return "Bazaar-NG Knit Repository Format 1"
425
426
    def get_format_description(self):
427
        """See RepositoryFormat.get_format_description()."""
428
        return "Knit repository format 1"
429
430
2255.2.211 by Robert Collins
Remove knit2 repository format- it has never been supported.
431
class RepositoryFormatKnit3(RepositoryFormatKnit):
2996.2.5 by Aaron Bentley
Correct docstring
432
    """Bzr repository knit format 3.
2255.2.211 by Robert Collins
Remove knit2 repository format- it has never been supported.
433
2100.3.31 by Aaron Bentley
Merged bzr.dev (17 tests failing)
434
    This repository format has:
435
     - knits for file texts and inventory
436
     - hash subdirectory based stores.
437
     - knits for revisions and signatures
438
     - TextStores for revisions and signatures.
439
     - a format marker of its own
440
     - an optional 'shared-storage' flag
441
     - an optional 'no-working-trees' flag
442
     - a LockDir lock
443
     - support for recording full info about the tree root
444
     - support for recording tree-references
445
    """
446
2889.1.1 by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into
447
    repository_class = KnitRepository
448
    _commit_builder_class = RootCommitBuilder
2255.2.211 by Robert Collins
Remove knit2 repository format- it has never been supported.
449
    rich_root_data = True
4988.9.1 by Jelmer Vernooij
Add experimental flag to RepositoryFormat.
450
    experimental = True
2323.5.16 by Martin Pool
rename support_tree_reference to supports_
451
    supports_tree_reference = True
3224.5.1 by Andrew Bennetts
Lots of assorted hackery to reduce the number of imports for common operations. Improves 'rocks', 'st' and 'help' times by ~50ms on my laptop.
452
    @property
453
    def _serializer(self):
454
        return xml7.serializer_v7
2100.3.31 by Aaron Bentley
Merged bzr.dev (17 tests failing)
455
456
    def _get_matching_bzrdir(self):
2255.2.194 by Robert Collins
[BROKEN] Many updates to stop using experimental formats in tests.
457
        return bzrdir.format_registry.make_bzrdir('dirstate-with-subtree')
2100.3.31 by Aaron Bentley
Merged bzr.dev (17 tests failing)
458
459
    def _ignore_setting_bzrdir(self, format):
460
        pass
461
462
    _matchingbzrdir = property(_get_matching_bzrdir, _ignore_setting_bzrdir)
463
464
    def get_format_string(self):
465
        """See RepositoryFormat.get_format_string()."""
2255.2.230 by Robert Collins
Update tree format signatures to mention introducing bzr version.
466
        return "Bazaar Knit Repository Format 3 (bzr 0.15)\n"
2100.3.31 by Aaron Bentley
Merged bzr.dev (17 tests failing)
467
468
    def get_format_description(self):
469
        """See RepositoryFormat.get_format_description()."""
470
        return "Knit repository format 3"
471
2535.3.53 by Andrew Bennetts
Remove get_stream_as_bytes from KnitVersionedFile's API, make it a function in knitrepo.py instead.
472
2996.2.1 by Aaron Bentley
Add KnitRepositoryFormat4
473
class RepositoryFormatKnit4(RepositoryFormatKnit):
474
    """Bzr repository knit format 4.
475
476
    This repository format has everything in format 3, except for
477
    tree-references:
478
     - knits for file texts and inventory
479
     - hash subdirectory based stores.
480
     - knits for revisions and signatures
481
     - TextStores for revisions and signatures.
482
     - a format marker of its own
483
     - an optional 'shared-storage' flag
484
     - an optional 'no-working-trees' flag
485
     - a LockDir lock
486
     - support for recording full info about the tree root
487
    """
488
489
    repository_class = KnitRepository
490
    _commit_builder_class = RootCommitBuilder
491
    rich_root_data = True
492
    supports_tree_reference = False
3224.5.1 by Andrew Bennetts
Lots of assorted hackery to reduce the number of imports for common operations. Improves 'rocks', 'st' and 'help' times by ~50ms on my laptop.
493
    @property
494
    def _serializer(self):
495
        return xml6.serializer_v6
2996.2.1 by Aaron Bentley
Add KnitRepositoryFormat4
496
497
    def _get_matching_bzrdir(self):
498
        return bzrdir.format_registry.make_bzrdir('rich-root')
499
500
    def _ignore_setting_bzrdir(self, format):
501
        pass
502
503
    _matchingbzrdir = property(_get_matching_bzrdir, _ignore_setting_bzrdir)
504
505
    def get_format_string(self):
506
        """See RepositoryFormat.get_format_string()."""
507
        return 'Bazaar Knit Repository Format 4 (bzr 1.0)\n'
508
509
    def get_format_description(self):
510
        """See RepositoryFormat.get_format_description()."""
511
        return "Knit repository format 4"
5537.2.1 by Jelmer Vernooij
Move InterWeaveRepo and InterKnitRepo to related repository files.
512
513
514
class InterKnitRepo(InterSameDataRepository):
515
    """Optimised code paths between Knit based repositories."""
516
517
    @classmethod
518
    def _get_repo_format_to_test(self):
519
        return RepositoryFormatKnit1()
520
521
    @staticmethod
522
    def is_compatible(source, target):
523
        """Be compatible with known Knit formats.
524
525
        We don't test for the stores being of specific types because that
526
        could lead to confusing results, and there is no need to be
527
        overly general.
528
        """
529
        try:
530
            are_knits = (isinstance(source._format, RepositoryFormatKnit) and
531
                isinstance(target._format, RepositoryFormatKnit))
532
        except AttributeError:
533
            return False
534
        return are_knits and InterRepository._same_model(source, target)
535
536
    @needs_read_lock
537
    def search_missing_revision_ids(self, revision_id=None, find_ghosts=True):
538
        """See InterRepository.missing_revision_ids()."""
539
        if revision_id is not None:
540
            source_ids = self.source.get_ancestry(revision_id)
541
            if source_ids[0] is not None:
542
                raise AssertionError()
543
            source_ids.pop(0)
544
        else:
545
            source_ids = self.source.all_revision_ids()
546
        source_ids_set = set(source_ids)
547
        # source_ids is the worst possible case we may need to pull.
548
        # now we want to filter source_ids against what we actually
549
        # have in target, but don't try to check for existence where we know
550
        # we do not have a revision as that would be pointless.
551
        target_ids = set(self.target.all_revision_ids())
552
        possibly_present_revisions = target_ids.intersection(source_ids_set)
553
        actually_present_revisions = set(
554
            self.target._eliminate_revisions_not_present(possibly_present_revisions))
555
        required_revisions = source_ids_set.difference(actually_present_revisions)
556
        if revision_id is not None:
557
            # we used get_ancestry to determine source_ids then we are assured all
558
            # revisions referenced are present as they are installed in topological order.
559
            # and the tip revision was validated by get_ancestry.
560
            result_set = required_revisions
561
        else:
562
            # if we just grabbed the possibly available ids, then
563
            # we only have an estimate of whats available and need to validate
564
            # that against the revision records.
565
            result_set = set(
566
                self.source._eliminate_revisions_not_present(required_revisions))
567
        return self.source.revision_ids_to_search_result(result_set)
568
569
570
InterRepository.register_optimiser(InterKnitRepo)