io: move size calculator there

It's mostly used for Serializable and in other cases where one needs to
estimate binary-encoded size of the stucture. This also simplifies future
removal of the Size() from Serializable.
This commit is contained in:
Roman Khimov 2019-09-16 12:33:53 +03:00
parent 5bf00db2c9
commit 0da9fe6946
13 changed files with 30 additions and 38 deletions

View file

@ -6,7 +6,7 @@ import (
"github.com/CityOfZion/neo-go/config" "github.com/CityOfZion/neo-go/config"
"github.com/CityOfZion/neo-go/pkg/core/storage" "github.com/CityOfZion/neo-go/pkg/core/storage"
"github.com/CityOfZion/neo-go/pkg/util" "github.com/CityOfZion/neo-go/pkg/io"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require" "github.com/stretchr/testify/require"
) )
@ -142,10 +142,10 @@ func TestGetTransaction(t *testing.T) {
assert.Equal(t, block.Index, height) assert.Equal(t, block.Index, height)
assert.Equal(t, block.Transactions[0], tx) assert.Equal(t, block.Transactions[0], tx)
assert.Equal(t, 10, tx.Size()) assert.Equal(t, 10, tx.Size())
assert.Equal(t, 1, util.GetVarSize(tx.Attributes)) assert.Equal(t, 1, io.GetVarSize(tx.Attributes))
assert.Equal(t, 1, util.GetVarSize(tx.Inputs)) assert.Equal(t, 1, io.GetVarSize(tx.Inputs))
assert.Equal(t, 1, util.GetVarSize(tx.Outputs)) assert.Equal(t, 1, io.GetVarSize(tx.Outputs))
assert.Equal(t, 1, util.GetVarSize(tx.Scripts)) assert.Equal(t, 1, io.GetVarSize(tx.Scripts))
} }
func newTestChain(t *testing.T) *Blockchain { func newTestChain(t *testing.T) *Blockchain {

View file

@ -6,7 +6,6 @@ import (
"fmt" "fmt"
"github.com/CityOfZion/neo-go/pkg/io" "github.com/CityOfZion/neo-go/pkg/io"
"github.com/CityOfZion/neo-go/pkg/util"
) )
// Attribute represents a Transaction attribute. // Attribute represents a Transaction attribute.
@ -87,7 +86,7 @@ func (attr *Attribute) Size() int {
case DescriptionURL: case DescriptionURL:
sz += 1 + len(attr.Data) sz += 1 + len(attr.Data)
default: default:
sz += util.GetVarSize(attr.Data) sz += io.GetVarSize(attr.Data)
} }
return sz return sz
} }

View file

@ -2,7 +2,6 @@ package transaction
import ( import (
"github.com/CityOfZion/neo-go/pkg/io" "github.com/CityOfZion/neo-go/pkg/io"
"github.com/CityOfZion/neo-go/pkg/util"
) )
// ClaimTX represents a claim transaction. // ClaimTX represents a claim transaction.
@ -42,7 +41,7 @@ func (tx *ClaimTX) EncodeBinary(bw *io.BinWriter) error {
// Size returns serialized binary size for this transaction. // Size returns serialized binary size for this transaction.
func (tx *ClaimTX) Size() int { func (tx *ClaimTX) Size() int {
sz := util.GetVarSize(uint64(len(tx.Claims))) sz := io.GetVarSize(uint64(len(tx.Claims)))
for _, claim := range tx.Claims { for _, claim := range tx.Claims {
sz += claim.Size() sz += claim.Size()
} }

View file

@ -53,7 +53,7 @@ func (tx *InvocationTX) EncodeBinary(bw *io.BinWriter) error {
// Size returns serialized binary size for this transaction. // Size returns serialized binary size for this transaction.
func (tx *InvocationTX) Size() int { func (tx *InvocationTX) Size() int {
sz := util.GetVarSize(tx.Script) sz := io.GetVarSize(tx.Script)
if tx.Version >= 1 { if tx.Version >= 1 {
sz += tx.Gas.Size() sz += tx.Gas.Size()
} }

View file

@ -3,7 +3,6 @@ package transaction
import ( import (
"github.com/CityOfZion/neo-go/pkg/io" "github.com/CityOfZion/neo-go/pkg/io"
"github.com/CityOfZion/neo-go/pkg/smartcontract" "github.com/CityOfZion/neo-go/pkg/smartcontract"
"github.com/CityOfZion/neo-go/pkg/util"
) )
// PublishTX represents a publish transaction. // PublishTX represents a publish transaction.
@ -73,14 +72,14 @@ func (tx *PublishTX) EncodeBinary(bw *io.BinWriter) error {
// Size returns serialized binary size for this transaction. // Size returns serialized binary size for this transaction.
func (tx *PublishTX) Size() int { func (tx *PublishTX) Size() int {
sz := util.GetVarSize(tx.Script) + util.GetVarSize(uint64(len(tx.ParamList))) sz := io.GetVarSize(tx.Script) + io.GetVarSize(uint64(len(tx.ParamList)))
sz += 1 * len(tx.ParamList) sz += 1 * len(tx.ParamList)
sz++ sz++
if tx.Version >= 1 { if tx.Version >= 1 {
sz++ sz++
} }
sz += util.GetVarSize(tx.Name) + util.GetVarSize(tx.CodeVersion) sz += io.GetVarSize(tx.Name) + io.GetVarSize(tx.CodeVersion)
sz += util.GetVarSize(tx.Author) + util.GetVarSize(tx.Email) sz += io.GetVarSize(tx.Author) + io.GetVarSize(tx.Email)
sz += util.GetVarSize(tx.Description) sz += io.GetVarSize(tx.Description)
return sz return sz
} }

View file

@ -62,5 +62,5 @@ func (tx *RegisterTX) EncodeBinary(bw *io.BinWriter) error {
// Size returns serialized binary size for this transaction. // Size returns serialized binary size for this transaction.
func (tx *RegisterTX) Size() int { func (tx *RegisterTX) Size() int {
return 1 + util.GetVarSize(tx.Name) + tx.Amount.Size() + 1 + len(tx.Owner.Bytes()) + tx.Admin.Size() return 1 + io.GetVarSize(tx.Name) + tx.Amount.Size() + 1 + len(tx.Owner.Bytes()) + tx.Admin.Size()
} }

View file

@ -2,7 +2,6 @@ package transaction
import ( import (
"github.com/CityOfZion/neo-go/pkg/io" "github.com/CityOfZion/neo-go/pkg/io"
"github.com/CityOfZion/neo-go/pkg/util"
) )
// StateTX represents a state transaction. // StateTX represents a state transaction.
@ -38,7 +37,7 @@ func (tx *StateTX) EncodeBinary(w *io.BinWriter) error {
// Size returns serialized binary size for this transaction. // Size returns serialized binary size for this transaction.
func (tx *StateTX) Size() int { func (tx *StateTX) Size() int {
sz := util.GetVarSize(uint64(len(tx.Descriptors))) sz := io.GetVarSize(uint64(len(tx.Descriptors)))
for _, desc := range tx.Descriptors { for _, desc := range tx.Descriptors {
sz += desc.Size() sz += desc.Size()
} }

View file

@ -2,7 +2,6 @@ package transaction
import ( import (
"github.com/CityOfZion/neo-go/pkg/io" "github.com/CityOfZion/neo-go/pkg/io"
"github.com/CityOfZion/neo-go/pkg/util"
) )
// DescStateType represents the type of StateDescriptor. // DescStateType represents the type of StateDescriptor.
@ -44,5 +43,5 @@ func (s *StateDescriptor) EncodeBinary(w *io.BinWriter) error {
// Size returns serialized binary size for state descriptor. // Size returns serialized binary size for state descriptor.
func (s *StateDescriptor) Size() int { func (s *StateDescriptor) Size() int {
return 1 + util.GetVarSize(s.Key) + util.GetVarSize(s.Value) + util.GetVarSize(s.Field) return 1 + io.GetVarSize(s.Key) + io.GetVarSize(s.Value) + io.GetVarSize(s.Field)
} }

View file

@ -265,10 +265,10 @@ func (t Transaction) GroupOutputByAssetID() map[util.Uint256][]*Output {
// Size returns the size of the transaction in term of bytes // Size returns the size of the transaction in term of bytes
func (t *Transaction) Size() int { func (t *Transaction) Size() int {
attrSize := util.GetVarSize(t.Attributes) attrSize := io.GetVarSize(t.Attributes)
inputSize := util.GetVarSize(t.Inputs) inputSize := io.GetVarSize(t.Inputs)
outputSize := util.GetVarSize(t.Outputs) outputSize := io.GetVarSize(t.Outputs)
witnesSize := util.GetVarSize(t.Scripts) witnesSize := io.GetVarSize(t.Scripts)
// uint8 + uint8 + attrSize + inputSize + outputSize + witnesSize // uint8 + uint8 + attrSize + inputSize + outputSize + witnesSize
return 2 + attrSize + inputSize + outputSize + witnesSize + t.Data.Size() return 2 + attrSize + inputSize + outputSize + witnesSize + t.Data.Size()
} }

View file

@ -42,7 +42,7 @@ func (w *Witness) MarshalJSON() ([]byte, error) {
// Size returns the size in bytes of the Witness. // Size returns the size in bytes of the Witness.
func (w *Witness) Size() int { func (w *Witness) Size() int {
return util.GetVarSize(w.InvocationScript) + util.GetVarSize(w.VerificationScript) return io.GetVarSize(w.InvocationScript) + io.GetVarSize(w.VerificationScript)
} }
// ScriptHash returns the hash of the VerificationScript. // ScriptHash returns the hash of the VerificationScript.

View file

@ -1,10 +1,8 @@
package util package io
import ( import (
"fmt" "fmt"
"reflect" "reflect"
"github.com/CityOfZion/neo-go/pkg/io"
) )
var ( var (
@ -67,9 +65,9 @@ func GetVarSize(value interface{}) int {
if valueLength != 0 { if valueLength != 0 {
switch reflect.ValueOf(value).Index(0).Interface().(type) { switch reflect.ValueOf(value).Index(0).Interface().(type) {
case io.Serializable: case Serializable:
for i := 0; i < valueLength; i++ { for i := 0; i < valueLength; i++ {
elem := v.Index(i).Interface().(io.Serializable) elem := v.Index(i).Interface().(Serializable)
valueSize += elem.Size() valueSize += elem.Size()
} }
case uint8, int8: case uint8, int8:

View file

@ -1,10 +1,10 @@
package util package io
import ( import (
"fmt" "fmt"
"testing" "testing"
"github.com/CityOfZion/neo-go/pkg/io" "github.com/CityOfZion/neo-go/pkg/util"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/assert"
) )
@ -12,11 +12,11 @@ import (
type smthSerializable struct { type smthSerializable struct {
} }
func (*smthSerializable) DecodeBinary(*io.BinReader) error { func (*smthSerializable) DecodeBinary(*BinReader) error {
return nil return nil
} }
func (*smthSerializable) EncodeBinary(*io.BinWriter) error { func (*smthSerializable) EncodeBinary(*BinWriter) error {
return nil return nil
} }
@ -87,7 +87,7 @@ func TestVarSize(t *testing.T) {
}, },
{ {
// The neo C# implementation doe not allowed this! // The neo C# implementation doe not allowed this!
Uint160{1, 2, 4, 5, 6}, util.Uint160{1, 2, 4, 5, 6},
"test_Uint160_1", "test_Uint160_1",
21, 21,
}, },
@ -153,7 +153,7 @@ func TestVarSize(t *testing.T) {
241, 241,
}, },
// The neo C# implementation doe not allowed this! // The neo C# implementation doe not allowed this!
{Uint256{1, 2, 3, 4, 5, 6}, {util.Uint256{1, 2, 3, 4, 5, 6},
"test_Uint256_1", "test_Uint256_1",
33, 33,
}, },

View file

@ -4,7 +4,6 @@ import (
"time" "time"
"github.com/CityOfZion/neo-go/pkg/io" "github.com/CityOfZion/neo-go/pkg/io"
"github.com/CityOfZion/neo-go/pkg/util"
) )
// Size of the payload not counting UserAgent encoding (which is at least 1 byte // Size of the payload not counting UserAgent encoding (which is at least 1 byte
@ -83,5 +82,5 @@ func (p *Version) EncodeBinary(br *io.BinWriter) error {
// Size implements the payloader interface. // Size implements the payloader interface.
func (p *Version) Size() uint32 { func (p *Version) Size() uint32 {
return uint32(minVersionSize + util.GetVarSize(p.UserAgent)) return uint32(minVersionSize + io.GetVarSize(p.UserAgent))
} }