ccaa6dd816
Sync to tip Co-authored-by: Brannon King <countprimes@gmail.com>
44 lines
882 B
Go
44 lines
882 B
Go
package merkletrie
|
|
|
|
import (
|
|
"github.com/btcsuite/btcd/chaincfg/chainhash"
|
|
)
|
|
|
|
type vertex struct {
|
|
merkleHash *chainhash.Hash
|
|
claimsHash *chainhash.Hash
|
|
childLinks map[byte]*vertex
|
|
hasValue bool
|
|
}
|
|
|
|
func newVertex(hash *chainhash.Hash) *vertex {
|
|
return &vertex{childLinks: map[byte]*vertex{}, merkleHash: hash}
|
|
}
|
|
|
|
// TODO: more professional to use msgpack here?
|
|
|
|
// nbuf decodes the on-disk format of a node, which has the following form:
|
|
// ch(1B) hash(32B)
|
|
// ...
|
|
// ch(1B) hash(32B)
|
|
// vhash(32B)
|
|
type nbuf []byte
|
|
|
|
func (nb nbuf) entries() int {
|
|
return len(nb) / 33
|
|
}
|
|
|
|
func (nb nbuf) entry(i int) (byte, *chainhash.Hash) {
|
|
h := chainhash.Hash{}
|
|
copy(h[:], nb[33*i+1:])
|
|
return nb[33*i], &h
|
|
}
|
|
|
|
func (nb nbuf) hasValue() (bool, *chainhash.Hash) {
|
|
if len(nb)%33 == 0 {
|
|
return false, nil
|
|
}
|
|
h := chainhash.Hash{}
|
|
copy(h[:], nb[len(nb)-32:])
|
|
return true, &h
|
|
}
|