From 1b186e046b90e6cd029ddc2f894e8a079789336f Mon Sep 17 00:00:00 2001 From: Roman Khimov Date: Wed, 4 Aug 2021 23:11:53 +0300 Subject: [PATCH] network: use optimized decoder for transactions NewTransactionFromBytes() works a bit faster and uses less memory. --- pkg/network/message.go | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/pkg/network/message.go b/pkg/network/message.go index f2892aae9..5eb360d9d 100644 --- a/pkg/network/message.go +++ b/pkg/network/message.go @@ -130,7 +130,6 @@ func (m *Message) decodePayload() error { buf = d } - r := io.NewBinReaderFromBuf(buf) var p payload.Payload switch m.Command { case CMDVersion: @@ -154,7 +153,12 @@ func (m *Message) decodePayload() error { case CMDHeaders: p = &payload.Headers{StateRootInHeader: m.StateRootInHeader} case CMDTX: - p = &transaction.Transaction{} + p, err := transaction.NewTransactionFromBytes(buf) + if err != nil { + return err + } + m.Payload = p + return nil case CMDMerkleBlock: p = &payload.MerkleBlock{} case CMDPing, CMDPong: @@ -164,6 +168,7 @@ func (m *Message) decodePayload() error { default: return fmt.Errorf("can't decode command %s", m.Command.String()) } + r := io.NewBinReaderFromBuf(buf) p.DecodeBinary(r) if r.Err == nil || r.Err == payload.ErrTooManyHeaders { m.Payload = p