2019-12-22 04:34:37 +03:00
|
|
|
module parser
|
|
|
|
|
|
|
|
import compiler2.ast
|
|
|
|
|
|
|
|
fn test_parser() {
|
|
|
|
//expr := ast.IntegerExpr {val:10}
|
|
|
|
//expr := ast.BinaryExpr{}
|
2019-12-25 15:39:58 +03:00
|
|
|
|
|
|
|
// print using walk
|
2019-12-22 04:34:37 +03:00
|
|
|
expr := parse_expr('3 + 7')
|
|
|
|
walk(expr)
|
2019-12-25 15:39:58 +03:00
|
|
|
println('\n')
|
|
|
|
|
|
|
|
text_expr := [
|
|
|
|
'4 + 4',
|
|
|
|
'1 + 2 * 5',
|
|
|
|
'(2 * 3) / 2',
|
|
|
|
'3 + (7 * 6)',
|
|
|
|
'2 ^ 8 * (7 * 6)',
|
|
|
|
'(2) + (17*2-30) * (5)+2 - (8/2)*4'
|
|
|
|
]
|
|
|
|
for s in text_expr {
|
|
|
|
// print using str method
|
|
|
|
x := parse_expr(s)
|
|
|
|
println('source: $s')
|
|
|
|
println('parsed: $x')
|
|
|
|
println('===================')
|
|
|
|
}
|
2019-12-22 04:34:37 +03:00
|
|
|
}
|
|
|
|
|
2019-12-25 15:39:58 +03:00
|
|
|
|
2019-12-22 04:34:37 +03:00
|
|
|
fn walk(node ast.Expr) {
|
|
|
|
//println('walk()')
|
|
|
|
match node {
|
|
|
|
ast.BinaryExpr {
|
2019-12-25 15:39:58 +03:00
|
|
|
print(' (')
|
2019-12-22 04:34:37 +03:00
|
|
|
walk(it.left)
|
2019-12-25 15:39:58 +03:00
|
|
|
// print('$it.op.str()')
|
2019-12-22 04:34:37 +03:00
|
|
|
match it.op {
|
|
|
|
.plus {
|
|
|
|
print(' + ')
|
|
|
|
}
|
|
|
|
.minus {
|
|
|
|
print(' - ')
|
|
|
|
}
|
|
|
|
else {}
|
|
|
|
|
|
|
|
}
|
|
|
|
walk(it.right)
|
2019-12-25 15:39:58 +03:00
|
|
|
print(') ')
|
2019-12-22 04:34:37 +03:00
|
|
|
}
|
2019-12-25 15:39:58 +03:00
|
|
|
ast.ScalarExpr {
|
|
|
|
walk(it.left)
|
|
|
|
print(' $it.val ')
|
|
|
|
}
|
|
|
|
ast.UnaryExpr {
|
|
|
|
walk(it.left)
|
|
|
|
print(' $it.op ')
|
|
|
|
}
|
|
|
|
else { }
|
2019-12-22 04:34:37 +03:00
|
|
|
}
|
2019-12-25 15:39:58 +03:00
|
|
|
}
|