Starting to actually do Hindley-Milner!!

This commit is contained in:
greg 2017-10-08 22:48:10 -07:00
parent 4bb8f82579
commit 8fe535597e
2 changed files with 25 additions and 19 deletions
src/schala_lang

View File

@ -70,7 +70,9 @@ impl ProgrammingLanguageInterface for Schala {
}
match self.type_context.type_check(&ast) {
Ok(_) => (),
Ok(ty) => {
output.add_artifact(TraceArtifact::new("type_check", format!("type: {:?}", ty)));
},
Err(msg) => {
output.add_artifact(TraceArtifact::new("type_check", msg));
output.add_output(format!("Type error"));
@ -87,7 +89,6 @@ impl ProgrammingLanguageInterface for Schala {
acc.push_str("\n");
}
}
output.add_output(acc);
return output;
}

View File

@ -64,7 +64,11 @@ impl TypeContext {
}
}
pub struct SchalaType {
#[derive(Debug)]
pub enum SchalaType {
Integer,
Boolean,
Unit,
}
type TypeCheckResult = Result<SchalaType, String>;
@ -81,35 +85,36 @@ type TypeCheckResult = Result<SchalaType, String>;
fn bare_type_check(exprssion, expected_type) -> Ty { ... }
*/
// from https://www.youtube.com/watch?v=il3gD7XMdmA
// typeInfer :: Expr a -> Matching (Type a)
// unify :: Type a -> Type b -> Matching (Type c)
impl TypeContext {
pub fn type_check(&mut self, ast: &AST) -> TypeCheckResult {
use self::ExpressionType::*;
let mut last = SchalaType::Unit;
for statement in ast.0.iter() {
match statement {
&Statement::Declaration(ref _decl) => {
return Err(format!("Declarations not supported"));
//return Err(format!("Declarations not supported"));
},
&Statement::ExpressionStatement(ref expr) => {
self.expr_type_check(expr)?;
last = self.infer(expr)?;
}
}
}
Ok(SchalaType { })
Ok(last)
}
fn expr_type_check(&mut self, expr: &Expression) -> TypeCheckResult {
fn infer(&mut self, expr: &Expression) -> TypeCheckResult {
use self::ExpressionType::*;
match (&expr.0, &expr.1) {
(&IntLiteral(_), &Some(ref t)) => {
match t {
&TypeName::Singleton { ref name, ref params } if **name == "Int" && params.len() == 0 => (),
t => return Err(format!("Bad type {:?} for int literal", t)),
}
},
_ => (),
}
Ok(SchalaType { })
Ok(match (&expr.0, &expr.1) {
(&IntLiteral(_), _) => SchalaType::Integer,
(&BoolLiteral(_), _) => SchalaType::Boolean,
_ => SchalaType::Unit,
})
}
}