forked from cerc-io/laconicd-deprecated
052134aff6
* refactor (errors) refactor errors import to use cosmossdk.io instead of cosmos-sdk/types/errors * refactor (errors) refactor errors import in ethsecp256k1 file * refactor (errors) add changes to changelog
36 lines
939 B
Go
36 lines
939 B
Go
package types
|
|
|
|
import (
|
|
fmt "fmt"
|
|
math "math"
|
|
"math/big"
|
|
|
|
errorsmod "cosmossdk.io/errors"
|
|
sdkmath "cosmossdk.io/math"
|
|
errortypes "github.com/cosmos/cosmos-sdk/types/errors"
|
|
)
|
|
|
|
const maxBitLen = 256
|
|
|
|
// SafeInt64 checks for overflows while casting a uint64 to int64 value.
|
|
func SafeInt64(value uint64) (int64, error) {
|
|
if value > uint64(math.MaxInt64) {
|
|
return 0, errorsmod.Wrapf(errortypes.ErrInvalidHeight, "uint64 value %v cannot exceed %v", value, int64(math.MaxInt64))
|
|
}
|
|
|
|
return int64(value), nil
|
|
}
|
|
|
|
// SafeNewIntFromBigInt constructs Int from big.Int, return error if more than 256bits
|
|
func SafeNewIntFromBigInt(i *big.Int) (sdkmath.Int, error) {
|
|
if !IsValidInt256(i) {
|
|
return sdkmath.NewInt(0), fmt.Errorf("big int out of bound: %s", i)
|
|
}
|
|
return sdkmath.NewIntFromBigInt(i), nil
|
|
}
|
|
|
|
// IsValidInt256 check the bound of 256 bit number
|
|
func IsValidInt256(i *big.Int) bool {
|
|
return i == nil || i.BitLen() <= maxBitLen
|
|
}
|