mirror of
https://github.com/tahoe-lafs/tahoe-lafs.git
synced 2025-01-21 12:05:03 +00:00
hashtree.BadHashError: mention which leaf caused the problem
This commit is contained in:
parent
2db17df833
commit
a383c17444
@ -304,6 +304,14 @@ class IncompleteHashTree(CompleteBinaryTreeMixin, list):
|
|||||||
maybe_needed.add(self.first_leaf_num + leafnum)
|
maybe_needed.add(self.first_leaf_num + leafnum)
|
||||||
return set([i for i in maybe_needed if self[i] is None])
|
return set([i for i in maybe_needed if self[i] is None])
|
||||||
|
|
||||||
|
def _name_hash(self, i):
|
||||||
|
name = "[%d of %d]" % (i, len(self))
|
||||||
|
if i >= self.first_leaf_num:
|
||||||
|
leafnum = i - self.first_leaf_num
|
||||||
|
numleaves = len(self) - self.first_leaf_num
|
||||||
|
name += " (leaf [%d] of %d)" % (leafnum, numleaves)
|
||||||
|
return name
|
||||||
|
|
||||||
def set_hashes(self, hashes={}, leaves={}):
|
def set_hashes(self, hashes={}, leaves={}):
|
||||||
"""Add a bunch of hashes to the tree.
|
"""Add a bunch of hashes to the tree.
|
||||||
|
|
||||||
@ -376,7 +384,9 @@ class IncompleteHashTree(CompleteBinaryTreeMixin, list):
|
|||||||
for i in new_hashes:
|
for i in new_hashes:
|
||||||
if self[i]:
|
if self[i]:
|
||||||
if self[i] != new_hashes[i]:
|
if self[i] != new_hashes[i]:
|
||||||
raise BadHashError("new hash does not match existing hash at [%d]" % i)
|
msg = "new hash does not match existing hash at "
|
||||||
|
msg += self._name_hash(i)
|
||||||
|
raise BadHashError(msg)
|
||||||
else:
|
else:
|
||||||
self[i] = new_hashes[i]
|
self[i] = new_hashes[i]
|
||||||
added.add(i)
|
added.add(i)
|
||||||
|
Loading…
Reference in New Issue
Block a user