prompto.statement.RaiseStatement Maven / Gradle / Ivy
The newest version!
package prompto.statement;
import java.util.Objects;
import prompto.compiler.ClassConstant;
import prompto.compiler.Flags;
import prompto.compiler.MethodInfo;
import prompto.compiler.Opcode;
import prompto.compiler.ResultInfo;
import prompto.compiler.ResultInfo.Flag;
import prompto.error.PromptoError;
import prompto.error.SyntaxError;
import prompto.error.UserError;
import prompto.expression.IExpression;
import prompto.grammar.Identifier;
import prompto.runtime.Context;
import prompto.transpiler.Transpiler;
import prompto.type.CategoryType;
import prompto.type.IType;
import prompto.type.VoidType;
import prompto.utils.CodeWriter;
import prompto.value.IValue;
public class RaiseStatement extends SimpleStatement {
static final IType ERROR_TYPE = new CategoryType(new Identifier("Error"));
IExpression expression;
public RaiseStatement(IExpression expression) {
this.expression = expression;
}
public IExpression getExpression() {
return expression;
}
@Override
public void toDialect(CodeWriter writer) {
switch(writer.getDialect()) {
case E:
case M:
writer.append("raise ");
break;
case O:
writer.append("throw ");
break;
}
expression.toDialect(writer);
}
@Override
public String toString() {
return "raise " + expression.toString();
}
@Override
public int hashCode() {
return Objects.hash(getExpression());
}
@Override
public boolean equals(Object obj) {
if(obj==this)
return true;
if(obj==null)
return false;
if(!(obj instanceof RaiseStatement))
return false;
RaiseStatement other = (RaiseStatement)obj;
return this.getExpression().equals(other.getExpression());
}
@Override
public IType check(Context context) {
IType type = expression.check(context);
if(!ERROR_TYPE.isAssignableFrom(context, type))
throw new SyntaxError(type.getTypeName() + " does not extend Error");
return VoidType.instance();
}
@Override
public IValue interpret(Context context) throws PromptoError {
throw new UserError(expression);
}
@Override
public ResultInfo compile(Context context, MethodInfo method, Flags flags) {
ResultInfo info = expression.compile(context, method, flags);
method.addInstruction(Opcode.ATHROW, new ClassConstant(info.getType()));
return new ResultInfo(void.class, Flag.THROW);
}
@Override
public void declare(Transpiler transpiler) {
this.expression.declare(transpiler);
}
@Override
public boolean transpile(Transpiler transpiler) {
transpiler.append("throw ");
this.expression.transpile(transpiler);
return false;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy