summaryrefslogtreecommitdiff
path: root/src/ast/nodes/IfNode.java
diff options
context:
space:
mode:
authorEmanuele Grasso <96300448+L0P0P@users.noreply.github.com>2024-07-14 18:48:09 +0200
committerGitHub <noreply@github.com>2024-07-14 18:48:09 +0200
commitce49d20a5fe3726e1800bc495a25c7617212abf4 (patch)
tree5a1a79efa79e7bf6dcf3d3151aec2edf6a47b3e7 /src/ast/nodes/IfNode.java
parent57599a42b863cc48050c137de2ec108aa1d59a44 (diff)
Reaching definition analysis (#17)
Co-authored-by: Santo Cariotti <santo@dcariotti.me> Co-authored-by: geno <gabriele.genovese2@studio.unibo.it> Co-authored-by: geno <gabrigeno@gmail.com>
Diffstat (limited to 'src/ast/nodes/IfNode.java')
-rw-r--r--src/ast/nodes/IfNode.java19
1 files changed, 15 insertions, 4 deletions
diff --git a/src/ast/nodes/IfNode.java b/src/ast/nodes/IfNode.java
index ca42b7a..fd878f8 100644
--- a/src/ast/nodes/IfNode.java
+++ b/src/ast/nodes/IfNode.java
@@ -34,7 +34,6 @@ public class IfNode implements Node {
return errors;
}
- // FIXME: fix the if statement
@Override
public Type typeCheck() {
if (guard.typeCheck() instanceof BoolType) {
@@ -78,14 +77,26 @@ public class IfNode implements Node {
}
@Override
- public String toPrint(String prefix) {
- String str = prefix + "If\n" + guard.toPrint(prefix + " ") + thenBranch.toPrint(prefix + " ");
+ public String printAST(String prefix) {
+ String str = prefix + "If\n" + guard.printAST(prefix + " ") + thenBranch.printAST(prefix + " ");
if (elseBranch != null) {
- str += elseBranch.toPrint(prefix + " ");
+ str += elseBranch.printAST(prefix + " ");
}
return str;
}
+ @Override
+ public String toPrint(String prefix) {
+ String str = prefix + "if ";
+ str += guard.toPrint("") + ":\n";
+ str += thenBranch.toPrint(prefix + "\t") + "\n";
+ if (elseBranch != null) {
+ str += prefix + "else:\n";
+ str += elseBranch.toPrint(prefix + "\t") + "\n";
+ }
+ return str;
+ }
+
}