forked from JavaTX/JavaCompilerCore
refactored Types //
This commit is contained in:
parent
6c2d71d005
commit
20d1106e07
@ -32,7 +32,7 @@ import de.dhbwstuttgart.typeinference.unify.model.FiniteClosure;
|
|||||||
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.PairOperator;
|
import de.dhbwstuttgart.typeinference.unify.model.PairOperator;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.PlaceholderType;
|
import de.dhbwstuttgart.typeinference.unify.model.PlaceholderType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.SimpleType;
|
import de.dhbwstuttgart.typeinference.unify.model.ReferenceType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.SuperType;
|
import de.dhbwstuttgart.typeinference.unify.model.SuperType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.TypeParams;
|
import de.dhbwstuttgart.typeinference.unify.model.TypeParams;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
||||||
@ -82,9 +82,9 @@ public class UnifyTypeFactory {
|
|||||||
for(Type pT : t.getParaList()){
|
for(Type pT : t.getParaList()){
|
||||||
params.add(UnifyTypeFactory.convert(pT));
|
params.add(UnifyTypeFactory.convert(pT));
|
||||||
}
|
}
|
||||||
ret = new SimpleType(t.get_Name(),new TypeParams(params));
|
ret = new ReferenceType(t.get_Name(),new TypeParams(params));
|
||||||
}else{
|
}else{
|
||||||
ret = new SimpleType(t.get_Name());
|
ret = new ReferenceType(t.get_Name());
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -102,7 +102,7 @@ public class UnifyTypeFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static UnifyType convert(GenericTypeVar t){
|
public static UnifyType convert(GenericTypeVar t){
|
||||||
return new SimpleType(t.get_Name());
|
return new ReferenceType(t.get_Name());
|
||||||
}
|
}
|
||||||
|
|
||||||
public static UnifyConstraintsSet convert(ConstraintsSet constraints) {
|
public static UnifyConstraintsSet convert(ConstraintsSet constraints) {
|
||||||
@ -146,7 +146,7 @@ public class UnifyTypeFactory {
|
|||||||
return new Pair(tl, tr, mp.getPairOp());
|
return new Pair(tl, tr, mp.getPairOp());
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Type convert(SimpleType t) {
|
public static Type convert(ReferenceType t) {
|
||||||
return new RefType(t.getName(),null,0);
|
return new RefType(t.getName(),null,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -165,7 +165,7 @@ public class UnifyTypeFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static Type convert(UnifyType t) {
|
public static Type convert(UnifyType t) {
|
||||||
if(t instanceof SimpleType)return convert((SimpleType) t);
|
if(t instanceof ReferenceType)return convert((ReferenceType) t);
|
||||||
if(t instanceof SuperType)return convert((SuperType) t);
|
if(t instanceof SuperType)return convert((SuperType) t);
|
||||||
if(t instanceof ExtendsType)return convert((ExtendsType) t);
|
if(t instanceof ExtendsType)return convert((ExtendsType) t);
|
||||||
if(t instanceof PlaceholderType)return convert((PlaceholderType) t);
|
if(t instanceof PlaceholderType)return convert((PlaceholderType) t);
|
||||||
|
@ -4,7 +4,6 @@ import java.util.ArrayList;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.Queue;
|
import java.util.Queue;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
@ -18,9 +17,10 @@ import de.dhbwstuttgart.typeinference.unify.model.ExtendsType;
|
|||||||
import de.dhbwstuttgart.typeinference.unify.model.FunNType;
|
import de.dhbwstuttgart.typeinference.unify.model.FunNType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.PlaceholderType;
|
import de.dhbwstuttgart.typeinference.unify.model.PlaceholderType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.SimpleType;
|
import de.dhbwstuttgart.typeinference.unify.model.ReferenceType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.SuperType;
|
import de.dhbwstuttgart.typeinference.unify.model.SuperType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
||||||
|
import de.dhbwstuttgart.typeinference.unify.model.WildcardType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.TypeParams;
|
import de.dhbwstuttgart.typeinference.unify.model.TypeParams;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.Unifier;
|
import de.dhbwstuttgart.typeinference.unify.model.Unifier;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.PairOperator;
|
import de.dhbwstuttgart.typeinference.unify.model.PairOperator;
|
||||||
@ -43,7 +43,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType lhsType = pair.getLhsType();
|
UnifyType lhsType = pair.getLhsType();
|
||||||
if(!(lhsType instanceof SimpleType) && !(lhsType instanceof PlaceholderType))
|
if(!(lhsType instanceof ReferenceType) && !(lhsType instanceof PlaceholderType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
return Optional.of(new MPair(lhsType, ((SuperType) rhsType).getSuperedType(), PairOperator.SMALLERDOT));
|
return Optional.of(new MPair(lhsType, ((SuperType) rhsType).getSuperedType(), PairOperator.SMALLERDOT));
|
||||||
@ -59,7 +59,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType rhsType = pair.getRhsType();
|
UnifyType rhsType = pair.getRhsType();
|
||||||
if(!(rhsType instanceof SimpleType) && !(rhsType instanceof PlaceholderType))
|
if(!(rhsType instanceof ReferenceType) && !(rhsType instanceof PlaceholderType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
return Optional.of(new MPair(((ExtendsType) lhsType).getExtendedType(), rhsType, PairOperator.SMALLERDOT));
|
return Optional.of(new MPair(((ExtendsType) lhsType).getExtendedType(), rhsType, PairOperator.SMALLERDOT));
|
||||||
@ -89,7 +89,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
UnifyType x = pair.getLhsType();
|
UnifyType x = pair.getLhsType();
|
||||||
UnifyType sTypeX;
|
UnifyType sTypeX;
|
||||||
|
|
||||||
if(x instanceof SimpleType)
|
if(x instanceof ReferenceType)
|
||||||
sTypeX = x;
|
sTypeX = x;
|
||||||
else if(x instanceof ExtendsType)
|
else if(x instanceof ExtendsType)
|
||||||
sTypeX = ((ExtendsType) x).getExtendedType();
|
sTypeX = ((ExtendsType) x).getExtendedType();
|
||||||
@ -141,7 +141,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
UnifyType x = pair.getLhsType();
|
UnifyType x = pair.getLhsType();
|
||||||
UnifyType sTypeX;
|
UnifyType sTypeX;
|
||||||
|
|
||||||
if(x instanceof SimpleType)
|
if(x instanceof ReferenceType)
|
||||||
sTypeX = x;
|
sTypeX = x;
|
||||||
else if(x instanceof SuperType)
|
else if(x instanceof SuperType)
|
||||||
sTypeX = ((SuperType) x).getSuperedType();
|
sTypeX = ((SuperType) x).getSuperedType();
|
||||||
@ -221,15 +221,15 @@ public class RuleSet implements IRuleSet{
|
|||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType c = pair.getLhsType();
|
UnifyType c = pair.getLhsType();
|
||||||
if(!(c instanceof SimpleType))
|
if(!(c instanceof ReferenceType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType d = pair.getRhsType();
|
UnifyType d = pair.getRhsType();
|
||||||
if(!(d instanceof SimpleType))
|
if(!(d instanceof ReferenceType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
SimpleType lhsSType = (SimpleType) c;
|
ReferenceType lhsSType = (ReferenceType) c;
|
||||||
SimpleType rhsSType = (SimpleType) d;
|
ReferenceType rhsSType = (ReferenceType) d;
|
||||||
|
|
||||||
if(lhsSType.getTypeParams().empty() || lhsSType.getTypeParams().size() != rhsSType.getTypeParams().size())
|
if(lhsSType.getTypeParams().empty() || lhsSType.getTypeParams().size() != rhsSType.getTypeParams().size())
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
@ -265,14 +265,17 @@ public class RuleSet implements IRuleSet{
|
|||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType lhsType = pair.getLhsType();
|
UnifyType lhsType = pair.getLhsType();
|
||||||
SimpleType lhsSType;
|
ReferenceType lhsSType;
|
||||||
|
|
||||||
if(lhsType instanceof SimpleType)
|
if(lhsType instanceof ReferenceType)
|
||||||
lhsSType = (SimpleType) lhsType;
|
lhsSType = (ReferenceType) lhsType;
|
||||||
else if(lhsType instanceof ExtendsType)
|
else if(lhsType instanceof WildcardType) {
|
||||||
lhsSType = (SimpleType) ((ExtendsType) lhsType).getExtendedType();
|
UnifyType lhsSTypeRaw = ((WildcardType) lhsType).getWildcardedType();
|
||||||
else if(lhsType instanceof SuperType)
|
if(lhsSTypeRaw instanceof ReferenceType)
|
||||||
lhsSType = (SimpleType) ((SuperType) lhsType).getSuperedType();
|
lhsSType = (ReferenceType) lhsSTypeRaw;
|
||||||
|
else
|
||||||
|
return Optional.empty();
|
||||||
|
}
|
||||||
else
|
else
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
@ -280,14 +283,17 @@ public class RuleSet implements IRuleSet{
|
|||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType rhsType = pair.getLhsType();
|
UnifyType rhsType = pair.getLhsType();
|
||||||
SimpleType rhsSType;
|
ReferenceType rhsSType;
|
||||||
|
|
||||||
if(rhsType instanceof SimpleType)
|
if(rhsType instanceof ReferenceType)
|
||||||
rhsSType = (SimpleType) rhsType;
|
rhsSType = (ReferenceType) rhsType;
|
||||||
else if(rhsType instanceof ExtendsType)
|
else if(rhsType instanceof WildcardType) {
|
||||||
rhsSType = (SimpleType) ((ExtendsType) rhsType).getExtendedType();
|
UnifyType rhsSTypeRaw = ((WildcardType) rhsType).getWildcardedType();
|
||||||
else if(rhsType instanceof SuperType)
|
if(rhsSTypeRaw instanceof ReferenceType)
|
||||||
rhsSType = (SimpleType) ((SuperType) rhsType).getSuperedType();
|
rhsSType = (ReferenceType) rhsSTypeRaw;
|
||||||
|
else
|
||||||
|
return Optional.empty();
|
||||||
|
}
|
||||||
else
|
else
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
@ -314,11 +320,11 @@ public class RuleSet implements IRuleSet{
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
UnifyType lhsType = pair.getLhsType();
|
UnifyType lhsType = pair.getLhsType();
|
||||||
if(!(lhsType instanceof SimpleType) && !(lhsType instanceof PlaceholderType))
|
if(!(lhsType instanceof ReferenceType) && !(lhsType instanceof PlaceholderType))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
UnifyType rhsType = pair.getRhsType();
|
UnifyType rhsType = pair.getRhsType();
|
||||||
if(!(rhsType instanceof SimpleType) && !(rhsType instanceof PlaceholderType))
|
if(!(rhsType instanceof ReferenceType) && !(rhsType instanceof PlaceholderType))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return finiteClosure.greater(lhsType).contains(rhsType);
|
return finiteClosure.greater(lhsType).contains(rhsType);
|
||||||
@ -363,11 +369,11 @@ public class RuleSet implements IRuleSet{
|
|||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType typeD = pair.getLhsType();
|
UnifyType typeD = pair.getLhsType();
|
||||||
if(!(typeD instanceof SimpleType))
|
if(!(typeD instanceof ReferenceType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType typeDs = pair.getRhsType();
|
UnifyType typeDs = pair.getRhsType();
|
||||||
if(!(typeDs instanceof SimpleType))
|
if(!(typeDs instanceof ReferenceType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
if(typeD.getTypeParams().size() == 0 || typeDs.getTypeParams().size() == 0)
|
if(typeD.getTypeParams().size() == 0 || typeDs.getTypeParams().size() == 0)
|
||||||
@ -409,7 +415,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType typeD = pair.getLhsType();
|
UnifyType typeD = pair.getLhsType();
|
||||||
if(!(typeD instanceof SimpleType) && !(typeD instanceof ExtendsType))
|
if(!(typeD instanceof ReferenceType) && !(typeD instanceof ExtendsType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType typeExtDs = pair.getRhsType();
|
UnifyType typeExtDs = pair.getRhsType();
|
||||||
@ -420,7 +426,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType typeDgen;
|
UnifyType typeDgen;
|
||||||
if(typeD instanceof SimpleType)
|
if(typeD instanceof ReferenceType)
|
||||||
typeDgen = finiteClosure.getLeftHandedType(typeD).orElse(null);
|
typeDgen = finiteClosure.getLeftHandedType(typeD).orElse(null);
|
||||||
else {
|
else {
|
||||||
Optional<UnifyType> opt = finiteClosure.getLeftHandedType(((ExtendsType) typeD).getExtendedType());
|
Optional<UnifyType> opt = finiteClosure.getLeftHandedType(((ExtendsType) typeD).getExtendedType());
|
||||||
@ -455,7 +461,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType typeDs = pair.getLhsType();
|
UnifyType typeDs = pair.getLhsType();
|
||||||
if(!(typeDs instanceof SimpleType) && !(typeDs instanceof SuperType))
|
if(!(typeDs instanceof ReferenceType) && !(typeDs instanceof SuperType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType typeSupD = pair.getRhsType();
|
UnifyType typeSupD = pair.getRhsType();
|
||||||
@ -484,7 +490,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
|
|
||||||
// New RHS
|
// New RHS
|
||||||
UnifyType newRhs = null;
|
UnifyType newRhs = null;
|
||||||
if(typeDs instanceof SimpleType)
|
if(typeDs instanceof ReferenceType)
|
||||||
newRhs = new ExtendsType(typeDs);
|
newRhs = new ExtendsType(typeDs);
|
||||||
else
|
else
|
||||||
newRhs = new ExtendsType(((SuperType) typeDs).getSuperedType());
|
newRhs = new ExtendsType(((SuperType) typeDs).getSuperedType());
|
||||||
@ -600,7 +606,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
|
|
||||||
UnifyType lhsType = pair.getLhsType();
|
UnifyType lhsType = pair.getLhsType();
|
||||||
UnifyType rhsType = pair.getRhsType();
|
UnifyType rhsType = pair.getRhsType();
|
||||||
if(!(lhsType instanceof SimpleType) || !(rhsType instanceof ExtendsType))
|
if(!(lhsType instanceof ReferenceType) || !(rhsType instanceof ExtendsType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
return Optional.of(new MPair(lhsType, ((ExtendsType) rhsType).getExtendedType(), PairOperator.SMALLERDOT));
|
return Optional.of(new MPair(lhsType, ((ExtendsType) rhsType).getExtendedType(), PairOperator.SMALLERDOT));
|
||||||
@ -626,7 +632,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
|
|
||||||
UnifyType lhsType = pair.getLhsType();
|
UnifyType lhsType = pair.getLhsType();
|
||||||
UnifyType rhsType = pair.getRhsType();
|
UnifyType rhsType = pair.getRhsType();
|
||||||
if(!(lhsType instanceof SimpleType) || !(rhsType instanceof SuperType))
|
if(!(lhsType instanceof ReferenceType) || !(rhsType instanceof SuperType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
return Optional.of(new MPair(((SuperType) rhsType).getSuperedType(), lhsType, PairOperator.SMALLERDOTWC));
|
return Optional.of(new MPair(((SuperType) rhsType).getSuperedType(), lhsType, PairOperator.SMALLERDOTWC));
|
||||||
@ -664,16 +670,13 @@ public class RuleSet implements IRuleSet{
|
|||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType rhsType = pair.getRhsType();
|
UnifyType rhsType = pair.getRhsType();
|
||||||
if(!(rhsType instanceof SimpleType))
|
if(!(rhsType instanceof ReferenceType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
UnifyType lhsType = pair.getLhsType();
|
UnifyType lhsType = pair.getLhsType();
|
||||||
|
|
||||||
if(lhsType instanceof SuperType)
|
if(lhsType instanceof WildcardType)
|
||||||
return Optional.of(new MPair(((SuperType) lhsType).getSuperedType(), rhsType, PairOperator.EQUALSDOT));
|
return Optional.of(new MPair(((WildcardType) lhsType).getWildcardedType(), rhsType, PairOperator.EQUALSDOT));
|
||||||
|
|
||||||
if(lhsType instanceof ExtendsType)
|
|
||||||
return Optional.of(new MPair(((ExtendsType) lhsType).getExtendedType(), rhsType, PairOperator.EQUALSDOT));
|
|
||||||
|
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
}
|
}
|
||||||
|
@ -73,11 +73,18 @@ public class Unify {
|
|||||||
Set<Set<MPair>> wrap = new HashSet<>();
|
Set<Set<MPair>> wrap = new HashSet<>();
|
||||||
wrap.add(bufferSet);
|
wrap.add(bufferSet);
|
||||||
topLevelSets.add(wrap);
|
topLevelSets.add(wrap);
|
||||||
|
eq2s.removeAll(bufferSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sets that originate from pair pattern matching
|
// Sets that originate from pair pattern matching
|
||||||
// Sets of the "second level"
|
// Sets of the "second level"
|
||||||
Set<Set<Set<Set<MPair>>>> secondLevelSets = calculatePairSets(eq2s, fc);
|
Set<MPair> undefinedPairs = new HashSet<>();
|
||||||
|
Set<Set<Set<Set<MPair>>>> secondLevelSets = calculatePairSets(eq2s, fc, undefinedPairs);
|
||||||
|
|
||||||
|
// If pairs occured that did not match one of the cartesian product cases,
|
||||||
|
// those pairs are contradictory and the unification is impossible.
|
||||||
|
if(!undefinedPairs.isEmpty())
|
||||||
|
return new HashSet<>();
|
||||||
|
|
||||||
/* Up to here, no cartesian products are calculated.
|
/* Up to here, no cartesian products are calculated.
|
||||||
* filters for pairs and sets can be applied here */
|
* filters for pairs and sets can be applied here */
|
||||||
@ -104,9 +111,6 @@ public class Unify {
|
|||||||
* Step 5: Substitution
|
* Step 5: Substitution
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
|
||||||
* TODO hier das ergebnis schonh flach machen? (wird im unify old (glaub ich) so gemacht)
|
|
||||||
*/
|
|
||||||
Set<Set<MPair>> eqPrimeSetFlat = new HashSet<>();
|
Set<Set<MPair>> eqPrimeSetFlat = new HashSet<>();
|
||||||
for(Set<Set<MPair>> setToFlatten : eqPrimeSet) {
|
for(Set<Set<MPair>> setToFlatten : eqPrimeSet) {
|
||||||
Set<MPair> buffer = new HashSet<>();
|
Set<MPair> buffer = new HashSet<>();
|
||||||
@ -121,10 +125,16 @@ public class Unify {
|
|||||||
for(Set<MPair> eqPrime : eqPrimeSetFlat) {
|
for(Set<MPair> eqPrime : eqPrimeSetFlat) {
|
||||||
Optional<Set<MPair>> eqPrimePrime = rules.subst(eqPrime);
|
Optional<Set<MPair>> eqPrimePrime = rules.subst(eqPrime);
|
||||||
|
|
||||||
if(eqPrimePrime.isPresent())
|
if(eqPrime.equals(eq))
|
||||||
|
eqPrimePrimeSet.add(eqPrime);
|
||||||
|
else if(eqPrimePrime.isPresent())
|
||||||
|
eqPrimePrimeSet.addAll(this.unify(eqPrimePrime.get(), fc));
|
||||||
|
else
|
||||||
|
eqPrimePrimeSet.addAll(this.unify(eqPrime, fc));
|
||||||
|
/*if(eqPrimePrime.isPresent())
|
||||||
changed.add(eqPrimePrime.get());
|
changed.add(eqPrimePrime.get());
|
||||||
else
|
else
|
||||||
eqPrimePrimeSet.add(eqPrime);
|
eqPrimePrimeSet.add(eqPrime);*/
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -255,7 +265,7 @@ public class Unify {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
protected Set<Set<Set<Set<MPair>>>> calculatePairSets(Set<MPair> eq2s, IFiniteClosure fc) {
|
protected Set<Set<Set<Set<MPair>>>> calculatePairSets(Set<MPair> eq2s, IFiniteClosure fc, Set<MPair> undefined) {
|
||||||
List<Set<Set<Set<MPair>>>> result = new ArrayList<>();
|
List<Set<Set<Set<MPair>>>> result = new ArrayList<>();
|
||||||
|
|
||||||
// Init all 8 cases
|
// Init all 8 cases
|
||||||
@ -299,6 +309,12 @@ public class Unify {
|
|||||||
// Case 8: (Theta <.? a)
|
// Case 8: (Theta <.? a)
|
||||||
else if(pairOp == PairOperator.SMALLERDOTWC && rhsType instanceof PlaceholderType)
|
else if(pairOp == PairOperator.SMALLERDOTWC && rhsType instanceof PlaceholderType)
|
||||||
result.get(7).add(unifyCase8(lhsType, (PlaceholderType) rhsType, fc));
|
result.get(7).add(unifyCase8(lhsType, (PlaceholderType) rhsType, fc));
|
||||||
|
// Case unknown: If a pair fits no other case, then the type unification has failed.
|
||||||
|
// Through application of the rules, every pair should have one of the above forms.
|
||||||
|
// Pairs that do not have one of the aboves form are contradictory.
|
||||||
|
else
|
||||||
|
undefined.add(pair);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return result.stream().map(x -> x.stream().filter(y -> y.size() > 0).collect(Collectors.toCollection(HashSet::new)))
|
return result.stream().map(x -> x.stream().filter(y -> y.size() > 0).collect(Collectors.toCollection(HashSet::new)))
|
||||||
@ -415,17 +431,18 @@ public class Unify {
|
|||||||
|
|
||||||
UnifyType aPrime = PlaceholderType.freshPlaceholder();
|
UnifyType aPrime = PlaceholderType.freshPlaceholder();
|
||||||
UnifyType supAPrime = new SuperType(aPrime);
|
UnifyType supAPrime = new SuperType(aPrime);
|
||||||
for(UnifyType theta : fc.smArg(subThetaPrime)) {
|
UnifyType thetaPrime = subThetaPrime.getSuperedType();
|
||||||
|
//for(UnifyType theta : fc.smArg(subThetaPrime)) {
|
||||||
Set<MPair> resultPrime = new HashSet<>();
|
Set<MPair> resultPrime = new HashSet<>();
|
||||||
resultPrime.add(new MPair(a, aPrime, PairOperator.EQUALSDOT));
|
resultPrime.add(new MPair(a, aPrime, PairOperator.EQUALSDOT));
|
||||||
resultPrime.add(new MPair(aPrime,theta, PairOperator.SMALLERDOT));
|
resultPrime.add(new MPair(thetaPrime, aPrime, PairOperator.SMALLERDOT));
|
||||||
result.add(resultPrime);
|
result.add(resultPrime);
|
||||||
|
|
||||||
resultPrime = new HashSet<>();
|
resultPrime = new HashSet<>();
|
||||||
resultPrime.add(new MPair(a, supAPrime, PairOperator.EQUALSDOT));
|
resultPrime.add(new MPair(a, supAPrime, PairOperator.EQUALSDOT));
|
||||||
resultPrime.add(new MPair(supAPrime,theta, PairOperator.SMALLERDOT));
|
resultPrime.add(new MPair(thetaPrime, aPrime, PairOperator.SMALLERDOT));
|
||||||
result.add(resultPrime);
|
result.add(resultPrime);
|
||||||
}
|
//}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,7 @@ import java.util.Set;
|
|||||||
import de.dhbwstuttgart.typeinference.unify.model.ExtendsType;
|
import de.dhbwstuttgart.typeinference.unify.model.ExtendsType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.FunNType;
|
import de.dhbwstuttgart.typeinference.unify.model.FunNType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.PlaceholderType;
|
import de.dhbwstuttgart.typeinference.unify.model.PlaceholderType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.SimpleType;
|
import de.dhbwstuttgart.typeinference.unify.model.ReferenceType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.SuperType;
|
import de.dhbwstuttgart.typeinference.unify.model.SuperType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
||||||
|
|
||||||
@ -38,8 +38,8 @@ public interface IFiniteClosure {
|
|||||||
*/
|
*/
|
||||||
public Set<UnifyType> smArg(UnifyType type);
|
public Set<UnifyType> smArg(UnifyType type);
|
||||||
|
|
||||||
public Set<UnifyType> grArg(SimpleType type);
|
public Set<UnifyType> grArg(ReferenceType type);
|
||||||
public Set<UnifyType> smArg(SimpleType type);
|
public Set<UnifyType> smArg(ReferenceType type);
|
||||||
|
|
||||||
public Set<UnifyType> grArg(ExtendsType type);
|
public Set<UnifyType> grArg(ExtendsType type);
|
||||||
public Set<UnifyType> smArg(ExtendsType type);
|
public Set<UnifyType> smArg(ExtendsType type);
|
||||||
|
@ -7,38 +7,28 @@ import de.dhbwstuttgart.typeinference.unify.interfaces.IFiniteClosure;
|
|||||||
/**
|
/**
|
||||||
* An extends wildcard type "? extends T".
|
* An extends wildcard type "? extends T".
|
||||||
*/
|
*/
|
||||||
public final class ExtendsType extends UnifyType {
|
public final class ExtendsType extends WildcardType {
|
||||||
|
|
||||||
/**
|
|
||||||
* The extended type
|
|
||||||
*/
|
|
||||||
private UnifyType extendedType;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new extends wildcard type.
|
* Creates a new extends wildcard type.
|
||||||
* @param extendedType The extended type e.g. Integer in "? extends Integer"
|
* @param extendedType The extended type e.g. Integer in "? extends Integer"
|
||||||
*/
|
*/
|
||||||
public ExtendsType(UnifyType extendedType) {
|
public ExtendsType(UnifyType extendedType) {
|
||||||
super("? extends " + extendedType.getName(), extendedType.getTypeParams());
|
super("? extends " + extendedType.getName(), extendedType, extendedType.getTypeParams());
|
||||||
this.extendedType = extendedType;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the type extended by this wildcard e.g. "Integer" for "? extends Integer"
|
|
||||||
* @return The extended type.
|
|
||||||
*/
|
|
||||||
public UnifyType getExtendedType() {
|
public UnifyType getExtendedType() {
|
||||||
return extendedType;
|
return wildcardedType;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TypeParams getTypeParams() {
|
public TypeParams getTypeParams() {
|
||||||
return extendedType.getTypeParams();
|
return wildcardedType.getTypeParams();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public UnifyType setTypeParams(TypeParams newTp) {
|
public UnifyType setTypeParams(TypeParams newTp) {
|
||||||
return new ExtendsType(extendedType.setTypeParams(newTp));
|
return new ExtendsType(wildcardedType.setTypeParams(newTp));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -53,12 +43,16 @@ public final class ExtendsType extends UnifyType {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
UnifyType apply(Unifier unif) {
|
UnifyType apply(Unifier unif) {
|
||||||
return new ExtendsType(extendedType.apply(unif));
|
return new ExtendsType(wildcardedType.apply(unif));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return extendedType.hashCode() + 17;
|
/*
|
||||||
|
* It is important that the prime that is added is different to the prime added in hashCode() of SuperType.
|
||||||
|
* Otherwise ? extends T and ? super T have the same hashCode() for every Type T.
|
||||||
|
*/
|
||||||
|
return wildcardedType.hashCode() + 229;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -67,12 +61,12 @@ public final class ExtendsType extends UnifyType {
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
ExtendsType other = (ExtendsType) obj;
|
ExtendsType other = (ExtendsType) obj;
|
||||||
return other.getExtendedType().equals(extendedType);
|
return other.getWildcardedType().equals(wildcardedType);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "? extends " + extendedType;
|
return "? extends " + wildcardedType;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -214,7 +214,7 @@ public class FiniteClosure implements IFiniteClosure {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<UnifyType> grArg(SimpleType type) {
|
public Set<UnifyType> grArg(ReferenceType type) {
|
||||||
Set<UnifyType> result = new HashSet<UnifyType>();
|
Set<UnifyType> result = new HashSet<UnifyType>();
|
||||||
|
|
||||||
result.add(type);
|
result.add(type);
|
||||||
@ -268,7 +268,7 @@ public class FiniteClosure implements IFiniteClosure {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<UnifyType> smArg(SimpleType type) {
|
public Set<UnifyType> smArg(ReferenceType type) {
|
||||||
Set<UnifyType> result = new HashSet<UnifyType>();
|
Set<UnifyType> result = new HashSet<UnifyType>();
|
||||||
|
|
||||||
result.add(type);
|
result.add(type);
|
||||||
|
@ -13,9 +13,18 @@ public final class PlaceholderType extends UnifyType{
|
|||||||
protected static String nextName = "gen_";
|
protected static String nextName = "gen_";
|
||||||
protected static Random rnd = new Random(43558747548978L);
|
protected static Random rnd = new Random(43558747548978L);
|
||||||
|
|
||||||
|
private final boolean IsGenerated;
|
||||||
|
|
||||||
public PlaceholderType(String name) {
|
public PlaceholderType(String name) {
|
||||||
super(name);
|
super(name);
|
||||||
EXISTING_PLACEHOLDERS.add(name);
|
EXISTING_PLACEHOLDERS.add(name);
|
||||||
|
IsGenerated = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected PlaceholderType(String name, boolean isGenerated) {
|
||||||
|
super(name);
|
||||||
|
EXISTING_PLACEHOLDERS.add(name);
|
||||||
|
IsGenerated = isGenerated;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static PlaceholderType freshPlaceholder() {
|
public static PlaceholderType freshPlaceholder() {
|
||||||
@ -24,7 +33,7 @@ public final class PlaceholderType extends UnifyType{
|
|||||||
while(EXISTING_PLACEHOLDERS.contains(name));
|
while(EXISTING_PLACEHOLDERS.contains(name));
|
||||||
nextName += randomChar();
|
nextName += randomChar();
|
||||||
|
|
||||||
return new PlaceholderType(name);
|
return new PlaceholderType(name, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -34,6 +43,10 @@ public final class PlaceholderType extends UnifyType{
|
|||||||
return (char) (rnd.nextInt(22) + 97);
|
return (char) (rnd.nextInt(22) + 97);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isGenerated() {
|
||||||
|
return IsGenerated;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
Set<UnifyType> smArg(IFiniteClosure fc) {
|
Set<UnifyType> smArg(IFiniteClosure fc) {
|
||||||
return fc.smArg(this);
|
return fc.smArg(this);
|
||||||
|
@ -4,12 +4,12 @@ import java.util.Set;
|
|||||||
|
|
||||||
import de.dhbwstuttgart.typeinference.unify.interfaces.IFiniteClosure;
|
import de.dhbwstuttgart.typeinference.unify.interfaces.IFiniteClosure;
|
||||||
|
|
||||||
public final class SimpleType extends UnifyType {
|
public final class ReferenceType extends UnifyType {
|
||||||
public SimpleType(String name, UnifyType... typeParams) {
|
public ReferenceType(String name, UnifyType... typeParams) {
|
||||||
super(name, new TypeParams(typeParams));
|
super(name, new TypeParams(typeParams));
|
||||||
}
|
}
|
||||||
|
|
||||||
public SimpleType(String name, TypeParams params) {
|
public ReferenceType(String name, TypeParams params) {
|
||||||
super(name, params);
|
super(name, params);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -25,12 +25,12 @@ public final class SimpleType extends UnifyType {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
UnifyType apply(Unifier unif) {
|
UnifyType apply(Unifier unif) {
|
||||||
return new SimpleType(typeName, typeParams.apply(unif));
|
return new ReferenceType(typeName, typeParams.apply(unif));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public UnifyType setTypeParams(TypeParams newTp) {
|
public UnifyType setTypeParams(TypeParams newTp) {
|
||||||
return new SimpleType(new String(typeName), newTp);
|
return new ReferenceType(new String(typeName), newTp);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -40,10 +40,10 @@ public final class SimpleType extends UnifyType {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean equals(Object obj) {
|
public boolean equals(Object obj) {
|
||||||
if(!(obj instanceof SimpleType))
|
if(!(obj instanceof ReferenceType))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
SimpleType other = (SimpleType) obj;
|
ReferenceType other = (ReferenceType) obj;
|
||||||
|
|
||||||
if(!other.getName().equals(typeName))
|
if(!other.getName().equals(typeName))
|
||||||
return false;
|
return false;
|
@ -4,32 +4,30 @@ import java.util.Set;
|
|||||||
|
|
||||||
import de.dhbwstuttgart.typeinference.unify.interfaces.IFiniteClosure;
|
import de.dhbwstuttgart.typeinference.unify.interfaces.IFiniteClosure;
|
||||||
|
|
||||||
public final class SuperType extends UnifyType {
|
public final class SuperType extends WildcardType {
|
||||||
|
|
||||||
private UnifyType superedType;
|
|
||||||
|
|
||||||
public SuperType(UnifyType superedType) {
|
public SuperType(UnifyType superedType) {
|
||||||
super("? super " + superedType.getName(), superedType.getTypeParams());
|
super("? super " + superedType.getName(), superedType, superedType.getTypeParams());
|
||||||
this.superedType = superedType;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public UnifyType getSuperedType() {
|
public UnifyType getSuperedType() {
|
||||||
return superedType;
|
return wildcardedType;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "? super " + superedType;
|
return "? super " + wildcardedType;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TypeParams getTypeParams() {
|
public TypeParams getTypeParams() {
|
||||||
return superedType.getTypeParams();
|
return wildcardedType.getTypeParams();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public UnifyType setTypeParams(TypeParams newTp) {
|
public UnifyType setTypeParams(TypeParams newTp) {
|
||||||
return new SuperType(superedType.setTypeParams(newTp));
|
return new SuperType(wildcardedType.setTypeParams(newTp));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -44,12 +42,16 @@ public final class SuperType extends UnifyType {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
UnifyType apply(Unifier unif) {
|
UnifyType apply(Unifier unif) {
|
||||||
return new SuperType(superedType.apply(unif));
|
return new SuperType(wildcardedType.apply(unif));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return superedType.hashCode() + 17;
|
/*
|
||||||
|
* It is important that the prime that is added is different to the prime added in hashCode() of ExtendsType.
|
||||||
|
* Otherwise ? extends T and ? super T have the same hashCode() for every Type T.
|
||||||
|
*/
|
||||||
|
return wildcardedType.hashCode() + 3917;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -58,7 +60,6 @@ public final class SuperType extends UnifyType {
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
SuperType other = (SuperType) obj;
|
SuperType other = (SuperType) obj;
|
||||||
return other.getSuperedType().equals(superedType);
|
return other.getSuperedType().equals(wildcardedType);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -12,7 +12,7 @@ import de.dhbwstuttgart.typeinference.unify.RuleSet;
|
|||||||
import de.dhbwstuttgart.typeinference.unify.interfaces.IRuleSet;
|
import de.dhbwstuttgart.typeinference.unify.interfaces.IRuleSet;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.ExtendsType;
|
import de.dhbwstuttgart.typeinference.unify.model.ExtendsType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.SimpleType;
|
import de.dhbwstuttgart.typeinference.unify.model.ReferenceType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.SuperType;
|
import de.dhbwstuttgart.typeinference.unify.model.SuperType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.PairOperator;
|
import de.dhbwstuttgart.typeinference.unify.model.PairOperator;
|
||||||
|
|
||||||
@ -139,15 +139,15 @@ public class RuleSetTest {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// C<T1, T2, T3, T4>
|
// C<T1, T2, T3, T4>
|
||||||
SimpleType c1 = tf.getSimpleType("C", "T1", "T2", "T3", "T4");
|
ReferenceType c1 = tf.getSimpleType("C", "T1", "T2", "T3", "T4");
|
||||||
// D<T4, T1, T2, T3>
|
// D<T4, T1, T2, T3>
|
||||||
SimpleType d1 = tf.getSimpleType("D", "T4", "T1", "T2", "T3");
|
ReferenceType d1 = tf.getSimpleType("D", "T4", "T1", "T2", "T3");
|
||||||
SimpleType buffer = tf.getSimpleType("Buffer");
|
ReferenceType buffer = tf.getSimpleType("Buffer");
|
||||||
|
|
||||||
//C<Int, ? extends Double, M, N>
|
//C<Int, ? extends Double, M, N>
|
||||||
SimpleType c2 = tf.getSimpleType("C", tf.getSimpleType("Int"), tf.getExtendsType(tf.getSimpleType("Double")), tf.getPlaceholderType("M"), tf.getPlaceholderType("N"));
|
ReferenceType c2 = tf.getSimpleType("C", tf.getSimpleType("Int"), tf.getExtendsType(tf.getSimpleType("Double")), tf.getPlaceholderType("M"), tf.getPlaceholderType("N"));
|
||||||
//D<? super HashSet<Int>, Number, Double, N>
|
//D<? super HashSet<Int>, Number, Double, N>
|
||||||
SimpleType d2 = tf.getSimpleType("D", tf.getSuperType(tf.getSimpleType("HashSet", "Int")), tf.getSimpleType("Number"), tf.getSimpleType("Double"), tf.getPlaceholderType("N"));
|
ReferenceType d2 = tf.getSimpleType("D", tf.getSuperType(tf.getSimpleType("HashSet", "Int")), tf.getSimpleType("Number"), tf.getSimpleType("Double"), tf.getPlaceholderType("N"));
|
||||||
|
|
||||||
// C<...> < buffer < D<...>
|
// C<...> < buffer < D<...>
|
||||||
fcb.add(c1, buffer);
|
fcb.add(c1, buffer);
|
||||||
@ -195,9 +195,9 @@ public class RuleSetTest {
|
|||||||
System.out.println("----- Reduce2 ------");
|
System.out.println("----- Reduce2 ------");
|
||||||
|
|
||||||
// C<T1, SType1, ? extends SType1>
|
// C<T1, SType1, ? extends SType1>
|
||||||
SimpleType c1 = tf.getSimpleType("C", tf.getPlaceholderType("T1"), tf.getSimpleType("SType1"), tf.getExtendsType(tf.getSimpleType("SType1")));
|
ReferenceType c1 = tf.getSimpleType("C", tf.getPlaceholderType("T1"), tf.getSimpleType("SType1"), tf.getExtendsType(tf.getSimpleType("SType1")));
|
||||||
// C<T2, SType2, ? extends SType2>
|
// C<T2, SType2, ? extends SType2>
|
||||||
SimpleType c2 = tf.getSimpleType("C", tf.getPlaceholderType("T2"), tf.getSimpleType("SType2"), tf.getExtendsType(tf.getSimpleType("SType2")));
|
ReferenceType c2 = tf.getSimpleType("C", tf.getPlaceholderType("T2"), tf.getSimpleType("SType2"), tf.getExtendsType(tf.getSimpleType("SType2")));
|
||||||
|
|
||||||
MPair pair1 = new MPair(c1, c2, PairOperator.EQUALSDOT);
|
MPair pair1 = new MPair(c1, c2, PairOperator.EQUALSDOT);
|
||||||
MPair pair2 = new MPair(tf.getExtendsType(c1), tf.getExtendsType(c2), PairOperator.EQUALSDOT);
|
MPair pair2 = new MPair(tf.getExtendsType(c1), tf.getExtendsType(c2), PairOperator.EQUALSDOT);
|
||||||
@ -217,7 +217,7 @@ public class RuleSetTest {
|
|||||||
* Negative Tests
|
* Negative Tests
|
||||||
*/
|
*/
|
||||||
|
|
||||||
SimpleType d1 = tf.getSimpleType("D", tf.getPlaceholderType("T2"), tf.getSimpleType("SType2"), tf.getExtendsType(tf.getSimpleType("SType2")));
|
ReferenceType d1 = tf.getSimpleType("D", tf.getPlaceholderType("T2"), tf.getSimpleType("SType2"), tf.getExtendsType(tf.getSimpleType("SType2")));
|
||||||
pair1 = new MPair(d1, c1, PairOperator.EQUALSDOT); // Case 1: D =. C
|
pair1 = new MPair(d1, c1, PairOperator.EQUALSDOT); // Case 1: D =. C
|
||||||
pair2 = new MPair(tf.getExtendsType(c1), c2, PairOperator.EQUALSDOT); // Case 2: ? extends C =. C
|
pair2 = new MPair(tf.getExtendsType(c1), c2, PairOperator.EQUALSDOT); // Case 2: ? extends C =. C
|
||||||
pair3 = new MPair(tf.getExtendsType(c1), tf.getSuperType(c2), PairOperator.EQUALSDOT); // Case 3: ? extends C =. ? super C
|
pair3 = new MPair(tf.getExtendsType(c1), tf.getSuperType(c2), PairOperator.EQUALSDOT); // Case 3: ? extends C =. ? super C
|
||||||
@ -239,13 +239,13 @@ public class RuleSetTest {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// X<T1, T2, T3, T4>
|
// X<T1, T2, T3, T4>
|
||||||
SimpleType x1 = tf.getSimpleType("X", "T1", "T2", "T3", "T4");
|
ReferenceType x1 = tf.getSimpleType("X", "T1", "T2", "T3", "T4");
|
||||||
// Y<T4, T1, T2, T3>
|
// Y<T4, T1, T2, T3>
|
||||||
SimpleType y1 = tf.getSimpleType("Y", "T4", "T1", "T2", "T3");
|
ReferenceType y1 = tf.getSimpleType("Y", "T4", "T1", "T2", "T3");
|
||||||
SimpleType buffer = tf.getSimpleType("Buffer");
|
ReferenceType buffer = tf.getSimpleType("Buffer");
|
||||||
|
|
||||||
//X<Int, ? extends Double, M, N>
|
//X<Int, ? extends Double, M, N>
|
||||||
SimpleType x2 = tf.getSimpleType("X", tf.getSimpleType("Int"), tf.getExtendsType(tf.getSimpleType("Double")), tf.getPlaceholderType("M"), tf.getPlaceholderType("N"));
|
ReferenceType x2 = tf.getSimpleType("X", tf.getSimpleType("Int"), tf.getExtendsType(tf.getSimpleType("Double")), tf.getPlaceholderType("M"), tf.getPlaceholderType("N"));
|
||||||
//? extends Y<? super HashSet<Int>, Number, Double, N>
|
//? extends Y<? super HashSet<Int>, Number, Double, N>
|
||||||
ExtendsType extY1 = tf.getExtendsType(tf.getSimpleType("Y", tf.getSuperType(tf.getSimpleType("HashSet", "Int")), tf.getSimpleType("Number"), tf.getSimpleType("Double"), tf.getPlaceholderType("N")));
|
ExtendsType extY1 = tf.getExtendsType(tf.getSimpleType("Y", tf.getSuperType(tf.getSimpleType("HashSet", "Int")), tf.getSimpleType("Number"), tf.getSimpleType("Double"), tf.getPlaceholderType("N")));
|
||||||
|
|
||||||
@ -301,13 +301,13 @@ public class RuleSetTest {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// X<T1, T2, T3, T4>
|
// X<T1, T2, T3, T4>
|
||||||
SimpleType x1 = tf.getSimpleType("X", "T1", "T2", "T3", "T4");
|
ReferenceType x1 = tf.getSimpleType("X", "T1", "T2", "T3", "T4");
|
||||||
// Y<T4, T1, T2, T3>
|
// Y<T4, T1, T2, T3>
|
||||||
SimpleType y1 = tf.getSimpleType("Y", "T4", "T1", "T2", "T3");
|
ReferenceType y1 = tf.getSimpleType("Y", "T4", "T1", "T2", "T3");
|
||||||
SimpleType buffer = tf.getSimpleType("Buffer");
|
ReferenceType buffer = tf.getSimpleType("Buffer");
|
||||||
|
|
||||||
//X<Int, ? extends Double, M, N>
|
//X<Int, ? extends Double, M, N>
|
||||||
SimpleType x2 = tf.getSimpleType("X", tf.getSimpleType("Int"), tf.getExtendsType(tf.getSimpleType("Double")), tf.getPlaceholderType("M"), tf.getPlaceholderType("N"));
|
ReferenceType x2 = tf.getSimpleType("X", tf.getSimpleType("Int"), tf.getExtendsType(tf.getSimpleType("Double")), tf.getPlaceholderType("M"), tf.getPlaceholderType("N"));
|
||||||
//? super Y<? super HashSet<Int>, Number, Double, N>
|
//? super Y<? super HashSet<Int>, Number, Double, N>
|
||||||
SuperType supY1 = tf.getSuperType(tf.getSimpleType("Y", tf.getSuperType(tf.getSimpleType("HashSet", "Int")), tf.getSimpleType("Number"), tf.getSimpleType("Double"), tf.getPlaceholderType("N")));
|
SuperType supY1 = tf.getSuperType(tf.getSimpleType("Y", tf.getSuperType(tf.getSimpleType("HashSet", "Int")), tf.getSimpleType("Number"), tf.getSimpleType("Double"), tf.getPlaceholderType("N")));
|
||||||
|
|
||||||
@ -365,9 +365,9 @@ public class RuleSetTest {
|
|||||||
System.out.println("----- ReduceEq ------");
|
System.out.println("----- ReduceEq ------");
|
||||||
|
|
||||||
// C<T1, SType1, ? extends SType1>
|
// C<T1, SType1, ? extends SType1>
|
||||||
SimpleType c1 = tf.getSimpleType("C", tf.getPlaceholderType("T1"), tf.getSimpleType("SType1"), tf.getExtendsType(tf.getSimpleType("SType1")));
|
ReferenceType c1 = tf.getSimpleType("C", tf.getPlaceholderType("T1"), tf.getSimpleType("SType1"), tf.getExtendsType(tf.getSimpleType("SType1")));
|
||||||
// C<T2, SType2, ? extends SType2>
|
// C<T2, SType2, ? extends SType2>
|
||||||
SimpleType c2 = tf.getSimpleType("C", tf.getPlaceholderType("T2"), tf.getSimpleType("SType2"), tf.getExtendsType(tf.getSimpleType("SType2")));
|
ReferenceType c2 = tf.getSimpleType("C", tf.getPlaceholderType("T2"), tf.getSimpleType("SType2"), tf.getExtendsType(tf.getSimpleType("SType2")));
|
||||||
|
|
||||||
MPair pair = new MPair(c1, c2, PairOperator.SMALLERDOTWC);
|
MPair pair = new MPair(c1, c2, PairOperator.SMALLERDOTWC);
|
||||||
Optional<Set<MPair>> res = rules.reduceEq(pair);
|
Optional<Set<MPair>> res = rules.reduceEq(pair);
|
||||||
@ -378,7 +378,7 @@ public class RuleSetTest {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// Case 1: D <.? C
|
// Case 1: D <.? C
|
||||||
SimpleType d1 = tf.getSimpleType("D", tf.getPlaceholderType("T2"), tf.getSimpleType("SType2"), tf.getExtendsType(tf.getSimpleType("SType2")));
|
ReferenceType d1 = tf.getSimpleType("D", tf.getPlaceholderType("T2"), tf.getSimpleType("SType2"), tf.getExtendsType(tf.getSimpleType("SType2")));
|
||||||
pair = new MPair(d1, c1, PairOperator.SMALLERDOTWC);
|
pair = new MPair(d1, c1, PairOperator.SMALLERDOTWC);
|
||||||
Assert.assertFalse(rules.reduceEq(pair).isPresent());
|
Assert.assertFalse(rules.reduceEq(pair).isPresent());
|
||||||
|
|
||||||
@ -521,9 +521,9 @@ public class RuleSetTest {
|
|||||||
TypeFactory tf = new TypeFactory();
|
TypeFactory tf = new TypeFactory();
|
||||||
FiniteClosureBuilder fcb = new FiniteClosureBuilder();
|
FiniteClosureBuilder fcb = new FiniteClosureBuilder();
|
||||||
|
|
||||||
SimpleType t1 = tf.getSimpleType("Type1", "T", "U");
|
ReferenceType t1 = tf.getSimpleType("Type1", "T", "U");
|
||||||
SimpleType t2 = tf.getSimpleType("Type2", "T");
|
ReferenceType t2 = tf.getSimpleType("Type2", "T");
|
||||||
SimpleType t3 = tf.getSimpleType("Type3", tf.getPlaceholderType("T"), tf.getSimpleType("Integer"));
|
ReferenceType t3 = tf.getSimpleType("Type3", tf.getPlaceholderType("T"), tf.getSimpleType("Integer"));
|
||||||
|
|
||||||
fcb.add(t1, t2);
|
fcb.add(t1, t2);
|
||||||
fcb.add(t2, t3);
|
fcb.add(t2, t3);
|
||||||
@ -534,9 +534,9 @@ public class RuleSetTest {
|
|||||||
* Positive Tests
|
* Positive Tests
|
||||||
*/
|
*/
|
||||||
|
|
||||||
SimpleType c1 = tf.getSimpleType("Type1", "String", "Double");
|
ReferenceType c1 = tf.getSimpleType("Type1", "String", "Double");
|
||||||
SimpleType c2 = tf.getSimpleType("Type2", "Object");
|
ReferenceType c2 = tf.getSimpleType("Type2", "Object");
|
||||||
SimpleType c3 = tf.getSimpleType("Type3", "Object", "Number");
|
ReferenceType c3 = tf.getSimpleType("Type3", "Object", "Number");
|
||||||
|
|
||||||
MPair pair1 = new MPair(c1, c2, PairOperator.SMALLERDOT);
|
MPair pair1 = new MPair(c1, c2, PairOperator.SMALLERDOT);
|
||||||
MPair pair2 = new MPair(c2, c3, PairOperator.SMALLERDOT);
|
MPair pair2 = new MPair(c2, c3, PairOperator.SMALLERDOT);
|
||||||
@ -565,11 +565,11 @@ public class RuleSetTest {
|
|||||||
TypeFactory tf = new TypeFactory();
|
TypeFactory tf = new TypeFactory();
|
||||||
FiniteClosureBuilder fcb = new FiniteClosureBuilder();
|
FiniteClosureBuilder fcb = new FiniteClosureBuilder();
|
||||||
|
|
||||||
SimpleType t1 = tf.getSimpleType("Type1", "T", "U");
|
ReferenceType t1 = tf.getSimpleType("Type1", "T", "U");
|
||||||
SimpleType t2 = tf.getSimpleType("Type2", "T");
|
ReferenceType t2 = tf.getSimpleType("Type2", "T");
|
||||||
SimpleType t3 = tf.getSimpleType("Type3", tf.getPlaceholderType("T"), tf.getSimpleType("Integer"));
|
ReferenceType t3 = tf.getSimpleType("Type3", tf.getPlaceholderType("T"), tf.getSimpleType("Integer"));
|
||||||
SimpleType t32 = tf.getSimpleType("Type3", "T", "U");
|
ReferenceType t32 = tf.getSimpleType("Type3", "T", "U");
|
||||||
SimpleType t4 = tf.getSimpleType("Object");
|
ReferenceType t4 = tf.getSimpleType("Object");
|
||||||
|
|
||||||
fcb.add(t1, t2);
|
fcb.add(t1, t2);
|
||||||
fcb.add(t2, t3);
|
fcb.add(t2, t3);
|
||||||
@ -581,9 +581,9 @@ public class RuleSetTest {
|
|||||||
* Positive Tests
|
* Positive Tests
|
||||||
*/
|
*/
|
||||||
|
|
||||||
SimpleType c1 = tf.getSimpleType("Type1", "String", "Double");
|
ReferenceType c1 = tf.getSimpleType("Type1", "String", "Double");
|
||||||
SimpleType c2 = tf.getSimpleType("Type2", "Object");
|
ReferenceType c2 = tf.getSimpleType("Type2", "Object");
|
||||||
SimpleType c3 = tf.getSimpleType("Type3", "Object", "Number");
|
ReferenceType c3 = tf.getSimpleType("Type3", "Object", "Number");
|
||||||
ExtendsType extc1 = new ExtendsType(c1);
|
ExtendsType extc1 = new ExtendsType(c1);
|
||||||
ExtendsType extc2 = new ExtendsType(c2);
|
ExtendsType extc2 = new ExtendsType(c2);
|
||||||
ExtendsType extc3 = new ExtendsType(c3);
|
ExtendsType extc3 = new ExtendsType(c3);
|
||||||
@ -627,11 +627,11 @@ public class RuleSetTest {
|
|||||||
TypeFactory tf = new TypeFactory();
|
TypeFactory tf = new TypeFactory();
|
||||||
FiniteClosureBuilder fcb = new FiniteClosureBuilder();
|
FiniteClosureBuilder fcb = new FiniteClosureBuilder();
|
||||||
|
|
||||||
SimpleType t1 = tf.getSimpleType("Type1", "T", "U");
|
ReferenceType t1 = tf.getSimpleType("Type1", "T", "U");
|
||||||
SimpleType t2 = tf.getSimpleType("Type2", "T");
|
ReferenceType t2 = tf.getSimpleType("Type2", "T");
|
||||||
SimpleType t3 = tf.getSimpleType("Type3", tf.getPlaceholderType("T"), tf.getSimpleType("Integer"));
|
ReferenceType t3 = tf.getSimpleType("Type3", tf.getPlaceholderType("T"), tf.getSimpleType("Integer"));
|
||||||
SimpleType t32 = tf.getSimpleType("Type3", "T", "U");
|
ReferenceType t32 = tf.getSimpleType("Type3", "T", "U");
|
||||||
SimpleType t4 = tf.getSimpleType("Object");
|
ReferenceType t4 = tf.getSimpleType("Object");
|
||||||
|
|
||||||
fcb.add(t1, t2);
|
fcb.add(t1, t2);
|
||||||
fcb.add(t2, t3);
|
fcb.add(t2, t3);
|
||||||
@ -643,9 +643,9 @@ public class RuleSetTest {
|
|||||||
* Positive Tests
|
* Positive Tests
|
||||||
*/
|
*/
|
||||||
|
|
||||||
SimpleType c1 = tf.getSimpleType("Type1", "String", "Double");
|
ReferenceType c1 = tf.getSimpleType("Type1", "String", "Double");
|
||||||
SimpleType c2 = tf.getSimpleType("Type2", "Object");
|
ReferenceType c2 = tf.getSimpleType("Type2", "Object");
|
||||||
SimpleType c3 = tf.getSimpleType("Type3", "Object", "Number");
|
ReferenceType c3 = tf.getSimpleType("Type3", "Object", "Number");
|
||||||
SuperType supc1 = new SuperType(c1);
|
SuperType supc1 = new SuperType(c1);
|
||||||
SuperType supc2 = new SuperType(c2);
|
SuperType supc2 = new SuperType(c2);
|
||||||
SuperType supc3 = new SuperType(c3);
|
SuperType supc3 = new SuperType(c3);
|
||||||
|
@ -11,7 +11,6 @@ import de.dhbwstuttgart.typeinference.unify.MartelliMontanariUnify;
|
|||||||
import de.dhbwstuttgart.typeinference.unify.interfaces.IUnify;
|
import de.dhbwstuttgart.typeinference.unify.interfaces.IUnify;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.MPair.PairOperator;
|
|
||||||
|
|
||||||
public class StandardUnifyTest {
|
public class StandardUnifyTest {
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@ import java.util.stream.Collectors;
|
|||||||
|
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.ExtendsType;
|
import de.dhbwstuttgart.typeinference.unify.model.ExtendsType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.PlaceholderType;
|
import de.dhbwstuttgart.typeinference.unify.model.PlaceholderType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.SimpleType;
|
import de.dhbwstuttgart.typeinference.unify.model.ReferenceType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.SuperType;
|
import de.dhbwstuttgart.typeinference.unify.model.SuperType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
||||||
|
|
||||||
@ -19,16 +19,16 @@ public class TypeFactory {
|
|||||||
return new SuperType(superedType);
|
return new SuperType(superedType);
|
||||||
}
|
}
|
||||||
|
|
||||||
public SimpleType getSimpleType(String name) {
|
public ReferenceType getSimpleType(String name) {
|
||||||
return new SimpleType(name);
|
return new ReferenceType(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
public SimpleType getSimpleType(String name, UnifyType... typeParams) {
|
public ReferenceType getSimpleType(String name, UnifyType... typeParams) {
|
||||||
return new SimpleType(name, typeParams);
|
return new ReferenceType(name, typeParams);
|
||||||
}
|
}
|
||||||
|
|
||||||
public SimpleType getSimpleType(String name, String... typeParams) {
|
public ReferenceType getSimpleType(String name, String... typeParams) {
|
||||||
return new SimpleType(name, Arrays.stream(typeParams).map(x -> getPlaceholderType(x)).collect(Collectors.toList()).toArray(new UnifyType[0]));
|
return new ReferenceType(name, Arrays.stream(typeParams).map(x -> getPlaceholderType(x)).collect(Collectors.toList()).toArray(new UnifyType[0]));
|
||||||
}
|
}
|
||||||
|
|
||||||
public PlaceholderType getPlaceholderType(String name) {
|
public PlaceholderType getPlaceholderType(String name) {
|
||||||
|
@ -12,6 +12,7 @@ import de.dhbwstuttgart.typeinference.unify.Unify;
|
|||||||
import de.dhbwstuttgart.typeinference.unify.interfaces.IFiniteClosure;
|
import de.dhbwstuttgart.typeinference.unify.interfaces.IFiniteClosure;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.PairOperator;
|
import de.dhbwstuttgart.typeinference.unify.model.PairOperator;
|
||||||
|
import de.dhbwstuttgart.typeinference.unify.model.PlaceholderType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.TypeParams;
|
import de.dhbwstuttgart.typeinference.unify.model.TypeParams;
|
||||||
import junit.framework.Assert;
|
import junit.framework.Assert;
|
||||||
@ -128,6 +129,7 @@ public class UnifyTest extends Unify {
|
|||||||
addAsSet(expected, new MPair(tphA, supObject, PairOperator.EQUALSDOT));
|
addAsSet(expected, new MPair(tphA, supObject, PairOperator.EQUALSDOT));
|
||||||
|
|
||||||
actual = unify(eq, fc);
|
actual = unify(eq, fc);
|
||||||
|
actual = filterGeneratedTPHsMultiple(actual);
|
||||||
|
|
||||||
Assert.assertEquals(expected, actual);
|
Assert.assertEquals(expected, actual);
|
||||||
|
|
||||||
@ -208,10 +210,11 @@ public class UnifyTest extends Unify {
|
|||||||
eq.add(new MPair(integer, number, PairOperator.SMALLERDOT));
|
eq.add(new MPair(integer, number, PairOperator.SMALLERDOT));
|
||||||
|
|
||||||
expected = new HashSet<>();
|
expected = new HashSet<>();
|
||||||
|
expected.add(new HashSet<>());
|
||||||
|
|
||||||
actual = unify(eq, fc);
|
actual = unify(eq, fc);
|
||||||
|
|
||||||
//Assert.assertEquals(expected, actual);
|
Assert.assertEquals(expected, actual);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Test 9:
|
* Test 9:
|
||||||
@ -226,7 +229,7 @@ public class UnifyTest extends Unify {
|
|||||||
|
|
||||||
actual = unify(eq, fc);
|
actual = unify(eq, fc);
|
||||||
|
|
||||||
//Assert.assertEquals(expected, actual);
|
Assert.assertEquals(expected, actual);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Test 10:
|
* Test 10:
|
||||||
@ -261,6 +264,21 @@ public class UnifyTest extends Unify {
|
|||||||
|
|
||||||
Assert.assertEquals(expected, actual);
|
Assert.assertEquals(expected, actual);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Test 11:
|
||||||
|
*
|
||||||
|
* (a <.? ? super b)
|
||||||
|
*/
|
||||||
|
|
||||||
|
eq = new HashSet<>();
|
||||||
|
eq.add(new MPair(tphA, tf.getSuperType(tphB), PairOperator.SMALLERDOTWC));
|
||||||
|
|
||||||
|
expected = new HashSet<>();
|
||||||
|
addAsSet(expected, new MPair(tphA, tf.getSuperType(tphB), PairOperator.SMALLERDOTWC));
|
||||||
|
|
||||||
|
actual = unify(eq, fc);
|
||||||
|
|
||||||
|
System.out.println(actual);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -320,8 +338,8 @@ public class UnifyTest extends Unify {
|
|||||||
|
|
||||||
actual = unify(eq, fc);
|
actual = unify(eq, fc);
|
||||||
|
|
||||||
System.out.println(actual);
|
//System.out.println(actual);
|
||||||
//Assert.assertEquals(expected, actual);
|
Assert.assertEquals(expected, actual);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -425,6 +443,14 @@ public class UnifyTest extends Unify {
|
|||||||
System.out.println(result);
|
System.out.println(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Set<Set<MPair>> filterGeneratedTPHsMultiple(Set<Set<MPair>> set) {
|
||||||
|
return set.stream().map(x -> filterGeneratedTPHs(x)).collect(Collectors.toSet());
|
||||||
|
}
|
||||||
|
|
||||||
|
private Set<MPair> filterGeneratedTPHs(Set<MPair> set) {
|
||||||
|
return set.stream().filter(x -> !((x.getRhsType() instanceof PlaceholderType) && ((PlaceholderType) x.getRhsType()).isGenerated())).
|
||||||
|
filter(x -> !((x.getLhsType() instanceof PlaceholderType) && ((PlaceholderType) x.getLhsType()).isGenerated())).collect(Collectors.toSet());
|
||||||
|
}
|
||||||
|
|
||||||
private void addAsSet(Set<Set<MPair>> addTo, MPair... mPairs) {
|
private void addAsSet(Set<Set<MPair>> addTo, MPair... mPairs) {
|
||||||
addTo.add(new HashSet<>(Arrays.stream(mPairs).collect(Collectors.toSet())));
|
addTo.add(new HashSet<>(Arrays.stream(mPairs).collect(Collectors.toSet())));
|
||||||
|
@ -23,7 +23,7 @@ import de.dhbwstuttgart.typeinference.UndConstraint;
|
|||||||
import de.dhbwstuttgart.typeinference.UnifyConstraintsSet;
|
import de.dhbwstuttgart.typeinference.UnifyConstraintsSet;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
import de.dhbwstuttgart.typeinference.unify.model.MPair;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.PairOperator;
|
import de.dhbwstuttgart.typeinference.unify.model.PairOperator;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.SimpleType;
|
import de.dhbwstuttgart.typeinference.unify.model.ReferenceType;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
||||||
|
|
||||||
|
|
||||||
@ -60,8 +60,8 @@ public class UnifyTypeFactoryTest {
|
|||||||
MPair mp4 = new MPair(tf.getPlaceholderType(tph2.getName().toString()), tf.getPlaceholderType(tph1.getName().toString()), PairOperator.SMALLERDOT);
|
MPair mp4 = new MPair(tf.getPlaceholderType(tph2.getName().toString()), tf.getPlaceholderType(tph1.getName().toString()), PairOperator.SMALLERDOT);
|
||||||
checkConvertMPair(mp4);
|
checkConvertMPair(mp4);
|
||||||
|
|
||||||
SimpleType typeWithParams = tf.getSimpleType("Test", getSimpleType());
|
ReferenceType typeWithParams = tf.getSimpleType("Test", getSimpleType());
|
||||||
SimpleType typeWithTPHParams = tf.getSimpleType("Test", tf.getPlaceholderType("Test"));
|
ReferenceType typeWithTPHParams = tf.getSimpleType("Test", tf.getPlaceholderType("Test"));
|
||||||
MPair mp5 = new MPair(typeWithTPHParams, typeWithParams, PairOperator.SMALLERDOT);
|
MPair mp5 = new MPair(typeWithTPHParams, typeWithParams, PairOperator.SMALLERDOT);
|
||||||
checkConvertMPair(mp5);
|
checkConvertMPair(mp5);
|
||||||
}
|
}
|
||||||
@ -130,7 +130,7 @@ public class UnifyTypeFactoryTest {
|
|||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static SimpleType getSimpleType(){
|
private static ReferenceType getSimpleType(){
|
||||||
return tf.getSimpleType("String");
|
return tf.getSimpleType("String");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user