decode: fix CID assigned to padding block
Signed-off-by: Csaba Kiraly <csaba.kiraly@gmail.com>
This commit is contained in:
parent
4275814c8a
commit
41c78b8d98
|
@ -463,7 +463,8 @@ proc decode*(
|
||||||
|
|
||||||
for i in 0..<encoded.ecK:
|
for i in 0..<encoded.ecK:
|
||||||
let idx = newIndex(encoded, step, column, i)
|
let idx = newIndex(encoded, step, column, i)
|
||||||
if data[i].len <= 0 and not cids[idx].isEmpty:
|
if data[i].len <= 0 and not (cids[idx].isEmpty or encoded.isPadding(idx)):
|
||||||
|
# if block was missing, and it wasn't padding, restore the block
|
||||||
without blk =? bt.Block.new(recovered[i]), error:
|
without blk =? bt.Block.new(recovered[i]), error:
|
||||||
trace "Unable to create block!", exc = error.msg
|
trace "Unable to create block!", exc = error.msg
|
||||||
return failure(error)
|
return failure(error)
|
||||||
|
@ -475,6 +476,10 @@ proc decode*(
|
||||||
|
|
||||||
cids[idx] = blk.cid
|
cids[idx] = blk.cid
|
||||||
recoveredIndices.add(idx)
|
recoveredIndices.add(idx)
|
||||||
|
elif data[i].len <= 0 and encoded.isPadding(idx):
|
||||||
|
without emptyBlockCid =? emptyCid(encoded.version, encoded.hcodec, encoded.codec), err:
|
||||||
|
return failure(err)
|
||||||
|
cids[idx] = emptyBlockCid
|
||||||
except CancelledError as exc:
|
except CancelledError as exc:
|
||||||
trace "Erasure coding decoding cancelled"
|
trace "Erasure coding decoding cancelled"
|
||||||
raise exc # cancellation needs to be propagated
|
raise exc # cancellation needs to be propagated
|
||||||
|
|
Loading…
Reference in New Issue