bzr branch
http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
|
2241.1.5
by Martin Pool
Move KnitFormat2 into repofmt |
1 |
# Copyright (C) 2005, 2006, 2007 Canonical Ltd
|
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
|
|
15 |
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
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 (
|
|
|
2592.3.112
by Robert Collins
Various fixups found dogfooding. |
20 |
debug,
|
|
2857.2.1
by Robert Collins
(robertc) Knit repo format tidyups from the packs branch. (Robert Collins) |
21 |
)
|
|
2592.3.26
by Robert Collins
Start of proper bunch-of-index based repository logic. Can branch bzr.dev with it... if you are patient. |
22 |
from bzrlib.store import revision
|
|
2857.2.1
by Robert Collins
(robertc) Knit repo format tidyups from the packs branch. (Robert Collins) |
23 |
from bzrlib.store.revision.knit import KnitRevisionStore
|
|
2592.3.24
by Robert Collins
Knit1 disk layout specified. |
24 |
""") |
|
2241.1.5
by Martin Pool
Move KnitFormat2 into repofmt |
25 |
from bzrlib import ( |
|
2100.3.31
by Aaron Bentley
Merged bzr.dev (17 tests failing) |
26 |
bzrdir, |
|
2490.2.21
by Aaron Bentley
Rename graph to deprecated_graph |
27 |
deprecated_graph, |
|
2241.1.5
by Martin Pool
Move KnitFormat2 into repofmt |
28 |
errors, |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
29 |
knit, |
|
2241.1.5
by Martin Pool
Move KnitFormat2 into repofmt |
30 |
lockable_files, |
31 |
lockdir, |
|
|
2249.5.16
by John Arbash Meinel
[merge] bzr.dev 2283 |
32 |
osutils, |
|
3099.3.3
by John Arbash Meinel
Deprecate get_parents() in favor of get_parent_map() |
33 |
symbol_versioning, |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
34 |
transactions, |
|
2241.1.8
by Martin Pool
Set the repository's serializer in the places it's needed, not in the base class |
35 |
xml5, |
|
2996.2.1
by Aaron Bentley
Add KnitRepositoryFormat4 |
36 |
xml6, |
|
2100.3.31
by Aaron Bentley
Merged bzr.dev (17 tests failing) |
37 |
xml7, |
|
2241.1.5
by Martin Pool
Move KnitFormat2 into repofmt |
38 |
)
|
39 |
||
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
40 |
from bzrlib.decorators import needs_read_lock, needs_write_lock |
|
2241.1.5
by Martin Pool
Move KnitFormat2 into repofmt |
41 |
from bzrlib.repository import ( |
|
2889.1.1
by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into |
42 |
CommitBuilder, |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
43 |
MetaDirRepository, |
44 |
MetaDirRepositoryFormat, |
|
|
2241.1.5
by Martin Pool
Move KnitFormat2 into repofmt |
45 |
RepositoryFormat, |
46 |
RootCommitBuilder, |
|
47 |
)
|
|
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
48 |
import bzrlib.revision as _mod_revision |
49 |
from bzrlib.store.versioned import VersionedFileStore |
|
|
2857.2.1
by Robert Collins
(robertc) Knit repo format tidyups from the packs branch. (Robert Collins) |
50 |
from bzrlib.trace import mutter, mutter_callsite |
|
2535.3.53
by Andrew Bennetts
Remove get_stream_as_bytes from KnitVersionedFile's API, make it a function in knitrepo.py instead. |
51 |
from bzrlib.util import bencode |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
52 |
|
53 |
||
|
2490.2.13
by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept |
54 |
class _KnitParentsProvider(object): |
55 |
||
56 |
def __init__(self, knit): |
|
57 |
self._knit = knit |
|
58 |
||
|
2490.2.28
by Aaron Bentley
Fix handling of null revision |
59 |
def __repr__(self): |
60 |
return 'KnitParentsProvider(%r)' % self._knit |
|
61 |
||
|
3099.3.3
by John Arbash Meinel
Deprecate get_parents() in favor of get_parent_map() |
62 |
@symbol_versioning.deprecated_method(symbol_versioning.one_one) |
|
2490.2.13
by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept |
63 |
def get_parents(self, revision_ids): |
|
3099.3.1
by John Arbash Meinel
Implement get_parent_map for ParentProviders |
64 |
"""See graph._StackedParentsProvider.get_parents""" |
65 |
parent_map = self.get_parent_map(revision_ids) |
|
66 |
return [parent_map.get(r, None) for r in revision_ids] |
|
67 |
||
68 |
def get_parent_map(self, keys): |
|
69 |
"""See graph._StackedParentsProvider.get_parent_map""" |
|
70 |
parent_map = {} |
|
71 |
for revision_id in keys: |
|
|
2490.2.13
by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept |
72 |
if revision_id == _mod_revision.NULL_REVISION: |
|
3146.1.2
by Aaron Bentley
ParentsProviders now provide tuples of parents, never lists |
73 |
parent_map[revision_id] = () |
|
2490.2.13
by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept |
74 |
else: |
75 |
try: |
|
|
3146.1.2
by Aaron Bentley
ParentsProviders now provide tuples of parents, never lists |
76 |
parents = tuple( |
77 |
self._knit.get_parents_with_ghosts(revision_id)) |
|
|
2490.2.13
by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept |
78 |
except errors.RevisionNotPresent: |
|
3146.1.1
by Aaron Bentley
Fix bad ghost handling in KnitParentsProvider |
79 |
continue
|
|
2490.2.13
by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept |
80 |
else: |
81 |
if len(parents) == 0: |
|
|
3146.1.2
by Aaron Bentley
ParentsProviders now provide tuples of parents, never lists |
82 |
parents = (_mod_revision.NULL_REVISION,) |
|
3099.3.1
by John Arbash Meinel
Implement get_parent_map for ParentProviders |
83 |
parent_map[revision_id] = parents |
84 |
return parent_map |
|
|
2490.2.13
by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept |
85 |
|
86 |
||
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
87 |
class KnitRepository(MetaDirRepository): |
88 |
"""Knit format repository.""" |
|
89 |
||
|
2889.1.2
by Robert Collins
Review feedback. |
90 |
# These attributes are inherited from the Repository base class. Setting
|
91 |
# them to None ensures that if the constructor is changed to not initialize
|
|
92 |
# them, or a subclass fails to call the constructor, that an error will
|
|
93 |
# 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 |
94 |
_commit_builder_class = None |
95 |
_serializer = None |
|
96 |
||
97 |
def __init__(self, _format, a_bzrdir, control_files, _revision_store, |
|
98 |
control_store, text_store, _commit_builder_class, _serializer): |
|
99 |
MetaDirRepository.__init__(self, _format, a_bzrdir, control_files, |
|
100 |
_revision_store, control_store, text_store) |
|
101 |
self._commit_builder_class = _commit_builder_class |
|
102 |
self._serializer = _serializer |
|
|
2745.6.16
by Aaron Bentley
Update from review |
103 |
self._reconcile_fixes_text_parents = True |
|
2241.1.8
by Martin Pool
Set the repository's serializer in the places it's needed, not in the base class |
104 |
|
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
105 |
def _warn_if_deprecated(self): |
106 |
# This class isn't deprecated
|
|
107 |
pass
|
|
108 |
||
|
2805.6.7
by Robert Collins
Review feedback. |
109 |
def _inventory_add_lines(self, inv_vf, revid, parents, lines, check_content): |
|
2817.2.1
by Robert Collins
* Inventory serialisation no longer double-sha's the content. |
110 |
return inv_vf.add_lines_with_ghosts(revid, parents, lines, |
111 |
check_content=check_content)[0] |
|
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
112 |
|
113 |
@needs_read_lock
|
|
114 |
def _all_revision_ids(self): |
|
115 |
"""See Repository.all_revision_ids().""" |
|
116 |
# Knits get the revision graph from the index of the revision knit, so
|
|
117 |
# it's always possible even if they're on an unlistable transport.
|
|
118 |
return self._revision_store.all_revision_ids(self.get_transaction()) |
|
119 |
||
120 |
def fileid_involved_between_revs(self, from_revid, to_revid): |
|
121 |
"""Find file_id(s) which are involved in the changes between revisions. |
|
122 |
||
123 |
This determines the set of revisions which are involved, and then
|
|
124 |
finds all file ids affected by those revisions.
|
|
125 |
"""
|
|
126 |
vf = self._get_revision_vf() |
|
127 |
from_set = set(vf.get_ancestry(from_revid)) |
|
128 |
to_set = set(vf.get_ancestry(to_revid)) |
|
129 |
changed = to_set.difference(from_set) |
|
130 |
return self._fileid_involved_by_set(changed) |
|
131 |
||
132 |
def fileid_involved(self, last_revid=None): |
|
133 |
"""Find all file_ids modified in the ancestry of last_revid. |
|
134 |
||
135 |
:param last_revid: If None, last_revision() will be used.
|
|
136 |
"""
|
|
137 |
if not last_revid: |
|
138 |
changed = set(self.all_revision_ids()) |
|
139 |
else: |
|
140 |
changed = set(self.get_ancestry(last_revid)) |
|
141 |
if None in changed: |
|
142 |
changed.remove(None) |
|
143 |
return self._fileid_involved_by_set(changed) |
|
144 |
||
145 |
@needs_read_lock
|
|
|
2530.1.1
by Aaron Bentley
Make topological sorting optional for get_ancestry |
146 |
def get_ancestry(self, revision_id, topo_sorted=True): |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
147 |
"""Return a list of revision-ids integrated by a revision. |
148 |
|
|
|
2490.2.32
by Aaron Bentley
Merge of not-sorting-ancestry branch |
149 |
This is topologically sorted, unless 'topo_sorted' is specified as
|
150 |
False.
|
|
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
151 |
"""
|
|
2598.5.1
by Aaron Bentley
Start eliminating the use of None to indicate null revision |
152 |
if _mod_revision.is_null(revision_id): |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
153 |
return [None] |
154 |
vf = self._get_revision_vf() |
|
155 |
try: |
|
|
2530.1.1
by Aaron Bentley
Make topological sorting optional for get_ancestry |
156 |
return [None] + vf.get_ancestry(revision_id, topo_sorted) |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
157 |
except errors.RevisionNotPresent: |
158 |
raise errors.NoSuchRevision(self, revision_id) |
|
159 |
||
|
3184.1.9
by Robert Collins
* ``Repository.get_data_stream`` is now deprecated in favour of |
160 |
@symbol_versioning.deprecated_method(symbol_versioning.one_two) |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
161 |
@needs_read_lock
|
|
2535.3.12
by Andrew Bennetts
Add a first cut of a get_data_stream method to Repository. |
162 |
def get_data_stream(self, revision_ids): |
|
3184.1.9
by Robert Collins
* ``Repository.get_data_stream`` is now deprecated in favour of |
163 |
"""See Repository.get_data_stream. |
164 |
|
|
165 |
Deprecated in 1.2 for get_data_stream_for_search.
|
|
166 |
"""
|
|
167 |
search_result = self.revision_ids_to_search_result(set(revision_ids)) |
|
168 |
return self.get_data_stream_for_search(search_result) |
|
169 |
||
170 |
@needs_read_lock
|
|
171 |
def get_data_stream_for_search(self, search): |
|
172 |
"""See Repository.get_data_stream_for_search.""" |
|
173 |
item_keys = self.item_keys_introduced_by(search.get_keys()) |
|
|
2535.3.62
by Andrew Bennetts
Cosmetic changes. |
174 |
for knit_kind, file_id, versions in item_keys: |
|
2535.3.50
by Andrew Bennetts
Use tuple names in data streams rather than concatenated strings. |
175 |
name = (knit_kind,) |
|
2535.3.12
by Andrew Bennetts
Add a first cut of a get_data_stream method to Repository. |
176 |
if knit_kind == 'file': |
|
2535.3.50
by Andrew Bennetts
Use tuple names in data streams rather than concatenated strings. |
177 |
name = ('file', file_id) |
|
2535.3.27
by Andrew Bennetts
Merge from bzr.dev. |
178 |
knit = self.weave_store.get_weave_or_empty( |
|
2535.3.12
by Andrew Bennetts
Add a first cut of a get_data_stream method to Repository. |
179 |
file_id, self.get_transaction()) |
180 |
elif knit_kind == 'inventory': |
|
181 |
knit = self.get_inventory_weave() |
|
182 |
elif knit_kind == 'revisions': |
|
|
2535.3.28
by Andrew Bennetts
Use self._revision_store.get_revision_file rather that self.control_store.get_weave('revisions', ...) |
183 |
knit = self._revision_store.get_revision_file( |
184 |
self.get_transaction()) |
|
|
2535.3.25
by Andrew Bennetts
Fetch signatures too. |
185 |
elif knit_kind == 'signatures': |
186 |
knit = self._revision_store.get_signature_file( |
|
187 |
self.get_transaction()) |
|
|
2535.3.12
by Andrew Bennetts
Add a first cut of a get_data_stream method to Repository. |
188 |
else: |
189 |
raise AssertionError('Unknown knit kind %r' % (knit_kind,)) |
|
|
2535.3.53
by Andrew Bennetts
Remove get_stream_as_bytes from KnitVersionedFile's API, make it a function in knitrepo.py instead. |
190 |
yield name, _get_stream_as_bytes(knit, versions) |
|
2535.3.12
by Andrew Bennetts
Add a first cut of a get_data_stream method to Repository. |
191 |
|
192 |
@needs_read_lock
|
|
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
193 |
def get_revision(self, revision_id): |
194 |
"""Return the Revision object for a named revision""" |
|
|
2249.5.16
by John Arbash Meinel
[merge] bzr.dev 2283 |
195 |
revision_id = osutils.safe_revision_id(revision_id) |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
196 |
return self.get_revision_reconcile(revision_id) |
197 |
||
198 |
@needs_read_lock
|
|
199 |
def get_revision_graph(self, revision_id=None): |
|
200 |
"""Return a dictionary containing the revision graph. |
|
201 |
||
202 |
:param revision_id: The revision_id to get a graph from. If None, then
|
|
203 |
the entire revision graph is returned. This is a deprecated mode of
|
|
204 |
operation and will be removed in the future.
|
|
205 |
:return: a dictionary of revision_id->revision_parents_list.
|
|
206 |
"""
|
|
|
2592.3.111
by Robert Collins
Make the temporary back for autopacking vs pack to pack fetching distinguishable. |
207 |
if 'evil' in debug.debug_flags: |
|
2592.3.112
by Robert Collins
Various fixups found dogfooding. |
208 |
mutter_callsite(3, |
|
2592.3.111
by Robert Collins
Make the temporary back for autopacking vs pack to pack fetching distinguishable. |
209 |
"get_revision_graph scales with size of history.") |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
210 |
# special case NULL_REVISION
|
211 |
if revision_id == _mod_revision.NULL_REVISION: |
|
212 |
return {} |
|
213 |
a_weave = self._get_revision_vf() |
|
214 |
if revision_id is None: |
|
215 |
return a_weave.get_graph() |
|
|
2592.3.43
by Robert Collins
A knit iter_parents API. |
216 |
if revision_id not in a_weave: |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
217 |
raise errors.NoSuchRevision(self, revision_id) |
218 |
else: |
|
219 |
# add what can be reached from revision_id
|
|
|
2652.1.1
by John Arbash Meinel
Avoid set.difference_update(other) because it is slow when other is big. |
220 |
return a_weave.get_graph([revision_id]) |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
221 |
|
222 |
@needs_read_lock
|
|
|
3228.4.11
by John Arbash Meinel
Deprecations abound. |
223 |
@symbol_versioning.deprecated_method(symbol_versioning.one_three) |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
224 |
def get_revision_graph_with_ghosts(self, revision_ids=None): |
225 |
"""Return a graph of the revisions with ghosts marked as applicable. |
|
226 |
||
227 |
:param revision_ids: an iterable of revisions to graph or None for all.
|
|
228 |
:return: a Graph object with the graph reachable from revision_ids.
|
|
229 |
"""
|
|
|
2592.3.112
by Robert Collins
Various fixups found dogfooding. |
230 |
if 'evil' in debug.debug_flags: |
231 |
mutter_callsite(3, |
|
232 |
"get_revision_graph_with_ghosts scales with size of history.") |
|
|
2490.2.21
by Aaron Bentley
Rename graph to deprecated_graph |
233 |
result = deprecated_graph.Graph() |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
234 |
vf = self._get_revision_vf() |
235 |
versions = set(vf.versions()) |
|
236 |
if not revision_ids: |
|
237 |
pending = set(self.all_revision_ids()) |
|
238 |
required = set([]) |
|
239 |
else: |
|
|
2858.2.1
by Martin Pool
Remove most calls to safe_file_id and safe_revision_id. |
240 |
pending = set(revision_ids) |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
241 |
# special case NULL_REVISION
|
242 |
if _mod_revision.NULL_REVISION in pending: |
|
243 |
pending.remove(_mod_revision.NULL_REVISION) |
|
244 |
required = set(pending) |
|
245 |
done = set([]) |
|
246 |
while len(pending): |
|
247 |
revision_id = pending.pop() |
|
248 |
if not revision_id in versions: |
|
249 |
if revision_id in required: |
|
250 |
raise errors.NoSuchRevision(self, revision_id) |
|
251 |
# a ghost
|
|
252 |
result.add_ghost(revision_id) |
|
253 |
# mark it as done so we don't try for it again.
|
|
254 |
done.add(revision_id) |
|
255 |
continue
|
|
256 |
parent_ids = vf.get_parents_with_ghosts(revision_id) |
|
257 |
for parent_id in parent_ids: |
|
258 |
# is this queued or done ?
|
|
259 |
if (parent_id not in pending and |
|
260 |
parent_id not in done): |
|
261 |
# no, queue it.
|
|
262 |
pending.add(parent_id) |
|
263 |
result.add_node(revision_id, parent_ids) |
|
264 |
done.add(revision_id) |
|
265 |
return result |
|
266 |
||
267 |
def _get_revision_vf(self): |
|
268 |
""":return: a versioned file containing the revisions.""" |
|
269 |
vf = self._revision_store.get_revision_file(self.get_transaction()) |
|
270 |
return vf |
|
271 |
||
|
2230.3.54
by Aaron Bentley
Move reverse history iteration to repository |
272 |
def _get_history_vf(self): |
273 |
"""Get a versionedfile whose history graph reflects all revisions. |
|
274 |
||
275 |
For knit repositories, this is the revision knit.
|
|
276 |
"""
|
|
277 |
return self._get_revision_vf() |
|
278 |
||
|
3172.3.1
by Robert Collins
Repository has a new method ``has_revisions`` which signals the presence |
279 |
def has_revisions(self, revision_ids): |
280 |
"""See Repository.has_revisions().""" |
|
281 |
result = set() |
|
282 |
transaction = self.get_transaction() |
|
283 |
for revision_id in revision_ids: |
|
284 |
if self._revision_store.has_revision_id(revision_id, transaction): |
|
285 |
result.add(revision_id) |
|
286 |
return result |
|
287 |
||
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
288 |
@needs_write_lock
|
289 |
def reconcile(self, other=None, thorough=False): |
|
290 |
"""Reconcile this repository.""" |
|
291 |
from bzrlib.reconcile import KnitReconciler |
|
292 |
reconciler = KnitReconciler(self, thorough=thorough) |
|
293 |
reconciler.reconcile() |
|
294 |
return reconciler |
|
295 |
||
296 |
def revision_parents(self, revision_id): |
|
297 |
return self._get_revision_vf().get_parents(revision_id) |
|
|
2241.1.5
by Martin Pool
Move KnitFormat2 into repofmt |
298 |
|
|
2490.2.13
by Aaron Bentley
Update distinct -> lowest, refactor, add ParentsProvider concept |
299 |
def _make_parents_provider(self): |
300 |
return _KnitParentsProvider(self._get_revision_vf()) |
|
301 |
||
|
2819.2.1
by Andrew Bennetts
Implement KnitRepository._find_inconsistent_revision_parents. |
302 |
def _find_inconsistent_revision_parents(self): |
303 |
"""Find revisions with different parent lists in the revision object |
|
304 |
and in the index graph.
|
|
|
2819.2.2
by Andrew Bennetts
Implement _check_for_inconsistent_revision_parents. |
305 |
|
306 |
:returns: an iterator yielding tuples of (revison-id, parents-in-index,
|
|
307 |
parents-in-revision).
|
|
|
2819.2.1
by Andrew Bennetts
Implement KnitRepository._find_inconsistent_revision_parents. |
308 |
"""
|
|
2592.3.214
by Robert Collins
Merge bzr.dev. |
309 |
assert self.is_locked() |
|
2819.2.1
by Andrew Bennetts
Implement KnitRepository._find_inconsistent_revision_parents. |
310 |
vf = self._get_revision_vf() |
|
2592.3.214
by Robert Collins
Merge bzr.dev. |
311 |
for index_version in vf.versions(): |
312 |
parents_according_to_index = tuple(vf.get_parents_with_ghosts( |
|
313 |
index_version)) |
|
314 |
revision = self.get_revision(index_version) |
|
315 |
parents_according_to_revision = tuple(revision.parent_ids) |
|
|
2819.2.1
by Andrew Bennetts
Implement KnitRepository._find_inconsistent_revision_parents. |
316 |
if parents_according_to_index != parents_according_to_revision: |
317 |
yield (index_version, parents_according_to_index, |
|
318 |
parents_according_to_revision) |
|
319 |
||
|
2819.2.2
by Andrew Bennetts
Implement _check_for_inconsistent_revision_parents. |
320 |
def _check_for_inconsistent_revision_parents(self): |
321 |
inconsistencies = list(self._find_inconsistent_revision_parents()) |
|
322 |
if inconsistencies: |
|
323 |
raise errors.BzrCheckError( |
|
324 |
"Revision knit has inconsistent parents.") |
|
325 |
||
|
2819.2.4
by Andrew Bennetts
Add a 'revision_graph_can_have_wrong_parents' method to repository. |
326 |
def revision_graph_can_have_wrong_parents(self): |
327 |
# The revision.kndx could potentially claim a revision has a different
|
|
328 |
# parent to the revision text.
|
|
329 |
return True |
|
330 |
||
|
2241.1.5
by Martin Pool
Move KnitFormat2 into repofmt |
331 |
|
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
332 |
class RepositoryFormatKnit(MetaDirRepositoryFormat): |
333 |
"""Bzr repository knit format (generalized). |
|
334 |
||
335 |
This repository format has:
|
|
336 |
- knits for file texts and inventory
|
|
337 |
- hash subdirectory based stores.
|
|
338 |
- knits for revisions and signatures
|
|
339 |
- TextStores for revisions and signatures.
|
|
340 |
- a format marker of its own
|
|
341 |
- an optional 'shared-storage' flag
|
|
342 |
- an optional 'no-working-trees' flag
|
|
343 |
- a LockDir lock
|
|
344 |
"""
|
|
345 |
||
|
2857.2.2
by Robert Collins
Review feedback. |
346 |
# Set this attribute in derived classes to control the repository class
|
347 |
# created by open and initialize.
|
|
348 |
repository_class = None |
|
|
2889.1.1
by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into |
349 |
# Set this attribute in derived classes to control the
|
350 |
# _commit_builder_class that the repository objects will have passed to
|
|
351 |
# their constructor.
|
|
352 |
_commit_builder_class = None |
|
353 |
# Set this attribute in derived clases to control the _serializer that the
|
|
354 |
# repository objects will have passed to their constructor.
|
|
355 |
_serializer = xml5.serializer_v5 |
|
|
2949.1.2
by Robert Collins
* Fetch with pack repositories will no longer read the entire history graph. |
356 |
# Knit based repositories handle ghosts reasonably well.
|
357 |
supports_ghosts = True |
|
|
3221.3.1
by Robert Collins
* Repository formats have a new supported-feature attribute |
358 |
# External lookups are not supported in this format.
|
359 |
supports_external_lookups = False |
|
|
2857.2.2
by Robert Collins
Review feedback. |
360 |
|
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
361 |
def _get_control_store(self, repo_transport, control_files): |
362 |
"""Return the control store for this repository.""" |
|
363 |
return VersionedFileStore( |
|
364 |
repo_transport, |
|
365 |
prefixed=False, |
|
366 |
file_mode=control_files._file_mode, |
|
367 |
versionedfile_class=knit.KnitVersionedFile, |
|
368 |
versionedfile_kwargs={'factory':knit.KnitPlainFactory()}, |
|
369 |
)
|
|
370 |
||
371 |
def _get_revision_store(self, repo_transport, control_files): |
|
372 |
"""See RepositoryFormat._get_revision_store().""" |
|
373 |
versioned_file_store = VersionedFileStore( |
|
374 |
repo_transport, |
|
375 |
file_mode=control_files._file_mode, |
|
376 |
prefixed=False, |
|
377 |
precious=True, |
|
378 |
versionedfile_class=knit.KnitVersionedFile, |
|
379 |
versionedfile_kwargs={'delta':False, |
|
380 |
'factory':knit.KnitPlainFactory(), |
|
381 |
},
|
|
382 |
escaped=True, |
|
383 |
)
|
|
384 |
return KnitRevisionStore(versioned_file_store) |
|
385 |
||
386 |
def _get_text_store(self, transport, control_files): |
|
387 |
"""See RepositoryFormat._get_text_store().""" |
|
388 |
return self._get_versioned_file_store('knits', |
|
389 |
transport, |
|
390 |
control_files, |
|
391 |
versionedfile_class=knit.KnitVersionedFile, |
|
392 |
versionedfile_kwargs={ |
|
393 |
'create_parent_dir':True, |
|
394 |
'delay_create':True, |
|
395 |
'dir_mode':control_files._dir_mode, |
|
396 |
},
|
|
397 |
escaped=True) |
|
398 |
||
399 |
def initialize(self, a_bzrdir, shared=False): |
|
400 |
"""Create a knit format 1 repository. |
|
401 |
||
402 |
:param a_bzrdir: bzrdir to contain the new repository; must already
|
|
403 |
be initialized.
|
|
404 |
:param shared: If true the repository will be initialized as a shared
|
|
405 |
repository.
|
|
406 |
"""
|
|
407 |
mutter('creating repository in %s.', a_bzrdir.transport.base) |
|
|
2592.3.60
by Robert Collins
Nuke per-fileid indices for a single unified index. |
408 |
dirs = ['knits'] |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
409 |
files = [] |
410 |
utf8_files = [('format', self.get_format_string())] |
|
411 |
||
412 |
self._upload_blank_content(a_bzrdir, dirs, files, utf8_files, shared) |
|
413 |
repo_transport = a_bzrdir.get_repository_transport(None) |
|
414 |
control_files = lockable_files.LockableFiles(repo_transport, |
|
415 |
'lock', lockdir.LockDir) |
|
416 |
control_store = self._get_control_store(repo_transport, control_files) |
|
417 |
transaction = transactions.WriteTransaction() |
|
418 |
# trigger a write of the inventory store.
|
|
419 |
control_store.get_weave_or_empty('inventory', transaction) |
|
420 |
_revision_store = self._get_revision_store(repo_transport, control_files) |
|
421 |
# the revision id here is irrelevant: it will not be stored, and cannot
|
|
422 |
# already exist.
|
|
423 |
_revision_store.has_revision_id('A', transaction) |
|
424 |
_revision_store.get_signature_file(transaction) |
|
425 |
return self.open(a_bzrdir=a_bzrdir, _found=True) |
|
426 |
||
427 |
def open(self, a_bzrdir, _found=False, _override_transport=None): |
|
428 |
"""See RepositoryFormat.open(). |
|
429 |
|
|
430 |
:param _override_transport: INTERNAL USE ONLY. Allows opening the
|
|
431 |
repository at a slightly different url
|
|
432 |
than normal. I.e. during 'upgrade'.
|
|
433 |
"""
|
|
434 |
if not _found: |
|
435 |
format = RepositoryFormat.find_format(a_bzrdir) |
|
436 |
assert format.__class__ == self.__class__ |
|
437 |
if _override_transport is not None: |
|
438 |
repo_transport = _override_transport |
|
439 |
else: |
|
440 |
repo_transport = a_bzrdir.get_repository_transport(None) |
|
441 |
control_files = lockable_files.LockableFiles(repo_transport, |
|
442 |
'lock', lockdir.LockDir) |
|
443 |
text_store = self._get_text_store(repo_transport, control_files) |
|
444 |
control_store = self._get_control_store(repo_transport, control_files) |
|
445 |
_revision_store = self._get_revision_store(repo_transport, control_files) |
|
|
2592.3.22
by Robert Collins
Add new experimental repository formats. |
446 |
return self.repository_class(_format=self, |
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
447 |
a_bzrdir=a_bzrdir, |
448 |
control_files=control_files, |
|
449 |
_revision_store=_revision_store, |
|
450 |
control_store=control_store, |
|
|
2889.1.1
by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into |
451 |
text_store=text_store, |
452 |
_commit_builder_class=self._commit_builder_class, |
|
453 |
_serializer=self._serializer) |
|
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
454 |
|
455 |
||
456 |
class RepositoryFormatKnit1(RepositoryFormatKnit): |
|
457 |
"""Bzr repository knit format 1. |
|
458 |
||
459 |
This repository format has:
|
|
460 |
- knits for file texts and inventory
|
|
461 |
- hash subdirectory based stores.
|
|
462 |
- knits for revisions and signatures
|
|
463 |
- TextStores for revisions and signatures.
|
|
464 |
- a format marker of its own
|
|
465 |
- an optional 'shared-storage' flag
|
|
466 |
- an optional 'no-working-trees' flag
|
|
467 |
- a LockDir lock
|
|
468 |
||
469 |
This format was introduced in bzr 0.8.
|
|
470 |
"""
|
|
|
2241.1.11
by Martin Pool
Get rid of RepositoryFormat*_instance objects. Instead the format |
471 |
|
|
2592.3.22
by Robert Collins
Add new experimental repository formats. |
472 |
repository_class = KnitRepository |
|
2889.1.1
by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into |
473 |
_commit_builder_class = CommitBuilder |
474 |
_serializer = xml5.serializer_v5 |
|
|
2592.3.22
by Robert Collins
Add new experimental repository formats. |
475 |
|
|
2100.3.35
by Aaron Bentley
equality operations on bzrdir |
476 |
def __ne__(self, other): |
|
2100.3.31
by Aaron Bentley
Merged bzr.dev (17 tests failing) |
477 |
return self.__class__ is not other.__class__ |
478 |
||
|
2241.1.6
by Martin Pool
Move Knit repositories into the submodule bzrlib.repofmt.knitrepo and |
479 |
def get_format_string(self): |
480 |
"""See RepositoryFormat.get_format_string().""" |
|
481 |
return "Bazaar-NG Knit Repository Format 1" |
|
482 |
||
483 |
def get_format_description(self): |
|
484 |
"""See RepositoryFormat.get_format_description().""" |
|
485 |
return "Knit repository format 1" |
|
486 |
||
487 |
def check_conversion_target(self, target_format): |
|
488 |
pass
|
|
489 |
||
490 |
||
|
2255.2.211
by Robert Collins
Remove knit2 repository format- it has never been supported. |
491 |
class RepositoryFormatKnit3(RepositoryFormatKnit): |
|
2996.2.5
by Aaron Bentley
Correct docstring |
492 |
"""Bzr repository knit format 3. |
|
2255.2.211
by Robert Collins
Remove knit2 repository format- it has never been supported. |
493 |
|
|
2100.3.31
by Aaron Bentley
Merged bzr.dev (17 tests failing) |
494 |
This repository format has:
|
495 |
- knits for file texts and inventory
|
|
496 |
- hash subdirectory based stores.
|
|
497 |
- knits for revisions and signatures
|
|
498 |
- TextStores for revisions and signatures.
|
|
499 |
- a format marker of its own
|
|
500 |
- an optional 'shared-storage' flag
|
|
501 |
- an optional 'no-working-trees' flag
|
|
502 |
- a LockDir lock
|
|
503 |
- support for recording full info about the tree root
|
|
504 |
- support for recording tree-references
|
|
505 |
"""
|
|
506 |
||
|
2889.1.1
by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into |
507 |
repository_class = KnitRepository |
508 |
_commit_builder_class = RootCommitBuilder |
|
|
2255.2.211
by Robert Collins
Remove knit2 repository format- it has never been supported. |
509 |
rich_root_data = True |
|
2323.5.16
by Martin Pool
rename support_tree_reference to supports_ |
510 |
supports_tree_reference = True |
|
2889.1.1
by Robert Collins
* The class ``bzrlib.repofmt.knitrepo.KnitRepository3`` has been folded into |
511 |
_serializer = xml7.serializer_v7 |
|
2100.3.31
by Aaron Bentley
Merged bzr.dev (17 tests failing) |
512 |
|
513 |
def _get_matching_bzrdir(self): |
|
|
2255.2.194
by Robert Collins
[BROKEN] Many updates to stop using experimental formats in tests. |
514 |
return bzrdir.format_registry.make_bzrdir('dirstate-with-subtree') |
|
2100.3.31
by Aaron Bentley
Merged bzr.dev (17 tests failing) |
515 |
|
516 |
def _ignore_setting_bzrdir(self, format): |
|
517 |
pass
|
|
518 |
||
519 |
_matchingbzrdir = property(_get_matching_bzrdir, _ignore_setting_bzrdir) |
|
520 |
||
521 |
def check_conversion_target(self, target_format): |
|
|
2255.2.211
by Robert Collins
Remove knit2 repository format- it has never been supported. |
522 |
if not target_format.rich_root_data: |
523 |
raise errors.BadConversionTarget( |
|
524 |
'Does not support rich root data.', target_format) |
|
|
2323.5.16
by Martin Pool
rename support_tree_reference to supports_ |
525 |
if not getattr(target_format, 'supports_tree_reference', False): |
|
2100.3.31
by Aaron Bentley
Merged bzr.dev (17 tests failing) |
526 |
raise errors.BadConversionTarget( |
527 |
'Does not support nested trees', target_format) |
|
528 |
||
529 |
def get_format_string(self): |
|
530 |
"""See RepositoryFormat.get_format_string().""" |
|
|
2255.2.230
by Robert Collins
Update tree format signatures to mention introducing bzr version. |
531 |
return "Bazaar Knit Repository Format 3 (bzr 0.15)\n" |
|
2100.3.31
by Aaron Bentley
Merged bzr.dev (17 tests failing) |
532 |
|
533 |
def get_format_description(self): |
|
534 |
"""See RepositoryFormat.get_format_description().""" |
|
535 |
return "Knit repository format 3" |
|
536 |
||
|
2535.3.53
by Andrew Bennetts
Remove get_stream_as_bytes from KnitVersionedFile's API, make it a function in knitrepo.py instead. |
537 |
|
|
2996.2.1
by Aaron Bentley
Add KnitRepositoryFormat4 |
538 |
class RepositoryFormatKnit4(RepositoryFormatKnit): |
539 |
"""Bzr repository knit format 4. |
|
540 |
||
541 |
This repository format has everything in format 3, except for
|
|
542 |
tree-references:
|
|
543 |
- knits for file texts and inventory
|
|
544 |
- hash subdirectory based stores.
|
|
545 |
- knits for revisions and signatures
|
|
546 |
- TextStores for revisions and signatures.
|
|
547 |
- a format marker of its own
|
|
548 |
- an optional 'shared-storage' flag
|
|
549 |
- an optional 'no-working-trees' flag
|
|
550 |
- a LockDir lock
|
|
551 |
- support for recording full info about the tree root
|
|
552 |
"""
|
|
553 |
||
554 |
repository_class = KnitRepository |
|
555 |
_commit_builder_class = RootCommitBuilder |
|
556 |
rich_root_data = True |
|
557 |
supports_tree_reference = False |
|
558 |
_serializer = xml6.serializer_v6 |
|
559 |
||
560 |
def _get_matching_bzrdir(self): |
|
561 |
return bzrdir.format_registry.make_bzrdir('rich-root') |
|
562 |
||
563 |
def _ignore_setting_bzrdir(self, format): |
|
564 |
pass
|
|
565 |
||
566 |
_matchingbzrdir = property(_get_matching_bzrdir, _ignore_setting_bzrdir) |
|
567 |
||
568 |
def check_conversion_target(self, target_format): |
|
569 |
if not target_format.rich_root_data: |
|
570 |
raise errors.BadConversionTarget( |
|
571 |
'Does not support rich root data.', target_format) |
|
572 |
||
573 |
def get_format_string(self): |
|
574 |
"""See RepositoryFormat.get_format_string().""" |
|
575 |
return 'Bazaar Knit Repository Format 4 (bzr 1.0)\n' |
|
576 |
||
577 |
def get_format_description(self): |
|
578 |
"""See RepositoryFormat.get_format_description().""" |
|
579 |
return "Knit repository format 4" |
|
580 |
||
581 |
||
|
2535.3.53
by Andrew Bennetts
Remove get_stream_as_bytes from KnitVersionedFile's API, make it a function in knitrepo.py instead. |
582 |
def _get_stream_as_bytes(knit, required_versions): |
583 |
"""Generate a serialised data stream. |
|
584 |
||
585 |
The format is a bencoding of a list. The first element of the list is a
|
|
586 |
string of the format signature, then each subsequent element is a list
|
|
587 |
corresponding to a record. Those lists contain:
|
|
588 |
||
589 |
* a version id
|
|
590 |
* a list of options
|
|
591 |
* a list of parents
|
|
592 |
* the bytes
|
|
593 |
||
594 |
:returns: a bencoded list.
|
|
595 |
"""
|
|
596 |
knit_stream = knit.get_data_stream(required_versions) |
|
597 |
format_signature, data_list, callable = knit_stream |
|
598 |
data = [] |
|
599 |
data.append(format_signature) |
|
600 |
for version, options, length, parents in data_list: |
|
601 |
data.append([version, options, parents, callable(length)]) |
|
602 |
return bencode.bencode(data) |