2019-01-31 02:53:58 +00:00
|
|
|
// Package bytesutil defines helper methods for converting integers to byte slices.
|
|
|
|
package bytesutil
|
2018-11-08 16:52:51 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/binary"
|
|
|
|
)
|
|
|
|
|
2019-02-12 03:57:00 +00:00
|
|
|
// Bytes1 returns integer x to bytes in little-endian format, x.to_bytes(1, 'big').
|
2018-11-08 16:52:51 +00:00
|
|
|
func Bytes1(x uint64) []byte {
|
|
|
|
bytes := make([]byte, 8)
|
2019-02-12 03:57:00 +00:00
|
|
|
binary.LittleEndian.PutUint64(bytes, x)
|
|
|
|
return bytes[:1]
|
2018-11-08 16:52:51 +00:00
|
|
|
}
|
|
|
|
|
2019-02-12 03:57:00 +00:00
|
|
|
// Bytes2 returns integer x to bytes in little-endian format, x.to_bytes(2, 'big').
|
2018-11-08 16:52:51 +00:00
|
|
|
func Bytes2(x uint64) []byte {
|
|
|
|
bytes := make([]byte, 8)
|
2019-02-12 03:57:00 +00:00
|
|
|
binary.LittleEndian.PutUint64(bytes, x)
|
|
|
|
return bytes[:2]
|
2018-11-08 16:52:51 +00:00
|
|
|
}
|
|
|
|
|
2019-02-12 03:57:00 +00:00
|
|
|
// Bytes3 returns integer x to bytes in little-endian format, x.to_bytes(3, 'big').
|
2018-11-08 16:52:51 +00:00
|
|
|
func Bytes3(x uint64) []byte {
|
|
|
|
bytes := make([]byte, 8)
|
2019-02-12 03:57:00 +00:00
|
|
|
binary.LittleEndian.PutUint64(bytes, x)
|
|
|
|
return bytes[:3]
|
2018-11-08 16:52:51 +00:00
|
|
|
}
|
|
|
|
|
2019-02-12 03:57:00 +00:00
|
|
|
// Bytes4 returns integer x to bytes in little-endian format, x.to_bytes(4, 'big').
|
2018-11-08 16:52:51 +00:00
|
|
|
func Bytes4(x uint64) []byte {
|
|
|
|
bytes := make([]byte, 8)
|
2019-02-12 03:57:00 +00:00
|
|
|
binary.LittleEndian.PutUint64(bytes, x)
|
|
|
|
return bytes[:4]
|
2018-11-08 16:52:51 +00:00
|
|
|
}
|
|
|
|
|
2019-02-12 03:57:00 +00:00
|
|
|
// Bytes8 returns integer x to bytes in little-endian format, x.to_bytes(8, 'big').
|
2018-11-08 16:52:51 +00:00
|
|
|
func Bytes8(x uint64) []byte {
|
|
|
|
bytes := make([]byte, 8)
|
2019-02-12 03:57:00 +00:00
|
|
|
binary.LittleEndian.PutUint64(bytes, x)
|
2018-11-08 16:52:51 +00:00
|
|
|
return bytes
|
|
|
|
}
|
2018-11-21 18:00:36 +00:00
|
|
|
|
2019-02-12 03:57:00 +00:00
|
|
|
// FromBytes8 returns an integer which is stored in the little-endian format(8, 'big')
|
2018-11-21 18:00:36 +00:00
|
|
|
// from a byte array.
|
|
|
|
func FromBytes8(x []byte) uint64 {
|
2019-02-12 03:57:00 +00:00
|
|
|
return binary.LittleEndian.Uint64(x)
|
2018-11-21 18:00:36 +00:00
|
|
|
}
|
2018-12-22 20:38:09 +00:00
|
|
|
|
2019-02-12 03:57:00 +00:00
|
|
|
// LowerThan returns true if byte slice x is lower than byte slice y. (little-endian format)
|
2018-12-22 20:38:09 +00:00
|
|
|
// This is used in spec to compare winning block root hash.
|
|
|
|
// Mentioned in spec as "ties broken by favoring lower `shard_block_root` values".
|
|
|
|
func LowerThan(x []byte, y []byte) bool {
|
|
|
|
for i, b := range x {
|
|
|
|
if b > y[i] {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
2019-01-06 15:25:43 +00:00
|
|
|
|
|
|
|
// ToBytes32 is a convenience method for converting a byte slice to a fix
|
|
|
|
// sized 32 byte array. This method will truncate the input if it is larger
|
|
|
|
// than 32 bytes.
|
2019-01-22 07:38:26 +00:00
|
|
|
func ToBytes32(x []byte) [32]byte {
|
|
|
|
var y [32]byte
|
|
|
|
copy(y[:], x)
|
|
|
|
return y
|
|
|
|
}
|
|
|
|
|
2019-02-03 23:05:34 +00:00
|
|
|
// ToBytes48 is a convenience method for converting a byte slice to a fix
|
|
|
|
// sized 48 byte array. This method will truncate the input if it is larger
|
|
|
|
// than 48 bytes.
|
|
|
|
func ToBytes48(x []byte) [48]byte {
|
|
|
|
var y [48]byte
|
|
|
|
copy(y[:], x)
|
|
|
|
return y
|
|
|
|
}
|
|
|
|
|
2019-01-22 07:38:26 +00:00
|
|
|
// Xor xors the bytes in x and y and returns the result.
|
|
|
|
func Xor(x []byte, y []byte) []byte {
|
|
|
|
n := len(x)
|
|
|
|
if len(y) < n {
|
|
|
|
n = len(y)
|
|
|
|
}
|
|
|
|
var result []byte
|
|
|
|
for i := 0; i < n; i++ {
|
|
|
|
result = append(result, x[i]^y[i])
|
|
|
|
}
|
|
|
|
return result
|
2019-01-06 15:25:43 +00:00
|
|
|
}
|