mirror of
https://github.com/SwingbyProtocol/tss-lib.git
synced 2026-04-23 03:00:36 -04:00
64 lines
1.4 KiB
Go
64 lines
1.4 KiB
Go
// Copyright © 2019 Binance
|
|
//
|
|
// This file is part of Binance. The full Binance copyright notice, including
|
|
// terms governing use, modification, and redistribution, is contained in the
|
|
// file LICENSE at the root of the source code distribution tree.
|
|
|
|
package common
|
|
|
|
import (
|
|
"math/big"
|
|
)
|
|
|
|
func BigIntsToBytes(bigInts []*big.Int) [][]byte {
|
|
bzs := make([][]byte, len(bigInts))
|
|
for i := range bzs {
|
|
if bigInts[i] == nil {
|
|
continue
|
|
}
|
|
bzs[i] = bigInts[i].Bytes()
|
|
}
|
|
return bzs
|
|
}
|
|
|
|
func ByteSlicesToBigInts(bytes [][]byte) []*big.Int {
|
|
ints := make([]*big.Int, len(bytes))
|
|
for i := range ints {
|
|
ints[i] = new(big.Int).SetBytes(bytes[i])
|
|
}
|
|
return ints
|
|
}
|
|
|
|
// Returns true when the byte slice is non-nil and non-empty
|
|
func NonEmptyBytes(bz []byte, minByteLen ...int) bool {
|
|
if 0 == len(bz) {
|
|
return false
|
|
}
|
|
allZero := true
|
|
for _, b := range bz {
|
|
if b != 0 {
|
|
allZero = false
|
|
break
|
|
}
|
|
}
|
|
return !allZero &&
|
|
(len(minByteLen) == 0 || minByteLen[0] <= len(bz))
|
|
}
|
|
|
|
// Returns true when all of the slices in the multi-dimensional byte slice are non-nil and non-empty
|
|
func NonEmptyMultiBytes(bzs [][]byte, expectLen ...int) bool {
|
|
if len(bzs) == 0 {
|
|
return false
|
|
}
|
|
// variadic (optional) arg test
|
|
if 0 < len(expectLen) && expectLen[0] != len(bzs) {
|
|
return false
|
|
}
|
|
for _, bz := range bzs {
|
|
if !NonEmptyBytes(bz) {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|