prompto.declaration.AbstractMethodDeclaration Maven / Gradle / Ivy
The newest version!
package prompto.declaration;
import java.lang.reflect.Modifier;
import java.lang.reflect.Type;
import prompto.compiler.ClassFile;
import prompto.compiler.InterfaceType;
import prompto.error.SyntaxError;
import prompto.grammar.Identifier;
import prompto.param.ParameterList;
import prompto.runtime.Context;
import prompto.transpiler.Transpiler;
import prompto.type.IType;
import prompto.type.VoidType;
import prompto.utils.CodeWriter;
import prompto.value.IValue;
public class AbstractMethodDeclaration extends BaseMethodDeclaration implements IMethodDeclaration {
public AbstractMethodDeclaration(Identifier name, ParameterList arguments, IType returnType) {
super(name, arguments, returnType!=null ? returnType : VoidType.instance());
}
@Override
public boolean isAbstract() {
return true;
}
@Override
public boolean isTemplate() {
return false;
}
@Override
public IType check(Context context, boolean isStart) {
if(parameters!=null)
parameters.check(context);
if(isStart) {
Context local = context.newLocalContext();
registerParameters(local); // will check them
}
return returnType;
}
@Override
public IType checkChild(Context context) {
if(parameters!=null)
parameters.check(context);
return returnType;
}
@Override
public IValue interpret(Context context) {
throw new SyntaxError("Should never get there !");
}
@Override
public void compile(Context context, boolean isStart, ClassFile classFile) {
if(memberOf==null)
throw new SyntaxError("Should never get there !");
else
compilePrototype(context, isStart, classFile);
}
@Override
public String compileTemplate(Context context, boolean isStart, ClassFile classFile) {
throw new SyntaxError("Should never get there !");
}
public ClassFile compileInterface(Context context, Type type) {
ClassFile classFile = new ClassFile(type);
classFile.addModifier(Modifier.ABSTRACT | Modifier.INTERFACE);
InterfaceType intf = new InterfaceType(parameters, returnType);
classFile.addAttribute(intf.computeSignature(context, Object.class));
classFile.addInterface(intf.getInterfaceType());
return classFile;
}
@Override
public void declarationToDialect(CodeWriter writer) {
switch(writer.getDialect()) {
case E:
toEDialect(writer);
break;
case O:
toODialect(writer);
break;
case M:
toMDialect(writer);
break;
}
}
private void toMDialect(CodeWriter writer) {
writer.append("abstract def ");
writer.append(getName());
writer.append(" (");
parameters.toDialect(writer);
writer.append(")");
if(returnType!=null && returnType!=VoidType.instance()) {
writer.append("->");
returnType.toDialect(writer);
}
}
protected void toEDialect(CodeWriter writer) {
writer.append("define ");
writer.append(getName());
writer.append(" as abstract method ");
parameters.toDialect(writer);
if(returnType!=null && returnType!=VoidType.instance()) {
writer.append("returning ");
returnType.toDialect(writer);
}
}
protected void toODialect(CodeWriter writer) {
writer.append("abstract ");
if(returnType!=null && returnType!=VoidType.instance()) {
returnType.toDialect(writer);
writer.append(" ");
}
writer.append("method ");
writer.append(getName());
writer.append(" (");
parameters.toDialect(writer);
writer.append(");");
}
@Override
public void declare(Transpiler transpiler) {
this.declareParameters(transpiler);
}
@Override
public boolean transpile(Transpiler transpiler) {
// nothing to do
return false;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy