-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparser.ts
67 lines (56 loc) · 1.33 KB
/
parser.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
import {
Token,
TokenTypes,
NodeTypes,
RootNode,
NumberNode,
CallExpressionNode,
} from "./type";
function createRootNode(): RootNode {
return {
type: NodeTypes.Root,
body: [],
};
}
function createNumberNode(value: string): NumberNode {
return {
type: NodeTypes.Number,
value,
};
}
function createCallExpressionNode(name: string): CallExpressionNode {
return {
type: NodeTypes.CallExpression,
name,
params: [],
};
}
export function parser(tokens: Token[]) {
let current = 0;
const rootNode = createRootNode();
function walk() {
let token = tokens[current];
if (token.type === TokenTypes.Number) {
// rootNode.body.push(createNumberNode(token.value));
current++;
return createNumberNode(token.value);
}
if (token.type === TokenTypes.Paren && token.value === "(") {
token = tokens[++current];
const node = createCallExpressionNode(token.value);
token = tokens[++current];
while (!(token.type === TokenTypes.Paren && token.value === ")")) {
node.params.push(walk());
token = tokens[current];
}
current++;
// rootNode.body.push(node);
return node;
}
throw new Error(`unknown token: ${token}`);
}
while (current < tokens.length) {
rootNode.body.push(walk());
}
return rootNode;
}