wip poseidon tree
This commit is contained in:
parent
80de04889f
commit
eaf052fea9
|
@ -1,39 +0,0 @@
|
|||
## Nim-Codex
|
||||
## Copyright (c) 2023 Status Research & Development GmbH
|
||||
## Licensed under either of
|
||||
## * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
|
||||
## * MIT license ([LICENSE-MIT](LICENSE-MIT))
|
||||
## at your option.
|
||||
## This file may not be copied, modified, or distributed except according to
|
||||
## those terms.
|
||||
|
||||
import pkg/poseidon2
|
||||
import pkg/constantine/math/io/io_fields
|
||||
|
||||
import ./merkletree
|
||||
|
||||
export merkletree, poseidon2
|
||||
|
||||
type
|
||||
Poseidon2Hash* = F
|
||||
|
||||
PoseidonKeysEnum* {.pure.} = enum
|
||||
KeyNone = "0x0"
|
||||
KeyBottomLayer = "0x1"
|
||||
KeyOdd = "0x2"
|
||||
KeyOddAndBottomLayer = "0x3"
|
||||
|
||||
MerkleTreePoseidon2* = MerkleTree[Poseidon2Hash, PoseidonKeysEnum]
|
||||
MerkleProofPoseidon2* = MerkleProof[Poseidon2Hash, PoseidonKeysEnum]
|
||||
|
||||
converter toKey*(x: PoseidonKeysEnum): Poseidon2Hash =
|
||||
return Poseidon2Hash.fromHex($x)
|
||||
|
||||
func init*(_: type MerkleTreePoseidon2, leaves: seq[Poseidon2Hash]): MerkleTreePoseidon2 =
|
||||
let
|
||||
compress = proc(
|
||||
x, y: Poseidon2Hash,
|
||||
key: PoseidonKeysEnum): Poseidon2Hash {.noSideEffect.} =
|
||||
poseidon2.compress( x, y, key )
|
||||
|
||||
MerkleTreePoseidon2(compress: compress, leaves: leaves, zero: zero)
|
Loading…
Reference in New Issue