summaryrefslogtreecommitdiff
path: root/submit/ast
diff options
context:
space:
mode:
Diffstat (limited to 'submit/ast')
-rw-r--r--submit/ast/AbstractNode.java15
-rw-r--r--submit/ast/Assignment.java33
-rw-r--r--submit/ast/AssignmentType.java35
-rw-r--r--submit/ast/BinaryOperator.java35
-rw-r--r--submit/ast/BinaryOperatorType.java37
-rw-r--r--submit/ast/BoolConstant.java27
-rw-r--r--submit/ast/Break.java18
-rw-r--r--submit/ast/Call.java37
-rw-r--r--submit/ast/CharConstant.java23
-rw-r--r--submit/ast/CompoundStatement.java30
-rw-r--r--submit/ast/Declaration.java13
-rw-r--r--submit/ast/Expression.java13
-rw-r--r--submit/ast/ExpressionStatement.java26
-rw-r--r--submit/ast/FunDeclaration.java46
-rw-r--r--submit/ast/If.java44
-rw-r--r--submit/ast/Mutable.java31
-rw-r--r--submit/ast/Node.java11
-rw-r--r--submit/ast/NumConstant.java23
-rw-r--r--submit/ast/Param.java43
-rw-r--r--submit/ast/ParenExpression.java26
-rw-r--r--submit/ast/Program.java36
-rw-r--r--submit/ast/Return.java31
-rw-r--r--submit/ast/Statement.java16
-rw-r--r--submit/ast/StringConstant.java23
-rw-r--r--submit/ast/UnaryOperator.java27
-rw-r--r--submit/ast/UnaryOperatorType.java35
-rw-r--r--submit/ast/VarDeclaration.java47
-rw-r--r--submit/ast/VarType.java35
-rw-r--r--submit/ast/While.java33
29 files changed, 849 insertions, 0 deletions
diff --git a/submit/ast/AbstractNode.java b/submit/ast/AbstractNode.java
new file mode 100644
index 0000000..01719aa
--- /dev/null
+++ b/submit/ast/AbstractNode.java
@@ -0,0 +1,15 @@
+package submit.ast;
+
+import submit.MIPSResult;
+import submit.RegisterAllocator;
+import submit.SymbolTable;
+
+public class AbstractNode implements Node {
+ public void toCminus(StringBuilder sb, String prefix) {
+ }
+
+ public MIPSResult toMIPS(StringBuilder code, StringBuilder data, SymbolTable symbolTable,
+ RegisterAllocator regAllocator) {
+ return null;
+ }
+}
diff --git a/submit/ast/Assignment.java b/submit/ast/Assignment.java
new file mode 100644
index 0000000..1a5d172
--- /dev/null
+++ b/submit/ast/Assignment.java
@@ -0,0 +1,33 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class Assignment extends AbstractNode implements Expression {
+
+ private final Mutable mutable;
+ private final AssignmentType type;
+ private final Expression rhs;
+
+ public Assignment(Mutable mutable, String assign, Expression rhs) {
+ this.mutable = mutable;
+ this.type = AssignmentType.fromString(assign);
+ this.rhs = rhs;
+ }
+
+ public void toCminus(StringBuilder builder, final String prefix) {
+ mutable.toCminus(builder, prefix);
+ if (rhs != null) {
+ builder.append(" ").append(type.toString()).append(" ");
+ rhs.toCminus(builder, prefix);
+ } else {
+ builder.append(type.toString());
+ }
+ }
+
+}
diff --git a/submit/ast/AssignmentType.java b/submit/ast/AssignmentType.java
new file mode 100644
index 0000000..9dd2bdf
--- /dev/null
+++ b/submit/ast/AssignmentType.java
@@ -0,0 +1,35 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public enum AssignmentType {
+
+ EQUALS("="), PLUS("+="), MINUS("-="), TIMES("*="), DIVIDE("/="), INC("++"), DEC("--");
+
+ private final String value;
+
+ private AssignmentType(String value) {
+ this.value = value;
+ }
+
+ public static AssignmentType fromString(String s) {
+ for (AssignmentType at : AssignmentType.values()) {
+ if (at.value.equals(s)) {
+ return at;
+ }
+ }
+ throw new RuntimeException("Illegal string in AssignType.fromString()");
+ }
+
+ @Override
+ public String toString() {
+ return value;
+ }
+
+}
diff --git a/submit/ast/BinaryOperator.java b/submit/ast/BinaryOperator.java
new file mode 100644
index 0000000..d18766b
--- /dev/null
+++ b/submit/ast/BinaryOperator.java
@@ -0,0 +1,35 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class BinaryOperator extends AbstractNode implements Expression {
+
+ private final Expression lhs, rhs;
+ private final BinaryOperatorType type;
+
+ public BinaryOperator(Expression lhs, BinaryOperatorType type, Expression rhs) {
+ this.lhs = lhs;
+ this.type = type;
+ this.rhs = rhs;
+ }
+
+ public BinaryOperator(Expression lhs, String type, Expression rhs) {
+ this.lhs = lhs;
+ this.type = BinaryOperatorType.fromString(type);
+ this.rhs = rhs;
+ }
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ lhs.toCminus(builder, prefix);
+ builder.append(" ").append(type).append(" ");
+ rhs.toCminus(builder, prefix);
+ }
+
+}
diff --git a/submit/ast/BinaryOperatorType.java b/submit/ast/BinaryOperatorType.java
new file mode 100644
index 0000000..37235c8
--- /dev/null
+++ b/submit/ast/BinaryOperatorType.java
@@ -0,0 +1,37 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public enum BinaryOperatorType {
+
+ OR("||"), AND("&&"),
+ LE("<="), LT("<"), GT(">"), GE(">="), EQ("=="), NE("!="),
+ PLUS("+"), MINUS("-"), TIMES("*"), DIVIDE("/"), MOD("%");
+
+ private final String value;
+
+ private BinaryOperatorType(String value) {
+ this.value = value;
+ }
+
+ public static BinaryOperatorType fromString(String s) {
+ for (BinaryOperatorType at : BinaryOperatorType.values()) {
+ if (at.value.equals(s)) {
+ return at;
+ }
+ }
+ throw new RuntimeException("Illegal string in OperatorType.fromString(): " + s);
+ }
+
+ @Override
+ public String toString() {
+ return value;
+ }
+
+}
diff --git a/submit/ast/BoolConstant.java b/submit/ast/BoolConstant.java
new file mode 100644
index 0000000..4b0ad2c
--- /dev/null
+++ b/submit/ast/BoolConstant.java
@@ -0,0 +1,27 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class BoolConstant extends AbstractNode implements Expression {
+
+ private final boolean value;
+
+ public BoolConstant(boolean value) {
+ this.value = value;
+ }
+
+ public void toCminus(StringBuilder builder, final String prefix) {
+ if (value) {
+ builder.append("true");
+ } else {
+ builder.append("false");
+ }
+ }
+
+}
diff --git a/submit/ast/Break.java b/submit/ast/Break.java
new file mode 100644
index 0000000..e3f28bc
--- /dev/null
+++ b/submit/ast/Break.java
@@ -0,0 +1,18 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class Break extends AbstractNode implements Statement {
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ builder.append(prefix).append("break;\n");
+ }
+
+}
diff --git a/submit/ast/Call.java b/submit/ast/Call.java
new file mode 100644
index 0000000..b6e61ba
--- /dev/null
+++ b/submit/ast/Call.java
@@ -0,0 +1,37 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class Call extends AbstractNode implements Expression {
+
+ private final String id;
+ private final List<Expression> args;
+
+ public Call(String id, List<Expression> args) {
+ this.id = id;
+ this.args = new ArrayList<>(args);
+ }
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ builder.append(id).append("(");
+ for (Expression arg : args) {
+ arg.toCminus(builder, prefix);
+ builder.append(", ");
+ }
+ if (!args.isEmpty()) {
+ builder.setLength(builder.length() - 2);
+ }
+ builder.append(")");
+ }
+
+}
diff --git a/submit/ast/CharConstant.java b/submit/ast/CharConstant.java
new file mode 100644
index 0000000..8ca801d
--- /dev/null
+++ b/submit/ast/CharConstant.java
@@ -0,0 +1,23 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class CharConstant extends AbstractNode implements Expression {
+
+ private final char value;
+
+ public CharConstant(char value) {
+ this.value = value;
+ }
+
+ public void toCminus(StringBuilder builder, final String prefix) {
+ builder.append("'").append(value).append("'");
+ }
+
+}
diff --git a/submit/ast/CompoundStatement.java b/submit/ast/CompoundStatement.java
new file mode 100644
index 0000000..bd5628a
--- /dev/null
+++ b/submit/ast/CompoundStatement.java
@@ -0,0 +1,30 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+import java.util.List;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class CompoundStatement extends AbstractNode implements Statement {
+
+ private final List<Statement> statements;
+
+ public CompoundStatement(List<Statement> statements) {
+ this.statements = statements;
+ }
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ builder.append(prefix).append("{\n");
+ for (Statement s : statements) {
+ s.toCminus(builder, prefix + " ");
+ }
+ builder.append(prefix).append("}\n");
+ }
+
+}
diff --git a/submit/ast/Declaration.java b/submit/ast/Declaration.java
new file mode 100644
index 0000000..32947e6
--- /dev/null
+++ b/submit/ast/Declaration.java
@@ -0,0 +1,13 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public interface Declaration extends Statement {
+
+}
diff --git a/submit/ast/Expression.java b/submit/ast/Expression.java
new file mode 100644
index 0000000..910f6f0
--- /dev/null
+++ b/submit/ast/Expression.java
@@ -0,0 +1,13 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public interface Expression extends Node {
+
+}
diff --git a/submit/ast/ExpressionStatement.java b/submit/ast/ExpressionStatement.java
new file mode 100644
index 0000000..69071d8
--- /dev/null
+++ b/submit/ast/ExpressionStatement.java
@@ -0,0 +1,26 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class ExpressionStatement extends AbstractNode implements Statement {
+
+ private final Expression expression;
+
+ public ExpressionStatement(Expression expression) {
+ this.expression = expression;
+ }
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ builder.append(prefix);
+ expression.toCminus(builder, prefix);
+ builder.append(";\n");
+ }
+
+}
diff --git a/submit/ast/FunDeclaration.java b/submit/ast/FunDeclaration.java
new file mode 100644
index 0000000..1ec2ca6
--- /dev/null
+++ b/submit/ast/FunDeclaration.java
@@ -0,0 +1,46 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class FunDeclaration extends AbstractNode implements Declaration {
+
+ private final VarType returnType;
+ private final String id;
+ private final ArrayList<Param> params;
+ private final Statement statement;
+
+ public FunDeclaration(VarType returnType, String id, List<Param> params,
+ Statement statement) {
+ this.returnType = returnType;
+ this.id = id;
+ this.params = new ArrayList<>(params);
+ this.statement = statement;
+ }
+
+ public void toCminus(StringBuilder builder, final String prefix) {
+ String rt = (returnType != null) ? returnType.toString() : "void";
+ builder.append("\n").append(rt).append(" ");
+ builder.append(id);
+ builder.append("(");
+
+ for (Param param : params) {
+ param.toCminus(builder, prefix);
+ builder.append(", ");
+ }
+ if (!params.isEmpty()) {
+ builder.delete(builder.length() - 2, builder.length());
+ }
+ builder.append(")\n");
+ statement.toCminus(builder, prefix);
+ }
+
+}
diff --git a/submit/ast/If.java b/submit/ast/If.java
new file mode 100644
index 0000000..a516c94
--- /dev/null
+++ b/submit/ast/If.java
@@ -0,0 +1,44 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class If extends AbstractNode implements Statement {
+
+ private final Expression expression;
+ private final Statement trueStatement;
+ private final Statement falseStatement;
+
+ public If(Expression expression, Statement trueStatement, Statement falseStatement) {
+ this.expression = expression;
+ this.trueStatement = trueStatement;
+ this.falseStatement = falseStatement;
+ }
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ builder.append(prefix).append("if (");
+ expression.toCminus(builder, prefix);
+ builder.append(")\n");
+ if (trueStatement instanceof CompoundStatement) {
+ trueStatement.toCminus(builder, prefix);
+ } else {
+ trueStatement.toCminus(builder, prefix + " ");
+ }
+ if (falseStatement != null) {
+ builder.append(prefix).append("else\n");
+ // falseStatement.toCminus(builder, prefix);
+ if (falseStatement instanceof CompoundStatement) {
+ falseStatement.toCminus(builder, prefix);
+ } else {
+ falseStatement.toCminus(builder, prefix + " ");
+ }
+ }
+ // builder.append(prefix).append("}");
+ }
+}
diff --git a/submit/ast/Mutable.java b/submit/ast/Mutable.java
new file mode 100644
index 0000000..d549371
--- /dev/null
+++ b/submit/ast/Mutable.java
@@ -0,0 +1,31 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class Mutable extends AbstractNode implements Expression {
+
+ private final String id;
+ private final Expression index;
+
+ public Mutable(String id, Expression index) {
+ this.id = id;
+ this.index = index;
+ }
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ builder.append(id);
+ if (index != null) {
+ builder.append("[");
+ index.toCminus(builder, prefix);
+ builder.append("]");
+ }
+ }
+
+}
diff --git a/submit/ast/Node.java b/submit/ast/Node.java
new file mode 100644
index 0000000..2eed788
--- /dev/null
+++ b/submit/ast/Node.java
@@ -0,0 +1,11 @@
+package submit.ast;
+
+import submit.MIPSResult;
+import submit.RegisterAllocator;
+import submit.SymbolTable;
+
+public interface Node {
+ void toCminus(StringBuilder builder, final String prefix);
+
+ MIPSResult toMIPS(StringBuilder code, StringBuilder data, SymbolTable symbolTable, RegisterAllocator regAllocator);
+}
diff --git a/submit/ast/NumConstant.java b/submit/ast/NumConstant.java
new file mode 100644
index 0000000..4e343fd
--- /dev/null
+++ b/submit/ast/NumConstant.java
@@ -0,0 +1,23 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class NumConstant extends AbstractNode implements Expression {
+
+ private final int value;
+
+ public NumConstant(int value) {
+ this.value = value;
+ }
+
+ public void toCminus(StringBuilder builder, final String prefix) {
+ builder.append(Integer.toString(value));
+ }
+
+}
diff --git a/submit/ast/Param.java b/submit/ast/Param.java
new file mode 100644
index 0000000..478c6e2
--- /dev/null
+++ b/submit/ast/Param.java
@@ -0,0 +1,43 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class Param extends AbstractNode implements Node {
+
+ private final VarType type;
+ private final String id;
+ private final boolean array;
+
+ public Param(VarType type, String id, boolean array) {
+ this.type = type;
+ this.id = id;
+ this.array = array;
+ }
+
+ public VarType getType() {
+ return type;
+ }
+
+ public String getId() {
+ return id;
+ }
+
+ public boolean isArray() {
+ return array;
+ }
+
+ public void toCminus(StringBuilder builder, final String prefix) {
+ if (isArray()) {
+ builder.append(type).append(" ").append(id).append("[]");
+ } else {
+ builder.append(type).append(" ").append(id);
+ }
+ }
+
+}
diff --git a/submit/ast/ParenExpression.java b/submit/ast/ParenExpression.java
new file mode 100644
index 0000000..2eb0b8f
--- /dev/null
+++ b/submit/ast/ParenExpression.java
@@ -0,0 +1,26 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class ParenExpression extends AbstractNode implements Expression {
+
+ private final Expression expression;
+
+ public ParenExpression(Expression expression) {
+ this.expression = expression;
+ }
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ builder.append("(");
+ expression.toCminus(builder, prefix);
+ builder.append(")");
+ }
+
+}
diff --git a/submit/ast/Program.java b/submit/ast/Program.java
new file mode 100644
index 0000000..1478961
--- /dev/null
+++ b/submit/ast/Program.java
@@ -0,0 +1,36 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class Program extends AbstractNode implements Node {
+
+ private ArrayList<Declaration> declarations;
+
+ public Program(List<Declaration> declarations) {
+ this.declarations = new ArrayList<>(declarations);
+ }
+
+ @Override
+ public String toString() {
+ StringBuilder builder = new StringBuilder();
+ toCminus(builder, "");
+ return builder.toString();
+ }
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ for (Declaration declaration : declarations) {
+ declaration.toCminus(builder, "");
+ }
+ }
+
+}
diff --git a/submit/ast/Return.java b/submit/ast/Return.java
new file mode 100644
index 0000000..47a8c16
--- /dev/null
+++ b/submit/ast/Return.java
@@ -0,0 +1,31 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class Return extends AbstractNode implements Statement {
+
+ private final Expression expr;
+
+ public Return(Expression expr) {
+ this.expr = expr;
+ }
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ builder.append(prefix);
+ if (expr == null) {
+ builder.append("return;\n");
+ } else {
+ builder.append("return ");
+ expr.toCminus(builder, prefix);
+ builder.append(";\n");
+ }
+ }
+
+}
diff --git a/submit/ast/Statement.java b/submit/ast/Statement.java
new file mode 100644
index 0000000..2e0581e
--- /dev/null
+++ b/submit/ast/Statement.java
@@ -0,0 +1,16 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+import java.util.ArrayList;
+
+/**
+ *
+ * @author edwajohn
+ */
+public interface Statement extends Node {
+ public static CompoundStatement empty() { return new CompoundStatement(new ArrayList<>()); }
+
+}
diff --git a/submit/ast/StringConstant.java b/submit/ast/StringConstant.java
new file mode 100644
index 0000000..c3b966e
--- /dev/null
+++ b/submit/ast/StringConstant.java
@@ -0,0 +1,23 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class StringConstant extends AbstractNode implements Expression {
+
+ private final String value;
+
+ public StringConstant(String value) {
+ this.value = value;
+ }
+
+ public void toCminus(StringBuilder builder, final String prefix) {
+ builder.append("\"").append(value).append("\"");
+ }
+
+}
diff --git a/submit/ast/UnaryOperator.java b/submit/ast/UnaryOperator.java
new file mode 100644
index 0000000..1b5082a
--- /dev/null
+++ b/submit/ast/UnaryOperator.java
@@ -0,0 +1,27 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class UnaryOperator extends AbstractNode implements Expression {
+
+ private final UnaryOperatorType type;
+ private final Expression expression;
+
+ public UnaryOperator(String type, Expression expression) {
+ this.type = UnaryOperatorType.fromString(type);
+ this.expression = expression;
+ }
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ builder.append(type);
+ expression.toCminus(builder, prefix);
+ }
+
+}
diff --git a/submit/ast/UnaryOperatorType.java b/submit/ast/UnaryOperatorType.java
new file mode 100644
index 0000000..828ee5a
--- /dev/null
+++ b/submit/ast/UnaryOperatorType.java
@@ -0,0 +1,35 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public enum UnaryOperatorType {
+
+ NOT("!"), NEG("-"), DEREF("*"), QUESTION("?");
+
+ private final String value;
+
+ private UnaryOperatorType(String value) {
+ this.value = value;
+ }
+
+ public static UnaryOperatorType fromString(String s) {
+ for (UnaryOperatorType at : UnaryOperatorType.values()) {
+ if (at.value.equals(s)) {
+ return at;
+ }
+ }
+ throw new RuntimeException("Illegal string in UnaryOperatorType.fromString()");
+ }
+
+ @Override
+ public String toString() {
+ return value;
+ }
+
+}
diff --git a/submit/ast/VarDeclaration.java b/submit/ast/VarDeclaration.java
new file mode 100644
index 0000000..d2a5264
--- /dev/null
+++ b/submit/ast/VarDeclaration.java
@@ -0,0 +1,47 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class VarDeclaration extends AbstractNode implements Declaration {
+
+ private final VarType type;
+ private final List<String> ids;
+ private final List<Integer> arraySizes;
+ private final boolean isStatic;
+
+ public VarDeclaration(VarType type, List<String> ids, List<Integer> arraySizes, boolean isStatic) {
+ this.type = type;
+ this.ids = new ArrayList<>(ids);
+ this.arraySizes = arraySizes;
+ this.isStatic = isStatic;
+ }
+
+ public void toCminus(StringBuilder builder, final String prefix) {
+ builder.append(prefix);
+ if (isStatic) {
+ builder.append("static ");
+ }
+ builder.append(type).append(" ");
+ for (int i = 0; i < ids.size(); ++i) {
+ final String id = ids.get(i);
+ final int arraySize = arraySizes.get(i);
+ if (arraySize >= 0) {
+ builder.append(id).append("[").append(arraySize).append("]").append(", ");
+ } else {
+ builder.append(id).append(", ");
+ }
+ }
+ builder.delete(builder.length() - 2, builder.length());
+ builder.append(";\n");
+ }
+
+}
diff --git a/submit/ast/VarType.java b/submit/ast/VarType.java
new file mode 100644
index 0000000..ba28946
--- /dev/null
+++ b/submit/ast/VarType.java
@@ -0,0 +1,35 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public enum VarType {
+
+ INT("int"), BOOL("bool"), CHAR("char");
+
+ private final String value;
+
+ private VarType(String value) {
+ this.value = value;
+ }
+
+ public static VarType fromString(String s) {
+ for (VarType vt : VarType.values()) {
+ if (vt.value.equals(s)) {
+ return vt;
+ }
+ }
+ throw new RuntimeException("Illegal string in VarType.fromString()");
+ }
+
+ @Override
+ public String toString() {
+ return value;
+ }
+
+}
diff --git a/submit/ast/While.java b/submit/ast/While.java
new file mode 100644
index 0000000..a37195e
--- /dev/null
+++ b/submit/ast/While.java
@@ -0,0 +1,33 @@
+/*
+ * Code formatter project
+ * CS 4481
+ */
+package submit.ast;
+
+/**
+ *
+ * @author edwajohn
+ */
+public class While extends AbstractNode implements Statement {
+
+ private final Expression expression;
+ private final Statement statement;
+
+ public While(Expression expression, Statement statement) {
+ this.expression = expression;
+ this.statement = statement;
+ }
+
+ @Override
+ public void toCminus(StringBuilder builder, String prefix) {
+ builder.append(prefix).append("while (");
+ expression.toCminus(builder, prefix);
+ builder.append(")\n");
+ if (statement instanceof CompoundStatement) {
+ statement.toCminus(builder, prefix);
+ } else {
+ statement.toCminus(builder, prefix + " ");
+ }
+
+ }
+}