mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-18 08:38:46 +00:00
55 lines
1.4 KiB
Go
55 lines
1.4 KiB
Go
package merkle_tree
|
|
|
|
import "encoding/binary"
|
|
|
|
// PackUint64IntoChunks packs a list of uint64 values into 32 byte roots.
|
|
func PackUint64IntoChunks(vals []uint64) [][32]byte {
|
|
numChunks := (len(vals) + 3) / 4
|
|
chunks := make([][32]byte, numChunks)
|
|
for i := 0; i < len(vals); i++ {
|
|
chunkIndex := i / 4
|
|
byteIndex := (i % 4) * 8
|
|
binary.LittleEndian.PutUint64(chunks[chunkIndex][byteIndex:byteIndex+8], vals[i])
|
|
}
|
|
return chunks
|
|
}
|
|
|
|
func PackSlashings(serializedItems [][]byte) ([][32]byte, error) {
|
|
emptyChunk := [32]byte{}
|
|
|
|
// If there are no items, return an empty chunk
|
|
if len(serializedItems) == 0 {
|
|
return [][32]byte{emptyChunk}, nil
|
|
}
|
|
|
|
// If all items are exactly 32 bytes long, return them as is
|
|
if len(serializedItems[0]) == 32 {
|
|
chunks := make([][32]byte, len(serializedItems))
|
|
for i, c := range serializedItems {
|
|
copy(chunks[i][:], c)
|
|
}
|
|
return chunks, nil
|
|
}
|
|
|
|
// Flatten the list of items
|
|
orderedItems := make([]byte, 0, len(serializedItems)*len(serializedItems[0]))
|
|
for _, item := range serializedItems {
|
|
orderedItems = append(orderedItems, item...)
|
|
}
|
|
|
|
// If the flattened list is empty, return an empty chunk
|
|
if len(orderedItems) == 0 {
|
|
return [][32]byte{emptyChunk}, nil
|
|
}
|
|
|
|
// Pack the flattened list into chunks of 32 bytes
|
|
var chunks [][32]byte
|
|
for i := 0; i < len(orderedItems); i += 32 {
|
|
var chunk [32]byte
|
|
copy(chunk[:], orderedItems[i:i+32])
|
|
chunks = append(chunks, chunk)
|
|
}
|
|
|
|
return chunks, nil
|
|
}
|