forked from JavaTX/JavaCompilerCore
adapted adaptRules
This commit is contained in:
parent
332dd57de3
commit
639ac8430c
@ -53,6 +53,8 @@ public interface IFiniteClosure {
|
|||||||
public Set<Type> grArg(FunNType type);
|
public Set<Type> grArg(FunNType type);
|
||||||
public Set<Type> smArg(FunNType type);
|
public Set<Type> smArg(FunNType type);
|
||||||
|
|
||||||
public Optional<Type> findGenericParent(String typeName);
|
public Optional<Type> getLeftHandedType(Type t);
|
||||||
|
public Set<Type> getAncestors(Type t);
|
||||||
|
|
||||||
public Set<Type> getAllTypesByName(String typeName);
|
public Set<Type> getAllTypesByName(String typeName);
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@ import java.util.ArrayList;
|
|||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
@ -271,8 +272,6 @@ public class FiniteClosure implements IFiniteClosure {
|
|||||||
Set<Type> result = new HashSet<Type>();
|
Set<Type> result = new HashSet<Type>();
|
||||||
|
|
||||||
result.add(type);
|
result.add(type);
|
||||||
// smaller(type).forEach(x -> result.add(new ExtendsType(x))); TODO inkorrekt? daher erstmal raus
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -318,8 +317,6 @@ public class FiniteClosure implements IFiniteClosure {
|
|||||||
public Set<Type> smArg(PlaceholderType type) {
|
public Set<Type> smArg(PlaceholderType type) {
|
||||||
HashSet<Type> result = new HashSet<>();
|
HashSet<Type> result = new HashSet<>();
|
||||||
result.add(type);
|
result.add(type);
|
||||||
//result.add(new SuperType(type)); TODO inkorrekt, daher erstmal raus
|
|
||||||
//result.add(new ExtendsType(type));
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -338,25 +335,6 @@ public class FiniteClosure implements IFiniteClosure {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public Optional<Type> findGenericParent(String type) {
|
|
||||||
Type genericType = null;
|
|
||||||
for(MPair pair : pairs) {
|
|
||||||
Type lhs = pair.getLhsType();
|
|
||||||
if(lhs.getName().equals(type)) {
|
|
||||||
genericType = lhs;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(genericType == null)
|
|
||||||
return Optional.empty();
|
|
||||||
|
|
||||||
// TODO reduce reglen überarbeiten, es kann mehrere Typen D geben die eine bedingung
|
|
||||||
// erfüllen, diese methode ausimplementieren
|
|
||||||
return Optional.empty();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<Type> getAllTypesByName(String typeName) {
|
public Set<Type> getAllTypesByName(String typeName) {
|
||||||
if(!strInheritanceGraph.containsKey(typeName))
|
if(!strInheritanceGraph.containsKey(typeName))
|
||||||
@ -364,6 +342,25 @@ public class FiniteClosure implements IFiniteClosure {
|
|||||||
return strInheritanceGraph.get(typeName).stream().map(x -> x.getContent()).collect(Collectors.toCollection(HashSet::new));
|
return strInheritanceGraph.get(typeName).stream().map(x -> x.getContent()).collect(Collectors.toCollection(HashSet::new));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Optional<Type> getLeftHandedType(Type t) {
|
||||||
|
if(!strInheritanceGraph.containsKey(t.getName()))
|
||||||
|
return Optional.empty();
|
||||||
|
|
||||||
|
for(MPair pair : pairs)
|
||||||
|
if(pair.getLhsType().getName().equals(t.getName()))
|
||||||
|
return Optional.of(pair.getLhsType());
|
||||||
|
|
||||||
|
return Optional.empty();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Set<Type> getAncestors(Type t) {
|
||||||
|
if(!inheritanceGraph.containsKey(t))
|
||||||
|
return new HashSet<>();
|
||||||
|
return inheritanceGraph.get(t).getContentOfPredecessors();
|
||||||
|
}
|
||||||
|
|
||||||
protected void permuteParams(ArrayList<Set<Type>> candidates, int idx, Set<TypeParams> result, Type[] current) {
|
protected void permuteParams(ArrayList<Set<Type>> candidates, int idx, Set<TypeParams> result, Type[] current) {
|
||||||
if(candidates.size() == idx) {
|
if(candidates.size() == idx) {
|
||||||
result.add(new TypeParams(Arrays.copyOf(current, current.length)));
|
result.add(new TypeParams(Arrays.copyOf(current, current.length)));
|
||||||
|
@ -85,26 +85,26 @@ public class RuleSet implements IRuleSet{
|
|||||||
if(pair.getPairOp() != PairOperator.SMALLERDOTWC)
|
if(pair.getPairOp() != PairOperator.SMALLERDOTWC)
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
Type lhsType = pair.getLhsType();
|
Type x = pair.getLhsType();
|
||||||
|
|
||||||
if(!(lhsType instanceof SimpleType) && !(lhsType instanceof ExtendsType))
|
if(!(x instanceof SimpleType) && !(x instanceof ExtendsType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
Type rhsType = pair.getRhsType();
|
Type extY = pair.getRhsType();
|
||||||
|
|
||||||
if(!(rhsType instanceof ExtendsType))
|
if(!(extY instanceof ExtendsType))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
if(lhsType.getTypeParams().empty() || rhsType.getTypeParams().size() != lhsType.getTypeParams().size())
|
if(x.getTypeParams().empty() || extY.getTypeParams().size() != x.getTypeParams().size())
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
int[] pi = pi(lhsType, rhsType);
|
int[] pi = pi(x, extY);
|
||||||
|
|
||||||
if(pi.length == 0)
|
if(pi.length == 0)
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
TypeParams rhsTypeParams = rhsType.getTypeParams();
|
TypeParams rhsTypeParams = extY.getTypeParams();
|
||||||
TypeParams lhsTypeParams = lhsType.getTypeParams();
|
TypeParams lhsTypeParams = x.getTypeParams();
|
||||||
Set<MPair> result = new HashSet<>();
|
Set<MPair> result = new HashSet<>();
|
||||||
|
|
||||||
for(int rhsIdx = 0; rhsIdx < rhsTypeParams.size(); rhsIdx++)
|
for(int rhsIdx = 0; rhsIdx < rhsTypeParams.size(); rhsIdx++)
|
||||||
@ -160,7 +160,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
if(!rhsType.getName().equals(lhsType.getName()))
|
if(!rhsType.getName().equals(lhsType.getName()))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
if(rhsType instanceof PlaceholderType || rhsType.getTypeParams().empty())
|
if(rhsType instanceof PlaceholderType || lhsType instanceof PlaceholderType || rhsType.getTypeParams().empty())
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
if(rhsType.getTypeParams().size() != lhsType.getTypeParams().size())
|
if(rhsType.getTypeParams().size() != lhsType.getTypeParams().size())
|
||||||
@ -328,7 +328,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
if(typeD.getName().equals(typeDs.getName()))
|
if(typeD.getName().equals(typeDs.getName()))
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
Optional<Type> opt = finiteClosure.findGenericParent(typeD.getName());
|
Optional<Type> opt = finiteClosure.getLeftHandedType(typeD);
|
||||||
|
|
||||||
if(!opt.isPresent())
|
if(!opt.isPresent())
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
@ -337,7 +337,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
Type typeDgen = opt.get();
|
Type typeDgen = opt.get();
|
||||||
|
|
||||||
// Actually greater+ because the types are ensured to have different names
|
// Actually greater+ because the types are ensured to have different names
|
||||||
Set<Type> greater = finiteClosure.greater(typeDgen);
|
Set<Type> greater = finiteClosure.getAncestors(typeDgen);
|
||||||
opt = greater.stream().filter(x -> x.getName().equals(typeDs.getName())).findAny();
|
opt = greater.stream().filter(x -> x.getName().equals(typeDs.getName())).findAny();
|
||||||
|
|
||||||
if(!opt.isPresent())
|
if(!opt.isPresent())
|
||||||
@ -350,7 +350,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
|
|
||||||
Unifier unif = new Unifier((PlaceholderType) typeDgenParams.get(0), typeDParams.get(0));
|
Unifier unif = new Unifier((PlaceholderType) typeDgenParams.get(0), typeDParams.get(0));
|
||||||
for(int i = 1; i < typeDParams.size(); i++)
|
for(int i = 1; i < typeDParams.size(); i++)
|
||||||
unif.andThen(new Unifier((PlaceholderType) typeDgenParams.get(i), typeDParams.get(i)));
|
unif.Add((PlaceholderType) typeDgenParams.get(i), typeDParams.get(i));
|
||||||
|
|
||||||
return Optional.of(new MPair(unif.apply(newLhs), typeDs, PairOperator.SMALLERDOT));
|
return Optional.of(new MPair(unif.apply(newLhs), typeDs, PairOperator.SMALLERDOT));
|
||||||
}
|
}
|
||||||
@ -373,9 +373,9 @@ public class RuleSet implements IRuleSet{
|
|||||||
|
|
||||||
Type typeDgen;
|
Type typeDgen;
|
||||||
if(typeD instanceof SimpleType)
|
if(typeD instanceof SimpleType)
|
||||||
typeDgen = finiteClosure.findGenericParent(typeD.getName()).orElse(null);
|
typeDgen = finiteClosure.getLeftHandedType(typeD).orElse(null);
|
||||||
else {
|
else {
|
||||||
Optional<Type> opt = finiteClosure.findGenericParent(((ExtendsType) typeD).getExtendedType().getName());
|
Optional<Type> opt = finiteClosure.getLeftHandedType(((ExtendsType) typeD).getExtendedType());
|
||||||
typeDgen = opt.isPresent() ? new ExtendsType(opt.get()) : null;
|
typeDgen = opt.isPresent() ? new ExtendsType(opt.get()) : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -396,7 +396,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
|
|
||||||
Unifier unif = new Unifier((PlaceholderType) typeDgenParams.get(0), typeDParams.get(0));
|
Unifier unif = new Unifier((PlaceholderType) typeDgenParams.get(0), typeDParams.get(0));
|
||||||
for(int i = 1; i < typeDParams.size(); i++)
|
for(int i = 1; i < typeDParams.size(); i++)
|
||||||
unif.andThen(new Unifier((PlaceholderType) typeDgenParams.get(i), typeDParams.get(i)));
|
unif.Add((PlaceholderType) typeDgenParams.get(i), typeDParams.get(i));
|
||||||
|
|
||||||
return Optional.of(new MPair(unif.apply(newLhs), typeExtDs, PairOperator.SMALLERDOTWC));
|
return Optional.of(new MPair(unif.apply(newLhs), typeExtDs, PairOperator.SMALLERDOTWC));
|
||||||
}
|
}
|
||||||
@ -418,7 +418,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
|
|
||||||
|
|
||||||
Optional<Type> opt = finiteClosure.findGenericParent(((SuperType) typeSupD).getSuperedType().getName());
|
Optional<Type> opt = finiteClosure.getLeftHandedType(((SuperType) typeSupD).getSuperedType());
|
||||||
|
|
||||||
if(!opt.isPresent())
|
if(!opt.isPresent())
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
@ -448,7 +448,7 @@ public class RuleSet implements IRuleSet{
|
|||||||
|
|
||||||
Unifier unif = new Unifier((PlaceholderType) typeSupDsgenParams.get(0), typeDParams.get(0));
|
Unifier unif = new Unifier((PlaceholderType) typeSupDsgenParams.get(0), typeDParams.get(0));
|
||||||
for(int i = 1; i < typeDParams.size(); i++)
|
for(int i = 1; i < typeDParams.size(); i++)
|
||||||
unif.andThen(new Unifier((PlaceholderType) typeSupDsgenParams.get(i), typeDParams.get(i)));
|
unif.Add((PlaceholderType) typeSupDsgenParams.get(i), typeDParams.get(i));
|
||||||
|
|
||||||
return Optional.of(new MPair(unif.apply(newLhs), newRhs, PairOperator.SMALLERDOTWC));
|
return Optional.of(new MPair(unif.apply(newLhs), newRhs, PairOperator.SMALLERDOTWC));
|
||||||
}
|
}
|
||||||
@ -460,42 +460,26 @@ public class RuleSet implements IRuleSet{
|
|||||||
* @return An array containing the values of pi for every type argument of C or an empty array if the search failed.
|
* @return An array containing the values of pi for every type argument of C or an empty array if the search failed.
|
||||||
*/
|
*/
|
||||||
private int[] pi(Type C, Type D) {
|
private int[] pi(Type C, Type D) {
|
||||||
Type cFromFc = null;
|
String simpleTypeDName = D.getName();
|
||||||
if(C instanceof SimpleType)
|
if(D instanceof ExtendsType)
|
||||||
cFromFc = finiteClosure.findGenericParent(C.getName()).orElse(null);
|
simpleTypeDName = ((ExtendsType) D).getExtendedType().getName();
|
||||||
else if(C instanceof ExtendsType) {
|
else if(D instanceof SuperType)
|
||||||
Optional<Type> opt = finiteClosure.findGenericParent(((ExtendsType) C).getExtendedType().getName());
|
simpleTypeDName = ((SuperType) D).getSuperedType().getName();
|
||||||
if(opt.isPresent()) cFromFc = new ExtendsType(opt.get());
|
|
||||||
}
|
|
||||||
else if(C instanceof SuperType) {
|
|
||||||
Optional<Type> opt = finiteClosure.findGenericParent(((SuperType) C).getSuperedType().getName());
|
|
||||||
if(opt.isPresent()) cFromFc = new SuperType(opt.get());
|
|
||||||
}
|
|
||||||
|
|
||||||
if(cFromFc == null)
|
String simpleTypeCName = C.getName();
|
||||||
|
if(C instanceof ExtendsType)
|
||||||
|
simpleTypeCName = ((ExtendsType) C).getExtendedType().getName();
|
||||||
|
if(C instanceof SuperType)
|
||||||
|
simpleTypeCName = ((SuperType) C).getSuperedType().getName();
|
||||||
|
|
||||||
|
Optional<Type[]> typesFromFc = Optional.empty(); //TODO reduce regeln
|
||||||
|
//finiteClosure.findCandD(simpleTypeCName, simpleTypeDName);
|
||||||
|
|
||||||
|
if(typesFromFc == null)
|
||||||
return new int[0];
|
return new int[0];
|
||||||
|
|
||||||
Optional<Type> opt = Optional.empty();
|
Type cFromFc = typesFromFc.get()[0];
|
||||||
if(D instanceof ExtendsType) {
|
Type dFromFc = typesFromFc.get()[1];
|
||||||
SimpleType dSType = (SimpleType) ((ExtendsType) D).getExtendedType();
|
|
||||||
opt = finiteClosure.grArg(cFromFc).stream()
|
|
||||||
.filter(x -> x instanceof ExtendsType)
|
|
||||||
.filter(x -> ((ExtendsType) x).getExtendedType().getName().equals(dSType.getName())).findAny();
|
|
||||||
}
|
|
||||||
else if(D instanceof SuperType) {
|
|
||||||
SimpleType dSType = (SimpleType) ((SuperType) D).getSuperedType();
|
|
||||||
opt = finiteClosure.grArg(cFromFc).stream()
|
|
||||||
.filter(x -> x instanceof SuperType)
|
|
||||||
.filter(x -> ((SuperType) x).getSuperedType().getName().equals(dSType.getName())).findAny();
|
|
||||||
}
|
|
||||||
else if (D instanceof SimpleType)
|
|
||||||
opt = finiteClosure.greater(cFromFc).stream()
|
|
||||||
.filter(x -> x.getName().equals(D.getName())).findAny();
|
|
||||||
|
|
||||||
if(!opt.isPresent())
|
|
||||||
return new int[0];
|
|
||||||
|
|
||||||
Type dFromFc = opt.get();
|
|
||||||
|
|
||||||
Assert.assertEquals(cFromFc.getTypeParams().size(), dFromFc.getTypeParams().size());
|
Assert.assertEquals(cFromFc.getTypeParams().size(), dFromFc.getTypeParams().size());
|
||||||
Assert.assertTrue(dFromFc.getTypeParams().size() > 0);
|
Assert.assertTrue(dFromFc.getTypeParams().size() > 0);
|
||||||
|
Loading…
Reference in New Issue
Block a user