Fehler in Overloading im Bezug auf FunNInterface behoben
This commit is contained in:
parent
ddb9ef6d7d
commit
f16a9345eb
@ -1,13 +1,18 @@
|
||||
package typinferenz;
|
||||
|
||||
import java.util.Vector;
|
||||
|
||||
import mycompiler.mytype.*;
|
||||
import mycompiler.myclass.Class;
|
||||
import mycompiler.mytype.TypePlaceholder;
|
||||
|
||||
|
||||
public class FunNInterface extends Class{
|
||||
//TODO: Diese Klasse sollte eigentlich von Interface erben
|
||||
|
||||
public FunNInterface(int parameterCount) {
|
||||
super("Fun"+parameterCount);
|
||||
public FunNInterface(Vector<Type> parameter) {
|
||||
super("Fun"+parameter.size());
|
||||
this.set_ParaList(parameter);
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -4,6 +4,7 @@ import java.util.Vector;
|
||||
|
||||
import typinferenz.assumptions.MethodAssumption;
|
||||
import typinferenz.assumptions.TypeAssumptions;
|
||||
import mycompiler.mystatement.Expr;
|
||||
import mycompiler.mystatement.MethodCall;
|
||||
import mycompiler.mytype.RefType;
|
||||
import mycompiler.mytype.Type;
|
||||
@ -55,7 +56,11 @@ public class Overloading{
|
||||
*/
|
||||
public OderConstraint generateConsstraints(){
|
||||
OderConstraint ret = new OderConstraint();
|
||||
for(MethodAssumption methodAssumption : assumptions.getMethodAssumptions(methodCall.getName(), methodCall.getArgumentList().size())){
|
||||
Vector<Type> parameterList = new Vector<Type>();
|
||||
for(Expr argument : methodCall.getArgumentList().expr){
|
||||
parameterList.add(argument.getType());
|
||||
}
|
||||
for(MethodAssumption methodAssumption : assumptions.getMethodAssumptions(methodCall.getName(), parameterList)){
|
||||
if(!(this.type instanceof TypePlaceholder) && !this.type.equals(methodAssumption.getAssumedType()))break;
|
||||
UndConstraint methodConstraint = new UndConstraint();
|
||||
//Ein Constraint für den ReturnType der Methode...
|
||||
|
@ -134,10 +134,11 @@ public class TypeAssumptions {
|
||||
/**
|
||||
* Sucht nach Assumptions zu einer Methode mit dem Namen methodName und parameterCount Parametern.
|
||||
* @param methodName
|
||||
* @param parameterCount Anzahl der Parameter der gesuchten Methoden-Assumption
|
||||
* @return
|
||||
* @param parameter Die Parameter, welche die Methode verarbeiten soll
|
||||
* @return Alle Methoden in den Assumptions, welche eine Parameterliste der Länge der übergebenen Parameterliste (parameter) verarbeiten können.
|
||||
*/
|
||||
public Vector<MethodAssumption> getMethodAssumptions(String methodName, int parameterCount){
|
||||
public Vector<MethodAssumption> getMethodAssumptions(String methodName, Vector<Type> parameter){
|
||||
int parameterCount = parameter.size();
|
||||
Vector<MethodAssumption> ret = new Vector<MethodAssumption>();
|
||||
for(MethodAssumption ass : this.methodAssumptions){
|
||||
if(ass.getMethodName().equals(methodName) && ass.getParaCount() == parameterCount){
|
||||
@ -148,7 +149,7 @@ public class TypeAssumptions {
|
||||
//Falls es sich um die apply-Methode eines FunN-Interface handelt:
|
||||
if(methodName.equals("apply")){ //Ein Workaround für den Typinferenzalgorithmus TODO: Das hier rausnehmen.
|
||||
//CMethodTypeAssumption funNAssumption = new FunN(parameterCount).toCMethodTypeAssumption();
|
||||
MethodAssumption funNAssumption = new MethodAssumption(new FunNMethod(parameterCount), new FunNInterface(parameterCount));
|
||||
MethodAssumption funNAssumption = new MethodAssumption(new FunNMethod(parameterCount), new FunNInterface(parameter));
|
||||
ret.add(funNAssumption);
|
||||
}
|
||||
if(ret.size()==0)throw new TypinferenzException("Eine Methode "+methodName+" ist in den Assumptions nicht vorhanden");
|
||||
|
File diff suppressed because one or more lines are too long
Loading…
x
Reference in New Issue
Block a user