summaryrefslogtreecommitdiff
path: root/src/ast/nodes/CompoundNode.java
diff options
context:
space:
mode:
authorGeno <48206120+gabrielegenovese@users.noreply.github.com>2024-07-11 12:57:56 +0200
committerGitHub <noreply@github.com>2024-07-11 12:57:56 +0200
commitb50c7e99603e9f85d82d700d62c16c4fcef88715 (patch)
tree5052206f06e0426a43599cb236652614db04d22e /src/ast/nodes/CompoundNode.java
parentf0692ff5f9e39cbd1c203e9d5abebf55a3d0f6fc (diff)
Code generation (#20)
Co-authored-by: geno <gabrigeno@gmail> Co-authored-by: Santo Cariotti <santo@dcariotti.me>
Diffstat (limited to 'src/ast/nodes/CompoundNode.java')
-rw-r--r--src/ast/nodes/CompoundNode.java29
1 files changed, 22 insertions, 7 deletions
diff --git a/src/ast/nodes/CompoundNode.java b/src/ast/nodes/CompoundNode.java
index 2655f35..f0f63f2 100644
--- a/src/ast/nodes/CompoundNode.java
+++ b/src/ast/nodes/CompoundNode.java
@@ -23,23 +23,23 @@ public class CompoundNode implements Node {
}
@Override
- public ArrayList<SemanticError> checkSemantics(SymbolTable ST, int _nesting) {
+ public ArrayList<SemanticError> checkSemantics(SymbolTable ST, int _nesting, FunctionType ft) {
ArrayList<SemanticError> errors = new ArrayList<>();
if (ifNode != null) {
- errors.addAll(ifNode.checkSemantics(ST, _nesting));
+ errors.addAll(ifNode.checkSemantics(ST, _nesting, ft));
}
if (funcDef != null) {
- errors.addAll(funcDef.checkSemantics(ST, _nesting));
+ errors.addAll(funcDef.checkSemantics(ST, _nesting, ft));
}
if (forStmt != null) {
- errors.addAll(forStmt.checkSemantics(ST, _nesting));
+ errors.addAll(forStmt.checkSemantics(ST, _nesting, ft));
}
if (whileStmt != null) {
- errors.addAll(whileStmt.checkSemantics(ST, _nesting));
+ errors.addAll(whileStmt.checkSemantics(ST, _nesting, ft));
}
return errors;
@@ -50,10 +50,25 @@ public class CompoundNode implements Node {
return new VoidType();
}
- // TODO: add code generation for CompoundNode
@Override
public String codeGeneration() {
- return "";
+ if (ifNode != null) {
+ return ifNode.codeGeneration();
+ }
+
+ if (funcDef != null) {
+ return funcDef.codeGeneration();
+ }
+
+ if (forStmt != null) {
+ return forStmt.codeGeneration();
+ }
+
+ if (whileStmt != null) {
+ return whileStmt.codeGeneration();
+ }
+
+ return "Error: everything is null in Compound node\n";
}
@Override