-
Notifications
You must be signed in to change notification settings - Fork 0
/
tokenizer.ts
70 lines (65 loc) · 1.31 KB
/
tokenizer.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
export enum TokenTypes {
Paren,
String,
Number
}
export interface Token {
type: TokenTypes
value: string
}
// 通过指针的方式去遍历字符串,根据token的类型入栈
export function tokenizer(code: string) {
const tokens: Token[] = []
let current = 0
while (current < code.length) {
let char = code[current]
const WHITESPACE = /\s/
if (WHITESPACE.test(char)) {
current++
continue
}
if (char === '(') {
tokens.push({
type: TokenTypes.Paren,
value: char
})
current++
continue
}
if (char === ')') {
tokens.push({
type: TokenTypes.Paren,
value: char
})
current++
continue
}
// char
const LETTERS = /[a-z]/i
if (LETTERS.test(char)) {
let value = ''
while (LETTERS.test(char) && current < code.length) {
value += char
char = code[++current]
}
tokens.push({
type: TokenTypes.String,
value
})
}
// number
const NUMBERS = /[0-9]/i
if (NUMBERS.test(char)) {
let value = ''
while (NUMBERS.test(char) && current < code.length) {
value += char
char = code[++current]
}
tokens.push({
type: TokenTypes.Number,
value
})
}
}
return tokens
}