-
Notifications
You must be signed in to change notification settings - Fork 3.7k
/
Copy pathidentifier.ts
102 lines (99 loc) · 1.53 KB
/
identifier.ts
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
export default class IdentifierGenerator {
// u 被框架占用了,不提供 u 开头的变量名
private _chars: string = 'abcdefghijklmnopqrstvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
private _nextIds: number[] = [0]
next(): string {
const r: string[] = []
for (const char of this._nextIds) {
r.unshift(this._chars[char])
}
this._increment()
const id = r.join('')
if (keywords.includes(id)) {
return this.next()
}
return id
}
_increment() {
for (let i = 0; i < this._nextIds.length; i++) {
const val = ++this._nextIds[i]
if (val >= this._chars.length) {
this._nextIds[i] = 0
} else {
return
}
}
this._nextIds.push(0)
}
*[Symbol.iterator]() {
while (true) {
yield this.next()
}
}
}
const keywords = [
'abstract',
'arguments',
'await',
'boolean',
'break',
'byte',
'case',
'catch',
'char',
'class',
'const',
'continue',
'debugger',
'default',
'delete',
'do',
'double',
'else',
'enum',
'eval',
'export',
'extends',
'false',
'final',
'finally',
'float',
'for',
'function',
'goto',
'if',
'implements',
'import',
'in',
'instanceof',
'int',
'interface',
'let',
'long',
'native',
'new',
'null',
'package',
'private',
'protected',
'public',
'return',
'short',
'static',
'super',
'switch',
'synchronized',
'this',
'throw',
'throws',
'transient',
'true',
'try',
'typeof',
'var',
'void',
'volatile',
'while',
'with',
'yield',
]