From 96138b1e23eedbefd4f30d728c91026ada2b226c Mon Sep 17 00:00:00 2001 From: Empa Date: Wed, 1 May 2024 10:14:31 +0200 Subject: [PATCH] Annotate functions --- crates/saft-ir/src/lowerer.rs | 2 +- crates/saft-syntax/src/ast.rs | 10 +++++++++- crates/saft-syntax/src/lex.rs | 1 + crates/saft-syntax/src/parser.rs | 17 +++++++++++++++-- crates/saft-syntax/src/token.rs | 2 ++ 5 files changed, 28 insertions(+), 4 deletions(-) diff --git a/crates/saft-ir/src/lowerer.rs b/crates/saft-ir/src/lowerer.rs index b747dfb..a10add2 100644 --- a/crates/saft-ir/src/lowerer.rs +++ b/crates/saft-ir/src/lowerer.rs @@ -120,7 +120,7 @@ impl Lowerer { self.scoped_based(|l| { let params = params .iter() - .map(|ident| l.declare(ident)) + .map(|ident| l.declare(&ident.v.name)) .try_collect::>()?; let body = l.lower_block(body)?; diff --git a/crates/saft-syntax/src/ast.rs b/crates/saft-syntax/src/ast.rs index 9e92ba0..8cb6a2e 100644 --- a/crates/saft-syntax/src/ast.rs +++ b/crates/saft-syntax/src/ast.rs @@ -127,13 +127,21 @@ pub enum Item { Function(Function), } +#[derive(Debug, Clone, PartialEq)] +pub struct Parameter { + pub name: Spanned, + pub ty: Spanned, +} + #[derive(Debug, Clone, PartialEq)] pub struct Function { pub ident: Spanned, - pub params: Vec>, + pub params: Vec>, pub body: Spanned, + pub ret_ty: Option>, } +#[derive(Debug, Clone, PartialEq, Eq)] pub enum Type { Ident(Ident), } diff --git a/crates/saft-syntax/src/lex.rs b/crates/saft-syntax/src/lex.rs index b9a8e1e..4c9456a 100644 --- a/crates/saft-syntax/src/lex.rs +++ b/crates/saft-syntax/src/lex.rs @@ -80,6 +80,7 @@ impl<'a> Lexer<'a> { '!' if Self::eat_chars(&mut cur, "!=") => mktoken!(cur, T::BangEqual), '!' => eat_token!(cur, T::Bang), '+' => eat_token!(cur, T::Plus), + '-' if Self::eat_chars(&mut cur, "->") => mktoken!(cur, T::Arrow), '-' => eat_token!(cur, T::Minus), '*' => eat_token!(cur, T::Star), '/' if Self::eat_chars(&mut cur, "//") => mktoken!(cur, T::SlashSlash), diff --git a/crates/saft-syntax/src/parser.rs b/crates/saft-syntax/src/parser.rs index cb33603..be9294c 100644 --- a/crates/saft-syntax/src/parser.rs +++ b/crates/saft-syntax/src/parser.rs @@ -493,11 +493,17 @@ impl<'a> Parser<'a> { let start = self.eat(Token::Fn)?; let ident = self.eat_ident()?; - let mut params = Vec::new(); + let mut params = Vec::>::new(); self.eat(Token::LParen)?; while self.peek().v != Token::RParen { - let param = self.eat_ident()?; + let name = self.eat_ident()?; + self.eat(Token::Colon)?; + let ty = self.parse_ty()?; + let s = name.s.join(&ty.s); + + let param = s.spanned(ast::Parameter { name, ty }); + params.push(param); if self.try_eat(Token::Comma).is_none() { @@ -507,6 +513,12 @@ impl<'a> Parser<'a> { self.eat(Token::RParen)?; + let ret_ty = if self.try_eat(Token::Arrow).is_some() { + Some(self.parse_ty()?) + } else { + None + }; + let body = self.parse_block(None)?; let s = start.join(&body.s); @@ -515,6 +527,7 @@ impl<'a> Parser<'a> { ident, params, body, + ret_ty, })), s, )) diff --git a/crates/saft-syntax/src/token.rs b/crates/saft-syntax/src/token.rs index 39d56a4..6ed8b4a 100644 --- a/crates/saft-syntax/src/token.rs +++ b/crates/saft-syntax/src/token.rs @@ -23,6 +23,7 @@ pub enum Token { Comma, Semicolon, Colon, + Arrow, Identifier(String), Float(f64), @@ -98,6 +99,7 @@ impl Token { Comment(s) => format!("comment '{s}'"), Colon => "':'".into(), Let => "'let'".into(), + Arrow => "'->'".into(), } } }