From 8e7089a5d6ba1f4f50a90133bb50bc5c6c554aff Mon Sep 17 00:00:00 2001 From: Santo Cariotti Date: Thu, 13 Jun 2024 11:00:06 +0200 Subject: Set up visitor (#3) Co-authored-by: geno --- src/ast/nodes/AssignmentNode.java | 52 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 src/ast/nodes/AssignmentNode.java (limited to 'src/ast/nodes/AssignmentNode.java') diff --git a/src/ast/nodes/AssignmentNode.java b/src/ast/nodes/AssignmentNode.java new file mode 100644 index 0000000..d722f41 --- /dev/null +++ b/src/ast/nodes/AssignmentNode.java @@ -0,0 +1,52 @@ +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 `assignment` statement of the grammar. + */ +public class AssignmentNode implements Node { + private Node lhr; + private Node assign; + private Node rhr; + + public AssignmentNode(Node lhr, Node assign, Node rhr) { + this.lhr = lhr; + this.assign = assign; + this.rhr = rhr; + } + + @Override + public ArrayList checkSemantics(SymbolTable ST, int _nesting) { + ArrayList errors = new ArrayList(); + + errors.addAll(lhr.checkSemantics(ST, _nesting)); + errors.addAll(assign.checkSemantics(ST, _nesting)); + errors.addAll(rhr.checkSemantics(ST, _nesting)); + + return errors; + } + + // TODO: check it out for this type + @Override + public Type typeCheck() { + return rhr.typeCheck(); + } + + // TODO: add code generation for assignment + @Override + public String codeGeneration() { + return ""; + } + + @Override + public String toPrint(String prefix) { + return prefix + "Assignment\n" + lhr.toPrint(prefix + " ") + assign.toPrint(prefix + " ") + + rhr.toPrint(prefix + " "); + } + +} -- cgit v1.2.3-18-g5258