blob: 1ce84938724e984135854e85094732a5975f9835 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
abstract sealed trait AST
abstract sealed trait AExpr extends AST
case class AAssign(name: String, v: AExpr) extends AExpr
case class AConstBool(v: Boolean) extends AExpr
trait Ty {}
case class TInt() extends Ty
case class TBool() extends Ty
object Foo {
def checkExpr(ast: AExpr): Ty = {
var astTy:Ty = ast match {
case AAssign(nm: String, v:AExpr) => TBool()
case AConstBool(v: Boolean) => TBool()
case _ => throw new Exception(s"Unhandled case check(ast: ${ast.getClass})")
}
astTy
}
}
|