Compare commits
No commits in common. "257a7e64c2f5473b7ebe3d7858010504e6b322b0" and "40d611ae37bcc68a103d0c83ee94c69b3e1fd3b5" have entirely different histories.
257a7e64c2
...
40d611ae37
3 changed files with 51 additions and 107 deletions
|
|
@ -653,7 +653,6 @@ impl<'a> Semantics<'a> {
|
||||||
TreeKind::LetStatement => Some(Type::Nothing),
|
TreeKind::LetStatement => Some(Type::Nothing),
|
||||||
TreeKind::ReturnStatement => Some(Type::Unreachable),
|
TreeKind::ReturnStatement => Some(Type::Unreachable),
|
||||||
TreeKind::ExpressionStatement => self.type_of_expression_statement(tree),
|
TreeKind::ExpressionStatement => self.type_of_expression_statement(tree),
|
||||||
TreeKind::IfStatement => self.type_of_if_statement(tree),
|
|
||||||
TreeKind::Identifier => self.type_of_identifier(t, tree),
|
TreeKind::Identifier => self.type_of_identifier(t, tree),
|
||||||
|
|
||||||
TreeKind::FunctionDecl => self.type_of_function_decl(tree),
|
TreeKind::FunctionDecl => self.type_of_function_decl(tree),
|
||||||
|
|
@ -1021,10 +1020,6 @@ impl<'a> Semantics<'a> {
|
||||||
Some(Type::Function(parameter_types, return_type))
|
Some(Type::Function(parameter_types, return_type))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn type_of_if_statement(&self, tree: &Tree) -> Option<Type> {
|
|
||||||
Some(self.type_of(tree.nth_tree(0)?))
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn dump_compiler_state(&self, tr: Option<TreeRef>) {
|
pub fn dump_compiler_state(&self, tr: Option<TreeRef>) {
|
||||||
eprintln!("Parsed the tree as:");
|
eprintln!("Parsed the tree as:");
|
||||||
eprintln!("\n{}", self.syntax_tree.dump(true));
|
eprintln!("\n{}", self.syntax_tree.dump(true));
|
||||||
|
|
|
||||||
|
|
@ -1,45 +1,9 @@
|
||||||
fun test() {
|
true and false or false and !true;
|
||||||
true and false or false and !true
|
|
||||||
}
|
|
||||||
|
|
||||||
// @no-errors
|
// @no-errors
|
||||||
// @compiles-to:
|
|
||||||
// | function test (0 args, 0 locals):
|
|
||||||
// | strings (0):
|
|
||||||
// | code (15):
|
|
||||||
// | 0: PushTrue
|
|
||||||
// | 1: JumpFalse(4)
|
|
||||||
// | 2: PushTrue
|
|
||||||
// | 3: Jump(5)
|
|
||||||
// | 4: PushFalse
|
|
||||||
// | 5: JumpTrue(8)
|
|
||||||
// | 6: PushTrue
|
|
||||||
// | 7: Jump(14)
|
|
||||||
// | 8: PushFalse
|
|
||||||
// | 9: JumpFalse(12)
|
|
||||||
// | 10: PushTrue
|
|
||||||
// | 11: Jump(14)
|
|
||||||
// | 12: PushTrue
|
|
||||||
// | 13: BoolNot
|
|
||||||
// | 14: Return
|
|
||||||
// | function << module >> (0 args, 0 locals):
|
|
||||||
// | strings (0):
|
|
||||||
// | code (2):
|
|
||||||
// | 0: PushNothing
|
|
||||||
// | 1: Return
|
|
||||||
// |
|
|
||||||
// @eval: Bool(false)
|
|
||||||
// @type: 15 bool
|
// @type: 15 bool
|
||||||
// @concrete:
|
// @concrete:
|
||||||
// | File
|
// | File
|
||||||
// | FunctionDecl
|
|
||||||
// | Fun:'"fun"'
|
|
||||||
// | Identifier:'"test"'
|
|
||||||
// | ParamList
|
|
||||||
// | LeftParen:'"("'
|
|
||||||
// | RightParen:'")"'
|
|
||||||
// | Block
|
|
||||||
// | LeftBrace:'"{"'
|
|
||||||
// | ExpressionStatement
|
// | ExpressionStatement
|
||||||
// | BinaryExpression
|
// | BinaryExpression
|
||||||
// | BinaryExpression
|
// | BinaryExpression
|
||||||
|
|
@ -57,5 +21,4 @@ fun test() {
|
||||||
// | Bang:'"!"'
|
// | Bang:'"!"'
|
||||||
// | LiteralExpression
|
// | LiteralExpression
|
||||||
// | True:'"true"'
|
// | True:'"true"'
|
||||||
// | RightBrace:'"}"'
|
// | Semicolon:'";"'
|
||||||
//
|
|
||||||
|
|
|
||||||
|
|
@ -1,33 +1,26 @@
|
||||||
fun test() {
|
if true { "discarded"; 23 } else { 45 }
|
||||||
if true { "discarded"; 23 } else { 45 }
|
|
||||||
}
|
|
||||||
|
|
||||||
// @no-errors
|
// @no-errors
|
||||||
// Here come some type probes!
|
// Here come some type probes!
|
||||||
// (type of the condition)
|
// (type of the condition)
|
||||||
// @type: 20 bool
|
// @type: 3 bool
|
||||||
//
|
//
|
||||||
// (the discarded expression)
|
// (the discarded expression)
|
||||||
// @type: 27 string
|
// @type: 10 string
|
||||||
//
|
//
|
||||||
// (the "then" clause)
|
// (the "then" clause)
|
||||||
// @type: 40 f64
|
// @type: 23 f64
|
||||||
// @type: 43 f64
|
// @type: 26 f64
|
||||||
//
|
//
|
||||||
// (the "else" clause)
|
// (the "else" clause)
|
||||||
// @type: 52 f64
|
// @type: 35 f64
|
||||||
// @type: 55 f64
|
// @type: 38 f64
|
||||||
|
//
|
||||||
|
// (the overall expression)
|
||||||
|
// @type: 0 f64
|
||||||
//
|
//
|
||||||
// @concrete:
|
// @concrete:
|
||||||
// | File
|
// | File
|
||||||
// | FunctionDecl
|
|
||||||
// | Fun:'"fun"'
|
|
||||||
// | Identifier:'"test"'
|
|
||||||
// | ParamList
|
|
||||||
// | LeftParen:'"("'
|
|
||||||
// | RightParen:'")"'
|
|
||||||
// | Block
|
|
||||||
// | LeftBrace:'"{"'
|
|
||||||
// | IfStatement
|
// | IfStatement
|
||||||
// | ConditionalExpression
|
// | ConditionalExpression
|
||||||
// | If:'"if"'
|
// | If:'"if"'
|
||||||
|
|
@ -50,10 +43,9 @@ fun test() {
|
||||||
// | LiteralExpression
|
// | LiteralExpression
|
||||||
// | Number:'"45"'
|
// | Number:'"45"'
|
||||||
// | RightBrace:'"}"'
|
// | RightBrace:'"}"'
|
||||||
// | RightBrace:'"}"'
|
|
||||||
//
|
//
|
||||||
// @compiles-to:
|
// @compiles-to:
|
||||||
// | function test (0 args, 0 locals):
|
// | function << module >> (0 args, 0 locals):
|
||||||
// | strings (1):
|
// | strings (1):
|
||||||
// | 0: "discarded"
|
// | 0: "discarded"
|
||||||
// | code (8):
|
// | code (8):
|
||||||
|
|
@ -65,10 +57,4 @@ fun test() {
|
||||||
// | 5: Jump(7)
|
// | 5: Jump(7)
|
||||||
// | 6: PushFloat(45.0)
|
// | 6: PushFloat(45.0)
|
||||||
// | 7: Return
|
// | 7: Return
|
||||||
// | function << module >> (0 args, 0 locals):
|
|
||||||
// | strings (0):
|
|
||||||
// | code (2):
|
|
||||||
// | 0: PushNothing
|
|
||||||
// | 1: Return
|
|
||||||
// |
|
// |
|
||||||
// @eval: Float(23.0)
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue