-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparser.ts
46 lines (39 loc) · 1.09 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
import {
createCallExpressionNode,
createNumberLiteralNode,
createRootNode,
createStringLiteralNode
} from './ast'
import { Token, TokenTypes } from './tokenizer'
export function parser(tokens: Token[]) {
let current = 0
const ast = createRootNode()
function walk() {
let token = tokens[current]
if (token.type === TokenTypes.Number) {
// rootNode.body.push(createNumberNode(token.value))
current++
return createNumberLiteralNode(token.value)
}
if (token.type === TokenTypes.String) {
current++
return createStringLiteralNode(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++
return node
}
throw new Error(`undefined token: ${token}`)
}
while (current < tokens.length) {
ast.body.push(walk())
}
return ast
}