diff options
author | Elizabeth Hunt <elizabeth.hunt@simponic.xyz> | 2023-04-23 00:24:42 -0600 |
---|---|---|
committer | Elizabeth Hunt <elizabeth.hunt@simponic.xyz> | 2023-04-23 00:24:42 -0600 |
commit | a1c15f046183373baf5deb66e77188e656806fb7 (patch) | |
tree | fc1a7f584e67dc583d335f09d5271a45ff7d9df4 /submit/ast/If.java | |
parent | 5f28f80c4e25a56cd444914c2f0b3da5e7fdb088 (diff) | |
download | cminus-a1c15f046183373baf5deb66e77188e656806fb7.tar.gz cminus-a1c15f046183373baf5deb66e77188e656806fb7.zip |
Diffstat (limited to 'submit/ast/If.java')
-rw-r--r-- | submit/ast/If.java | 40 |
1 files changed, 39 insertions, 1 deletions
diff --git a/submit/ast/If.java b/submit/ast/If.java index a516c94..0c47ce9 100644 --- a/submit/ast/If.java +++ b/submit/ast/If.java @@ -4,6 +4,10 @@ */ package submit.ast; +import submit.MIPSResult; +import submit.RegisterAllocator; +import submit.SymbolTable; + /** * * @author edwajohn @@ -14,7 +18,8 @@ public class If extends AbstractNode implements Statement { private final Statement trueStatement; private final Statement falseStatement; - public If(Expression expression, Statement trueStatement, Statement falseStatement) { + public If(Expression expression, Statement trueStatement, + Statement falseStatement) { this.expression = expression; this.trueStatement = trueStatement; this.falseStatement = falseStatement; @@ -41,4 +46,37 @@ public class If extends AbstractNode implements Statement { } // builder.append(prefix).append("}"); } + + @Override + public MIPSResult toMIPS(StringBuilder code, StringBuilder data, + SymbolTable symbolTable, + RegisterAllocator regAllocator) { + String continueLabel = "if_" + SymbolTable.nextId(); + String elseLabel = "else_" + SymbolTable.nextId(); + + MIPSResult expressionTruthiness = + expression.toMIPS(code, data, symbolTable, regAllocator); + + code.append(String.format("bne %s $zero %s\n", + expressionTruthiness.getRegister(), elseLabel)); + regAllocator.clear(expressionTruthiness.getRegister()); + + MIPSResult trueRes = + trueStatement.toMIPS(code, data, symbolTable, regAllocator); + regAllocator.clear(trueRes.getRegister()); + + code.append(String.format("j %s\n", continueLabel)) + .append(String.format("%s:\n", elseLabel)); + + regAllocator.clear(expressionTruthiness.getRegister()); + + if (falseStatement != null) { + MIPSResult falseRes = + falseStatement.toMIPS(code, data, symbolTable, regAllocator); + regAllocator.clear(falseRes.getRegister()); + } + code.append(String.format("%s:\n", continueLabel)); + + return MIPSResult.createVoidResult(); + } } |