Files
multibase/base2.go
2019-02-14 19:34:11 +05:30

57 lines
1.2 KiB
Go

package multibase
import (
"fmt"
"math"
"strconv"
"strings"
)
// binaryEncodeToString takes an array of bytes and returns
// multibase binary representation
func binaryEncodeToString(src []byte) string {
dst := make([]byte, len(src)*8)
encodeBinary(dst, src)
return string(dst)
}
// encodeBinary takes the src and dst bytes and converts each
// byte to their binary rep using power reduction method
func encodeBinary(dst []byte, src []byte) {
for i := 0; i < len(src); i++ {
t := src[i]
for j := i << 3; j < (i<<3)+8; j++ {
higherPower := math.Pow(2, float64(7-(j&7)))
if t >= byte(higherPower) {
dst[j] = '1'
t = t - byte(higherPower)
} else {
dst[j] = '0'
}
}
}
}
// decodeBinaryString takes multibase binary representation
// and returns a byte array
func decodeBinaryString(s string) ([]byte, error) {
if len(s)&7 != 0 {
// prepend the padding
s = strings.Repeat("0", 8-len(s)&7) + s
}
data := make([]byte, len(s)>>3)
for i, dstIndex := 0, 0; i < len(s); i = i + 8 {
value, err := strconv.ParseInt(s[i:i+8], 2, 0)
if err != nil {
return nil, fmt.Errorf("error while conversion: %s", err)
}
data[dstIndex] = byte(value)
dstIndex++
}
return data, nil
}