15
15
# along with this program; if not, write to the Free Software
16
16
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19
from bzrlib.trace import note, warning
21
def _update_store_entry(obj, obj_id, branch, store_name, store):
22
"""This is just a meta-function, which handles both revision entries
23
and inventory entries.
25
from bzrlib.trace import mutter
26
import tempfile, os, errno
27
from osutils import rename
28
obj_tmp = tempfile.TemporaryFile()
29
obj.write_xml(obj_tmp)
32
tmpfd, tmp_path = tempfile.mkstemp(prefix=obj_id, suffix='.gz',
33
dir=branch.controlfilename(store_name))
36
orig_obj_path = branch.controlfilename([store_name, obj_id+'.gz'])
37
# Remove the old entry out of the way
38
rename(orig_obj_path, tmp_path)
40
# TODO: We may need to handle the case where the old
41
# entry was not compressed (and thus did not end with .gz)
43
store.add(obj_tmp, obj_id) # Add the new one
44
os.remove(tmp_path) # Remove the old name
45
mutter(' Updated %s entry {%s}' % (store_name, obj_id))
47
# On any exception, restore the old entry
48
rename(tmp_path, orig_obj_path)
51
if os.path.exists(tmp_path):
52
# Unfortunately, the next command might throw
53
# an exception, which will mask a previous exception.
57
def _update_revision_entry(rev, branch):
58
"""After updating the values in a revision, make sure to
59
write out the data, but try to do it in an atomic manner.
61
:param rev: The Revision object to store
62
:param branch: The Branch object where this Revision is to be stored.
64
_update_store_entry(rev, rev.revision_id, branch,
65
'revision-store', branch.revision_store)
67
def _update_inventory_entry(inv, inv_id, branch):
68
"""When an inventory has been modified (such as by adding a unique tree root)
69
this atomically re-generates the file.
71
:param inv: The Inventory
72
:param inv_id: The inventory id for this inventory
73
:param branch: The Branch where this entry will be stored.
75
raise NotImplementedError("can't update existing inventory entry")
83
26
TODO: Check for extra files in the control directory.
85
28
from bzrlib.trace import mutter
86
from bzrlib.errors import BzrCheckError, NoSuchRevision
29
from bzrlib.errors import BzrCheckError
87
30
from bzrlib.osutils import fingerprint_file
88
from bzrlib.inventory import ROOT_ID
89
from bzrlib.branch import gen_root_id
31
from bzrlib.progress import ProgressBar
36
pb = ProgressBar(show_spinner=True)
96
39
missing_inventory_sha_cnt = 0
97
40
missing_revision_sha_cnt = 0
98
missing_revision_cnt = 0
100
42
history = branch.revision_history()
105
47
# for all texts checked, text_id -> sha1
106
48
checked_texts = {}
108
progress = bzrlib.ui.ui_factory.progress_bar()
110
50
for rev_id in history:
112
progress.update('checking revision', revno, revcount)
113
# mutter(' revision {%s}' % rev_id)
52
pb.update('checking revision', revno, revcount)
53
mutter(' revision {%s}' % rev_id)
114
54
rev = branch.get_revision(rev_id)
115
55
if rev.revision_id != rev_id:
116
56
raise BzrCheckError('wrong internal revision id in revision {%s}'
135
75
missing_revision_sha_cnt += 1
137
77
prid = prr.revision_id
140
actual_sha = branch.get_revision_sha1(prid)
141
except NoSuchRevision:
142
missing_revision_cnt += 1
143
mutter("parent {%s} of {%s} not present in store",
78
actual_sha = branch.get_revision_sha1(prid)
147
79
if prr.revision_sha1 != actual_sha:
148
80
raise BzrCheckError("mismatched revision sha1 for "
149
81
"parent {%s} of {%s}: %s vs %s"
155
87
% (rev_id, last_rev_id))
157
if hasattr(rev, 'inventory_id') and rev.inventory_id != rev_id:
89
if rev.inventory_id != rev_id:
158
90
mismatch_inv_id.append(rev_id)
160
92
## TODO: Check all the required fields are present on the revision.
162
94
if rev.inventory_sha1:
163
inv_sha1 = branch.get_inventory_sha1(rev_id)
95
inv_sha1 = branch.get_inventory_sha1(rev.inventory_id)
164
96
if inv_sha1 != rev.inventory_sha1:
165
97
raise BzrCheckError('Inventory sha1 hash doesn\'t match'
166
98
' value in revision {%s}' % rev_id)
230
note('checked %d revisions, %d file texts' % (revcount, len(checked_texts)))
162
print 'checked %d revisions, %d file texts' % (revcount, len(checked_texts))
232
164
if missing_inventory_sha_cnt:
233
note('%d revisions are missing inventory_sha1' % missing_inventory_sha_cnt)
165
print '%d revisions are missing inventory_sha1' % missing_inventory_sha_cnt
235
167
if missing_revision_sha_cnt:
236
note('%d parent links are missing revision_sha1' % missing_revision_sha_cnt)
238
if missing_revision_cnt:
239
note('%d revisions are mentioned but not present' % missing_revision_cnt)
241
if missing_revision_cnt:
242
print '%d revisions are mentioned but not present' % missing_revision_cnt
244
# stub this out for now because the main bzr branch has references
245
# to revisions that aren't present in the store -- mbp 20050804
246
# if (missing_inventory_sha_cnt
247
# or missing_revision_sha_cnt):
248
# print ' (use "bzr upgrade" to fix them)'
168
print '%d parent links are missing revision_sha1' % missing_revision_sha_cnt
170
if (missing_inventory_sha_cnt
171
or missing_revision_sha_cnt):
172
print ' (use "bzr upgrade" to fix them)'
250
174
if mismatch_inv_id:
251
warning('%d revisions have mismatched inventory ids:' % len(mismatch_inv_id))
175
print '%d revisions have mismatched inventory ids:' % len(mismatch_inv_id)
252
176
for rev_id in mismatch_inv_id:
253
warning(' %s', rev_id)