mirror of
https://github.com/JonathanFleischmann/CompilerULTIMATE.git
synced 2024-12-27 00:18:04 +00:00
Refactored TypedAST and added a new exception type
This commit is contained in:
parent
976f9c2ba6
commit
92c08ac3de
@ -0,0 +1,7 @@
|
||||
package de.maishai.typedast.ExceptionHandler;
|
||||
|
||||
public class InvalidWhileConditionException extends RuntimeException{
|
||||
public InvalidWhileConditionException() {
|
||||
super("Invalid while condition");
|
||||
}
|
||||
}
|
@ -19,11 +19,11 @@ public final class TypedDeclaration implements TypedNode {
|
||||
private Type type;
|
||||
|
||||
public TypedDeclaration(TypedProgram typedProgram, Declaration declaration) {
|
||||
convertToTypedDeclaration(typedProgram, declaration);
|
||||
convertToTypedDeclaration(declaration);
|
||||
typeCheck(typedProgram);
|
||||
}
|
||||
|
||||
private void convertToTypedDeclaration(TypedProgram typedProgram, Declaration declaration) {
|
||||
private void convertToTypedDeclaration(Declaration declaration) {
|
||||
name = declaration.name();
|
||||
type = declaration.type();
|
||||
}
|
||||
|
@ -35,15 +35,17 @@ public class TypedIfElse implements TypedStatement {
|
||||
|
||||
@Override
|
||||
public Type typeCheck(TypedProgram typedProgram) {
|
||||
Type ifType = ifTypedBlock.typeCheck(typedProgram);
|
||||
Type elseType = elseTypedBlock.typeCheck(typedProgram);
|
||||
|
||||
if (ifTypedBlock.typeCheck(typedProgram) == elseTypedBlock.typeCheck(typedProgram)) {
|
||||
type = ifTypedBlock.typeCheck(typedProgram);
|
||||
if (ifType == elseType) {
|
||||
type = ifType;
|
||||
}
|
||||
if (elseTypedBlock.typeCheck(typedProgram) == Type.VOID) {
|
||||
type = ifTypedBlock.typeCheck(typedProgram);
|
||||
if (elseType == Type.VOID) {
|
||||
type = ifType;
|
||||
}
|
||||
if (ifTypedBlock.typeCheck(typedProgram) == Type.VOID) {
|
||||
type = elseTypedBlock.typeCheck(typedProgram);
|
||||
if (ifType == Type.VOID) {
|
||||
type = elseType;
|
||||
}
|
||||
|
||||
return type;
|
||||
|
@ -1,6 +1,7 @@
|
||||
package de.maishai.typedast.typedclass;
|
||||
|
||||
import de.maishai.ast.records.While;
|
||||
import de.maishai.typedast.ExceptionHandler.InvalidWhileConditionException;
|
||||
import de.maishai.typedast.MethodContext;
|
||||
import de.maishai.typedast.Type;
|
||||
import de.maishai.typedast.TypedExpression;
|
||||
@ -28,11 +29,10 @@ public class TypedWhile implements TypedStatement {
|
||||
cond = convertExpression(typedProgram, unTypedWhile.cond());
|
||||
typedBlock = new TypedBlock(typedProgram, unTypedWhile.block());
|
||||
}
|
||||
|
||||
@Override
|
||||
public Type typeCheck(TypedProgram typedProgram) {
|
||||
if (cond.typeCheck(typedProgram) != Type.BOOL) {
|
||||
throw new RuntimeException("While condition must be a boolean");
|
||||
throw new InvalidWhileConditionException();
|
||||
}
|
||||
type = typedBlock.typeCheck(typedProgram);
|
||||
return type;
|
||||
|
Loading…
Reference in New Issue
Block a user