mirror of
https://github.com/status-im/nim-codex.git
synced 2025-01-26 10:39:24 +00:00
2396c4d76d
* Blockexchange uses merkle root and index to fetch blocks * Links the network store getTree to the local store. * Update codex/stores/repostore.nim Co-authored-by: Dmitriy Ryajov <dryajov@gmail.com> Signed-off-by: Tomasz Bekas <tomasz.bekas@gmail.com> * Rework erasure.nim to include recent cleanup * Revert accidential changes to lib versions * Addressing review comments * Storing proofs instead of trees * Fix a comment * Fix broken tests * Fix for broken testerasure.nim * Addressing PR comments --------- Signed-off-by: Tomasz Bekas <tomasz.bekas@gmail.com> Co-authored-by: benbierens <thatbenbierens@gmail.com> Co-authored-by: Dmitriy Ryajov <dryajov@gmail.com>
46 lines
837 B
Nim
46 lines
837 B
Nim
import std/sequtils
|
|
|
|
import pkg/chronos
|
|
|
|
import pkg/codex/chunker
|
|
import pkg/codex/rng
|
|
|
|
export chunker
|
|
|
|
type
|
|
MockChunker* = Chunker
|
|
|
|
proc new*(
|
|
T: type MockChunker,
|
|
dataset: openArray[byte],
|
|
chunkSize: int | NBytes,
|
|
pad: bool = false
|
|
): MockChunker =
|
|
## Create a chunker that produces data
|
|
##
|
|
|
|
let
|
|
chunkSize = chunkSize.NBytes
|
|
dataset = @dataset
|
|
|
|
var consumed = 0
|
|
proc reader(data: ChunkBuffer, len: int): Future[int] {.async, gcsafe, raises: [Defect].} =
|
|
|
|
if consumed >= dataset.len:
|
|
return 0
|
|
|
|
var read = 0
|
|
while read < len and
|
|
read < chunkSize.int and
|
|
(consumed + read) < dataset.len:
|
|
data[read] = dataset[consumed + read]
|
|
read.inc
|
|
|
|
consumed += read
|
|
return read
|
|
|
|
Chunker.new(
|
|
reader = reader,
|
|
pad = pad,
|
|
chunkSize = chunkSize)
|