util: rename Int64Value to IntegralValue, add FractionalValue

Makes it's interface more clear and allows to easily access fractional part.
This commit is contained in:
Roman Khimov 2020-03-04 13:26:08 +03:00
parent 7cc847d655
commit 823798514a
4 changed files with 21 additions and 6 deletions

View file

@ -455,7 +455,7 @@ func (bc *Blockchain) storeBlock(block *block.Block) error {
cache := newCachedDao(bc.dao.store) cache := newCachedDao(bc.dao.store)
fee := bc.getSystemFeeAmount(block.PrevHash) fee := bc.getSystemFeeAmount(block.PrevHash)
for _, tx := range block.Transactions { for _, tx := range block.Transactions {
fee += uint32(bc.SystemFee(tx).Int64Value()) fee += uint32(bc.SystemFee(tx).IntegralValue())
} }
if err := cache.StoreAsBlock(block, fee); err != nil { if err := cache.StoreAsBlock(block, fee); err != nil {
return err return err

View file

@ -23,7 +23,8 @@ func TestEncodeDecodeContract(t *testing.T) {
assert.Equal(t, "eec17cc828d6ede932b57e4eaf79c2591151096a7825435cd67f498f9fa98d88", input.PrevHash.StringLE()) assert.Equal(t, "eec17cc828d6ede932b57e4eaf79c2591151096a7825435cd67f498f9fa98d88", input.PrevHash.StringLE())
assert.Equal(t, 0, int(input.PrevIndex)) assert.Equal(t, 0, int(input.PrevIndex))
assert.Equal(t, int64(706), tx.Outputs[0].Amount.Int64Value()) assert.Equal(t, int64(706), tx.Outputs[0].Amount.IntegralValue())
assert.Equal(t, int32(0), tx.Outputs[0].Amount.FractionalValue())
assert.Equal(t, "c56f33fc6ecfcd0c225c4ab356fee59390af8560be0e930faebe74a6daff7c9b", tx.Outputs[0].AssetID.StringLE()) assert.Equal(t, "c56f33fc6ecfcd0c225c4ab356fee59390af8560be0e930faebe74a6daff7c9b", tx.Outputs[0].AssetID.StringLE())
assert.Equal(t, "a8666b4830229d6a1a9b80f6088059191c122d2b", tx.Outputs[0].ScriptHash.String()) assert.Equal(t, "a8666b4830229d6a1a9b80f6088059191c122d2b", tx.Outputs[0].ScriptHash.String())
assert.Equal(t, "bdf6cc3b9af12a7565bda80933a75ee8cef1bc771d0d58effc08e4c8b436da79", tx.Hash().StringLE()) assert.Equal(t, "bdf6cc3b9af12a7565bda80933a75ee8cef1bc771d0d58effc08e4c8b436da79", tx.Hash().StringLE())

View file

@ -46,11 +46,18 @@ func (f Fixed8) FloatValue() float64 {
return float64(f) / decimals return float64(f) / decimals
} }
// Int64Value returns the original value representing Fixed8 as int64. // IntegralValue returns integer part of the original value representing
func (f Fixed8) Int64Value() int64 { // Fixed8 as int64.
func (f Fixed8) IntegralValue() int64 {
return int64(f) / decimals return int64(f) / decimals
} }
// FractionalValue returns decimal part of the original value. It has the same
// sign as f, so that f = f.IntegralValue() + f.FractionalValue().
func (f Fixed8) FractionalValue() int32 {
return int32(int64(f) % decimals)
}
// Fixed8FromInt64 returns a new Fixed8 type multiplied by decimals. // Fixed8FromInt64 returns a new Fixed8 type multiplied by decimals.
func Fixed8FromInt64(val int64) Fixed8 { func Fixed8FromInt64(val int64) Fixed8 {
return Fixed8(decimals * val) return Fixed8(decimals * val)

View file

@ -2,6 +2,7 @@ package util
import ( import (
"encoding/json" "encoding/json"
"math"
"strconv" "strconv"
"testing" "testing"
@ -16,7 +17,8 @@ func TestFixed8FromInt64(t *testing.T) {
for _, val := range values { for _, val := range values {
assert.Equal(t, Fixed8(val*decimals), Fixed8FromInt64(val)) assert.Equal(t, Fixed8(val*decimals), Fixed8FromInt64(val))
assert.Equal(t, val, Fixed8FromInt64(val).Int64Value()) assert.Equal(t, val, Fixed8FromInt64(val).IntegralValue())
assert.Equal(t, int32(0), Fixed8FromInt64(val).FractionalValue())
} }
} }
@ -35,7 +37,8 @@ func TestFixed8Sub(t *testing.T) {
b := Fixed8FromInt64(34) b := Fixed8FromInt64(34)
c := a.Sub(b) c := a.Sub(b)
assert.Equal(t, int64(8), c.Int64Value()) assert.Equal(t, int64(8), c.IntegralValue())
assert.Equal(t, int32(0), c.FractionalValue())
} }
func TestFixed8FromFloat(t *testing.T) { func TestFixed8FromFloat(t *testing.T) {
@ -44,6 +47,10 @@ func TestFixed8FromFloat(t *testing.T) {
for _, val := range inputs { for _, val := range inputs {
assert.Equal(t, Fixed8(val*decimals), Fixed8FromFloat(val)) assert.Equal(t, Fixed8(val*decimals), Fixed8FromFloat(val))
assert.Equal(t, val, Fixed8FromFloat(val).FloatValue()) assert.Equal(t, val, Fixed8FromFloat(val).FloatValue())
trunc := math.Trunc(val)
rem := (val - trunc) * decimals
assert.Equal(t, int64(trunc), Fixed8FromFloat(val).IntegralValue())
assert.Equal(t, int32(math.Round(rem)), Fixed8FromFloat(val).FractionalValue())
} }
} }