diff options
author | Santo Cariotti <santo@dcariotti.me> | 2024-06-13 11:00:06 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-06-13 11:00:06 +0200 |
commit | 8e7089a5d6ba1f4f50a90133bb50bc5c6c554aff (patch) | |
tree | d4a627e56a199720f7d811af5756402e76628864 /src/ast/nodes/IfNode.java | |
parent | 1c8761901b26c0be4d61f3aed5ec0495a558a0e7 (diff) |
Set up visitor (#3)
Co-authored-by: geno <gabriele.genovese2@studio.unibo.it>
Diffstat (limited to 'src/ast/nodes/IfNode.java')
-rw-r--r-- | src/ast/nodes/IfNode.java | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/src/ast/nodes/IfNode.java b/src/ast/nodes/IfNode.java new file mode 100644 index 0000000..a4f160d --- /dev/null +++ b/src/ast/nodes/IfNode.java @@ -0,0 +1,71 @@ +package com.clp.project.ast.nodes; + +import java.util.ArrayList; + +import com.clp.project.semanticanalysis.SemanticError; +import com.clp.project.semanticanalysis.SymbolTable; +import com.clp.project.ast.types.*; + +/** + * Node for the `if` statement of the grammar. + */ +public class IfNode implements Node { + private Node guard; + private Node thenbranch; + private Node elsebranch; + + public IfNode(Node guard, Node thenbranch, Node elsebranch) { + this.guard = guard; + this.thenbranch = thenbranch; + this.elsebranch = elsebranch; + } + + @Override + public ArrayList<SemanticError> checkSemantics(SymbolTable ST, int _nesting) { + ArrayList<SemanticError> errors = new ArrayList<SemanticError>(); + + errors.addAll(guard.checkSemantics(ST, _nesting)); + errors.addAll(thenbranch.checkSemantics(ST, _nesting)); + if (elsebranch != null) { + errors.addAll(elsebranch.checkSemantics(ST, _nesting)); + } + + return errors; + } + + // FIXME: fix the if statement + @Override + public Type typeCheck() { + if (guard.typeCheck() instanceof BoolType) { + Type thenexp = thenbranch.typeCheck(); + Type elseexp = elsebranch.typeCheck(); + if (thenexp.getClass().equals(elseexp.getClass())) + return thenexp; + else { + System.out.println("Type Error: incompatible types in then and else branches"); + return new ErrorType(); + } + } else { + System.out.println("Type Error: non boolean condition in if"); + return new ErrorType(); + } + } + + // TODO: add code generation for if + @Override + public String codeGeneration() { + return ""; + } + + @Override + public String toPrint(String prefix) { + String str = prefix + "If\n" + guard.toPrint(prefix + " ") + thenbranch.toPrint(prefix + " "); + + if (elsebranch != null) { + str += elsebranch.toPrint(prefix + " "); + } + + return str; + } + +} |