forked from TrueCloudLab/neoneo-go
mpt: do not allocate NodeObject for serialization
Signed-off-by: Evgeniy Stratonikov <evgeniy@nspcc.ru>
This commit is contained in:
parent
e41fc2fd1b
commit
43ee671f36
5 changed files with 11 additions and 27 deletions
|
@ -23,7 +23,6 @@ type BaseNodeIface interface {
|
||||||
Hash() util.Uint256
|
Hash() util.Uint256
|
||||||
Type() NodeType
|
Type() NodeType
|
||||||
Bytes() []byte
|
Bytes() []byte
|
||||||
EncodeBinaryAsChild(w *io.BinWriter)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type flushedNode interface {
|
type flushedNode interface {
|
||||||
|
@ -76,6 +75,15 @@ func (b *BaseNode) invalidateCache() {
|
||||||
b.hashValid = false
|
b.hashValid = false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func encodeBinaryAsChild(n Node, w *io.BinWriter) {
|
||||||
|
if isEmpty(n) {
|
||||||
|
w.WriteB(byte(EmptyT))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
w.WriteB(byte(HashT))
|
||||||
|
w.WriteBytes(n.Hash().BytesBE())
|
||||||
|
}
|
||||||
|
|
||||||
// encodeNodeWithType encodes node together with it's type.
|
// encodeNodeWithType encodes node together with it's type.
|
||||||
func encodeNodeWithType(n Node, w *io.BinWriter) {
|
func encodeNodeWithType(n Node, w *io.BinWriter) {
|
||||||
switch t := n.Type(); t {
|
switch t := n.Type(); t {
|
||||||
|
|
|
@ -48,16 +48,10 @@ func (b *BranchNode) Bytes() []byte {
|
||||||
// EncodeBinary implements io.Serializable.
|
// EncodeBinary implements io.Serializable.
|
||||||
func (b *BranchNode) EncodeBinary(w *io.BinWriter) {
|
func (b *BranchNode) EncodeBinary(w *io.BinWriter) {
|
||||||
for i := 0; i < childrenCount; i++ {
|
for i := 0; i < childrenCount; i++ {
|
||||||
b.Children[i].EncodeBinaryAsChild(w)
|
encodeBinaryAsChild(b.Children[i], w)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// EncodeBinaryAsChild implements BaseNode interface.
|
|
||||||
func (b *BranchNode) EncodeBinaryAsChild(w *io.BinWriter) {
|
|
||||||
n := &NodeObject{Node: NewHashNode(b.Hash())} // with type
|
|
||||||
n.EncodeBinary(w)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DecodeBinary implements io.Serializable.
|
// DecodeBinary implements io.Serializable.
|
||||||
func (b *BranchNode) DecodeBinary(r *io.BinReader) {
|
func (b *BranchNode) DecodeBinary(r *io.BinReader) {
|
||||||
for i := 0; i < childrenCount; i++ {
|
for i := 0; i < childrenCount; i++ {
|
||||||
|
|
|
@ -69,13 +69,7 @@ func (e *ExtensionNode) DecodeBinary(r *io.BinReader) {
|
||||||
// EncodeBinary implements io.Serializable.
|
// EncodeBinary implements io.Serializable.
|
||||||
func (e ExtensionNode) EncodeBinary(w *io.BinWriter) {
|
func (e ExtensionNode) EncodeBinary(w *io.BinWriter) {
|
||||||
w.WriteVarBytes(e.key)
|
w.WriteVarBytes(e.key)
|
||||||
e.next.EncodeBinaryAsChild(w)
|
encodeBinaryAsChild(e.next, w)
|
||||||
}
|
|
||||||
|
|
||||||
// EncodeBinaryAsChild implements BaseNode interface.
|
|
||||||
func (e *ExtensionNode) EncodeBinaryAsChild(w *io.BinWriter) {
|
|
||||||
n := &NodeObject{Node: NewHashNode(e.Hash())} // with type
|
|
||||||
n.EncodeBinary(w)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// MarshalJSON implements json.Marshaler.
|
// MarshalJSON implements json.Marshaler.
|
||||||
|
|
|
@ -58,12 +58,6 @@ func (h HashNode) EncodeBinary(w *io.BinWriter) {
|
||||||
w.WriteBytes(h.hash[:])
|
w.WriteBytes(h.hash[:])
|
||||||
}
|
}
|
||||||
|
|
||||||
// EncodeBinaryAsChild implements BaseNode interface.
|
|
||||||
func (h *HashNode) EncodeBinaryAsChild(w *io.BinWriter) {
|
|
||||||
no := &NodeObject{Node: h} // with type
|
|
||||||
no.EncodeBinary(w)
|
|
||||||
}
|
|
||||||
|
|
||||||
// MarshalJSON implements json.Marshaler.
|
// MarshalJSON implements json.Marshaler.
|
||||||
func (h *HashNode) MarshalJSON() ([]byte, error) {
|
func (h *HashNode) MarshalJSON() ([]byte, error) {
|
||||||
if !h.hashValid {
|
if !h.hashValid {
|
||||||
|
|
|
@ -56,12 +56,6 @@ func (n LeafNode) EncodeBinary(w *io.BinWriter) {
|
||||||
w.WriteVarBytes(n.value)
|
w.WriteVarBytes(n.value)
|
||||||
}
|
}
|
||||||
|
|
||||||
// EncodeBinaryAsChild implements BaseNode interface.
|
|
||||||
func (n *LeafNode) EncodeBinaryAsChild(w *io.BinWriter) {
|
|
||||||
no := &NodeObject{Node: NewHashNode(n.Hash())} // with type
|
|
||||||
no.EncodeBinary(w)
|
|
||||||
}
|
|
||||||
|
|
||||||
// MarshalJSON implements json.Marshaler.
|
// MarshalJSON implements json.Marshaler.
|
||||||
func (n *LeafNode) MarshalJSON() ([]byte, error) {
|
func (n *LeafNode) MarshalJSON() ([]byte, error) {
|
||||||
return []byte(`{"value":"` + hex.EncodeToString(n.value) + `"}`), nil
|
return []byte(`{"value":"` + hex.EncodeToString(n.value) + `"}`), nil
|
||||||
|
|
Loading…
Reference in a new issue