2024-04-25 11:27:38 +00:00
|
|
|
package abstractSyntaxTree.Expression;
|
|
|
|
|
2024-05-02 12:31:37 +00:00
|
|
|
import TypeCheck.AbstractType;
|
|
|
|
import TypeCheck.TypeCheckHelper;
|
|
|
|
import TypeCheck.TypeCheckResult;
|
|
|
|
import abstractSyntaxTree.Datatype.IDatatype;
|
2024-05-07 11:50:51 +00:00
|
|
|
import org.objectweb.asm.MethodVisitor;
|
|
|
|
import org.objectweb.asm.Opcodes;
|
2024-05-02 12:31:37 +00:00
|
|
|
|
|
|
|
import java.util.Objects;
|
|
|
|
|
|
|
|
public class UnaryExpression extends AbstractType implements IExpression{
|
|
|
|
public String operator;
|
|
|
|
public IDatatype operand;
|
|
|
|
@Override
|
|
|
|
public TypeCheckResult typeCheck() throws Exception {
|
|
|
|
TypeCheckResult result = new TypeCheckResult();
|
|
|
|
|
|
|
|
TypeCheckResult operandTypeCheckResult = operand.typeCheck();
|
|
|
|
String operandType = operandTypeCheckResult.type;
|
|
|
|
|
|
|
|
switch (operator) {
|
|
|
|
|
|
|
|
case "!" :{
|
|
|
|
if (Objects.equals(operandType, "bool")){
|
|
|
|
result.type = "bool";
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
case "-":
|
|
|
|
case "+":
|
|
|
|
if (Objects.equals(operandType, "int")){
|
|
|
|
result.type = "int";
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
setTypeCheckResult(result);
|
|
|
|
return result;
|
|
|
|
}
|
2024-05-07 11:50:51 +00:00
|
|
|
|
|
|
|
@Override
|
2024-05-08 10:56:40 +00:00
|
|
|
public void codeGen(MethodVisitor mv) throws Exception {
|
2024-05-07 11:50:51 +00:00
|
|
|
|
2024-05-08 10:56:40 +00:00
|
|
|
operand.codeGen(mv);
|
2024-05-07 11:50:51 +00:00
|
|
|
|
|
|
|
switch (operator) {
|
|
|
|
case "!":
|
|
|
|
//XOR with 1 to get the negation
|
|
|
|
mv.visitInsn(Opcodes.ICONST_1);
|
|
|
|
mv.visitInsn(Opcodes.IXOR);
|
|
|
|
break;
|
|
|
|
case "-":
|
|
|
|
mv.visitInsn(Opcodes.INEG);
|
|
|
|
break;
|
|
|
|
case "+":
|
|
|
|
break;
|
|
|
|
|
|
|
|
default: throw new Exception("Unknown operator :" + operator);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2024-04-25 11:27:38 +00:00
|
|
|
}
|