-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathbase62.go
41 lines (36 loc) · 836 Bytes
/
base62.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
package goutil
import (
"fmt"
"math"
"strings"
)
const (
alphabet = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
base = uint64(len(alphabet))
)
// ToB62 encodes the decoded integer to base62 string.
func ToB62(n uint64) string {
if n == 0 {
return "0"
}
b := make([]byte, 0, 512)
for n > 0 {
r := math.Mod(float64(n), float64(base))
n /= base
b = append([]byte{alphabet[int(r)]}, b...)
}
return string(b)
}
// FromB62 decodes a base62 encoded string to int.
// Returns an error if input s is not valid base62 literal [0-9a-zA-Z].
func FromB62(s string) (uint64, error) {
var r uint64
for _, c := range []byte(s) {
i := strings.IndexByte(alphabet, c)
if i < 0 {
return 0, fmt.Errorf("unexpected character %c in base62 literal", c)
}
r = base*r + uint64(i)
}
return r, nil
}