-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtypes.go
57 lines (48 loc) · 958 Bytes
/
types.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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
package main
import "fmt"
var (
enWords = []byte{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'}
)
type Generator struct {
prefix []byte
index int
}
func New(s int) *Generator {
bs := make([]byte, s-1)
for i := 0; i < s-1; i++ {
bs[i] = enWords[0]
}
return &Generator{prefix: bs, index: -1}
}
func (g *Generator) Next() string {
n := g.index + 1
if n == len(enWords) {
if !g.growth(len(g.prefix) - 1) {
return ""
}
g.index = -1
return g.Next()
}
e := enWords[n]
g.index = n
return fmt.Sprintf("%s%c", g.prefix, e)
}
func (g *Generator) growth(level int) bool {
if level < 0 {
return false
}
b := g.prefix[level]
nd := -1
for i, word := range enWords {
if word == b {
nd = i + 1
break
}
}
if nd == len(enWords) {
g.prefix[level] = enWords[0]
return g.growth(level - 1)
}
g.prefix[level] = enWords[nd]
return true
}