2020-02-03 07:00:36 +03:00
|
|
|
// Copyright (c) 2019-2020 Alexander Medvednikov. All rights reserved.
|
2020-01-22 23:34:38 +03:00
|
|
|
// Use of this source code is governed by an MIT license
|
|
|
|
// that can be found in the LICENSE file.
|
|
|
|
module eval
|
|
|
|
|
2020-04-25 18:49:16 +03:00
|
|
|
import v.ast
|
|
|
|
import v.checker
|
|
|
|
import v.table
|
|
|
|
import v.pref
|
2020-01-22 23:34:38 +03:00
|
|
|
|
|
|
|
pub type Object = int | string
|
|
|
|
|
|
|
|
pub struct Eval {
|
|
|
|
mut:
|
|
|
|
checker checker.Checker
|
|
|
|
vars map[string]Var
|
2020-02-28 16:05:20 +03:00
|
|
|
table &table.Table
|
2020-01-22 23:34:38 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
pub struct Var {
|
|
|
|
value Object
|
|
|
|
}
|
|
|
|
|
2020-04-25 18:49:16 +03:00
|
|
|
pub fn (mut e Eval) eval(file ast.File, table &table.Table) string {
|
2020-04-04 03:03:41 +03:00
|
|
|
vpref := &pref.Preferences{}
|
2020-02-28 16:05:20 +03:00
|
|
|
e.table = table
|
2020-01-22 23:34:38 +03:00
|
|
|
mut res := ''
|
2020-04-04 03:03:41 +03:00
|
|
|
e.checker = checker.new_checker(table, vpref)
|
2020-01-22 23:34:38 +03:00
|
|
|
for stmt in file.stmts {
|
|
|
|
res += e.stmt(stmt) + '\n'
|
|
|
|
}
|
|
|
|
return res.trim_space()
|
|
|
|
}
|
|
|
|
|
|
|
|
fn print_object(o Object) {
|
|
|
|
match o {
|
2020-04-25 18:49:16 +03:00
|
|
|
int { println(it) }
|
|
|
|
else { println('unknown object') }
|
2020-01-22 23:34:38 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn (o Object) str() string {
|
|
|
|
match o {
|
2020-04-25 18:49:16 +03:00
|
|
|
int { return it.str() }
|
|
|
|
else { println('unknown object') }
|
2020-01-22 23:34:38 +03:00
|
|
|
}
|
|
|
|
return ''
|
|
|
|
}
|
|
|
|
|
2020-04-25 18:49:16 +03:00
|
|
|
fn (mut e Eval) stmt(node ast.Stmt) string {
|
2020-01-22 23:34:38 +03:00
|
|
|
match node {
|
2020-04-25 18:49:16 +03:00
|
|
|
ast.AssignStmt {
|
|
|
|
// TODO; replaced VarDecl
|
|
|
|
}
|
2020-01-22 23:34:38 +03:00
|
|
|
ast.ExprStmt {
|
|
|
|
o := e.expr(it.expr)
|
|
|
|
print('out: ')
|
|
|
|
print_object(o)
|
|
|
|
return o.str()
|
|
|
|
}
|
2020-02-28 16:05:20 +03:00
|
|
|
// ast.StructDecl {
|
2020-04-25 18:49:16 +03:00
|
|
|
// println('s decl')
|
2020-02-28 16:05:20 +03:00
|
|
|
// }
|
2020-03-10 14:01:37 +03:00
|
|
|
// ast.VarDecl {
|
2020-04-25 18:49:16 +03:00
|
|
|
// e.vars[it.name] = Var{
|
|
|
|
// value: e.expr(it.expr)
|
|
|
|
// }
|
2020-03-10 14:01:37 +03:00
|
|
|
// }
|
2020-01-22 23:34:38 +03:00
|
|
|
else {}
|
|
|
|
}
|
|
|
|
return '>>'
|
|
|
|
}
|
|
|
|
|
2020-04-25 18:49:16 +03:00
|
|
|
fn (mut e Eval) expr(node ast.Expr) Object {
|
2020-01-22 23:34:38 +03:00
|
|
|
match node {
|
|
|
|
ast.IntegerLiteral {
|
|
|
|
return it.val
|
|
|
|
}
|
|
|
|
ast.Ident {
|
|
|
|
print_object(it.value)
|
|
|
|
// Find the variable
|
|
|
|
v := e.vars[it.name]
|
|
|
|
return v.value
|
|
|
|
}
|
|
|
|
ast.InfixExpr {
|
2020-03-07 02:42:52 +03:00
|
|
|
e.checker.infix_expr(mut it)
|
2020-01-22 23:34:38 +03:00
|
|
|
// println('bin $it.op')
|
|
|
|
left := e.expr(it.left) as int
|
|
|
|
right := e.expr(it.right) as int
|
|
|
|
match it.op {
|
2020-04-25 18:49:16 +03:00
|
|
|
.plus { return left + right }
|
|
|
|
.mul { return left * right }
|
2020-01-22 23:34:38 +03:00
|
|
|
else {}
|
2020-04-25 18:49:16 +03:00
|
|
|
}
|
2020-01-22 23:34:38 +03:00
|
|
|
}
|
|
|
|
else {}
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
// return Object{}
|
|
|
|
}
|