diff options
Diffstat (limited to 'src/type/check.rs')
-rw-r--r-- | src/type/check.rs | 17 |
1 files changed, 5 insertions, 12 deletions
diff --git a/src/type/check.rs b/src/type/check.rs index e9917c7..d678411 100644 --- a/src/type/check.rs +++ b/src/type/check.rs @@ -136,8 +136,7 @@ impl SExp { match self { Atom(Int(_)) => Ok(Integer), - Atom(True) => todo!(), - Atom(False) => todo!(), + Atom(True | False) => Ok(Boolean), Atom(Var(name)) => ctx.get(name) .ok_or(UndefinedVariable(name.to_string())) .cloned(), @@ -145,16 +144,10 @@ impl SExp { Atom(Mul) => Ok(arr(List(vec![Integer, Integer]), Integer)), // TODO varlen Atom(Sub) => Ok(arr(List(vec![Integer, Integer]), Integer)), Atom(Div) => Ok(arr(List(vec![Integer, Integer]), Integer)), - Atom(Eq) => todo!(), - Atom(Neq) => todo!(), - Atom(Lt) => todo!(), - Atom(Gt) => todo!(), - Atom(Le) => todo!(), - Atom(Ge) => todo!(), - Atom(Or) => todo!(), - Atom(And) => todo!(), - Atom(Xor) => todo!(), - Atom(Not) => todo!(), + Atom(Eq | Neq | Lt | Gt | Le | Ge) => + Ok(arr(List(vec![Integer, Integer]), Boolean)), + Atom(Or | And | Xor) => Ok(arr(List(vec![Boolean, Boolean]), Boolean)), + Atom(Not) => Ok(arr(Boolean, Boolean)), Atom(Nil) => Ok(List(vec![])), Atom(Quote) => Ok(arr( VarType("T".to_string()), |