From d3046e3b1481cf6d190b8fcb814985e29852b5eb Mon Sep 17 00:00:00 2001 From: AidenRushbrooke <72034940+AidenRushbrooke@users.noreply.github.com> Date: Sat, 6 Nov 2021 16:40:12 +0000 Subject: Working if/else statements (very basic and unstable) --- src/Compiler/Translator.java | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) (limited to 'src/Compiler/Translator.java') diff --git a/src/Compiler/Translator.java b/src/Compiler/Translator.java index b62df63..5848389 100644 --- a/src/Compiler/Translator.java +++ b/src/Compiler/Translator.java @@ -43,6 +43,9 @@ public class Translator{ case "print": evalPrintStatement((PrintStatement)statement); break; + case "ifStmt": + evalIfStatement((IfStatement)statement); + break; } } private void evalExpressionStatement(ExpressionStatement stmt){ @@ -58,6 +61,22 @@ public class Translator{ CCode.add("printf(\"%d\","+evaluateExpression(print.expr)+");"); } + private void evalIfStatement(IfStatement ifstatement){ + + CCode.add("if("+evaluateExpression(ifstatement.condition)+"){"); + for(Statement s:ifstatement.statements) { + evaluateStatement(s); + } + if(ifstatement.elseStatements.size()>0){ + CCode.add("}"); + CCode.add("else {"); + for(Statement s:ifstatement.elseStatements) { + evaluateStatement(s); + } + } + CCode.add("}"); + } + private String evaluateExpression(Expression expression){ switch(expression.getExpressionType()){ case "binary": -- cgit v1.2.3