62 lines
1.2 KiB
Go
62 lines
1.2 KiB
Go
|
package mpt
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
|
||
|
"github.com/nspcc-dev/neo-go/pkg/io"
|
||
|
"github.com/nspcc-dev/neo-go/pkg/util"
|
||
|
)
|
||
|
|
||
|
// HashNode represents MPT's hash node.
|
||
|
type HashNode struct {
|
||
|
hash util.Uint256
|
||
|
valid bool
|
||
|
}
|
||
|
|
||
|
var _ Node = (*HashNode)(nil)
|
||
|
|
||
|
// NewHashNode returns hash node with the specified hash.
|
||
|
func NewHashNode(h util.Uint256) *HashNode {
|
||
|
return &HashNode{
|
||
|
hash: h,
|
||
|
valid: true,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Type implements Node interface.
|
||
|
func (h *HashNode) Type() NodeType { return HashT }
|
||
|
|
||
|
// Hash implements Node interface.
|
||
|
func (h *HashNode) Hash() util.Uint256 {
|
||
|
if !h.valid {
|
||
|
panic("can't get hash of an empty HashNode")
|
||
|
}
|
||
|
return h.hash
|
||
|
}
|
||
|
|
||
|
// IsEmpty returns true iff h is an empty node i.e. contains no hash.
|
||
|
func (h *HashNode) IsEmpty() bool { return !h.valid }
|
||
|
|
||
|
// DecodeBinary implements io.Serializable.
|
||
|
func (h *HashNode) DecodeBinary(r *io.BinReader) {
|
||
|
sz := r.ReadVarUint()
|
||
|
switch sz {
|
||
|
case 0:
|
||
|
h.valid = false
|
||
|
case util.Uint256Size:
|
||
|
h.valid = true
|
||
|
r.ReadBytes(h.hash[:])
|
||
|
default:
|
||
|
r.Err = fmt.Errorf("invalid hash node size: %d", sz)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// EncodeBinary implements io.Serializable.
|
||
|
func (h HashNode) EncodeBinary(w *io.BinWriter) {
|
||
|
if !h.valid {
|
||
|
w.WriteVarUint(0)
|
||
|
return
|
||
|
}
|
||
|
w.WriteVarBytes(h.hash[:])
|
||
|
}
|