Merge branch 'unify' of ssh://gohorb.ba-horb.de/bahome/projekt/git/JavaCompilerCore into refactoring

This commit is contained in:
JanUlrich 2016-04-12 14:00:53 +02:00
commit 4173733ada
4 changed files with 83 additions and 25 deletions

View File

@ -97,7 +97,12 @@ public class Unify {
Set<List<Set<UnifyPair>>> cartResult = setOps.cartesianProduct(secondLevelSetList); Set<List<Set<UnifyPair>>> cartResult = setOps.cartesianProduct(secondLevelSetList);
Set<Set<UnifyPair>> flat = new HashSet<>(); Set<Set<UnifyPair>> flat = new HashSet<>();
cartResult.stream().forEach(x -> flat.addAll(x)); for(List<Set<UnifyPair>> s : cartResult) {
Set<UnifyPair> flat1 = new HashSet<>();
for(Set<UnifyPair> s1 : s)
flat1.addAll(s1);
flat.add(flat1);
}
topLevelSets.add(flat); topLevelSets.add(flat);
} }

View File

@ -41,11 +41,11 @@ public class FiniteClosure implements IFiniteClosure {
Node<UnifyType> parentNode = inheritanceGraph.get(pair.getRhsType()); Node<UnifyType> parentNode = inheritanceGraph.get(pair.getRhsType());
// Add edge // Add edge
parentNode.AddDescendant(childNode); parentNode.addDescendant(childNode);
// Add edges to build the transitive closure // Add edges to build the transitive closure
parentNode.getPredecessors().stream().forEach(x -> x.AddDescendant(childNode)); parentNode.getPredecessors().stream().forEach(x -> x.addDescendant(childNode));
childNode.getDescendants().stream().forEach(x -> x.AddPredecessor(parentNode)); childNode.getDescendants().stream().forEach(x -> x.addPredecessor(parentNode));
} }
// Build the alternative representation with strings as keys // Build the alternative representation with strings as keys

View File

@ -4,25 +4,39 @@ import java.util.Set;
import de.dhbwstuttgart.typeinference.unify.interfaces.IFiniteClosure; import de.dhbwstuttgart.typeinference.unify.interfaces.IFiniteClosure;
/**
* A real function type in java.
* @author Florian Steurer
*/
public class FunNType extends UnifyType { public class FunNType extends UnifyType {
/**
* Creates a FunN-Type with the specified TypeParameters.
*/
protected FunNType(TypeParams p) { protected FunNType(TypeParams p) {
super("FuN", p); super("FuN", p);
} }
public static FunNType getFunNType(TypeParams tp) { /**
if(!validateTypeParams(tp)) * Creates a new FunNType.
* @param tp The parameters of the type.
* @return A FunNType.
* @throws IllegalArgumentException is thrown when there are to few type parameters or there are wildcard-types.
*/
public static FunNType getFunNType(TypeParams tp) throws IllegalArgumentException {
if(tp.size() == 0)
throw new IllegalArgumentException("FunNTypes need at least one type parameter");
for(UnifyType t : tp)
if(t instanceof WildcardType)
throw new IllegalArgumentException("Invalid TypeParams for a FunNType: " + tp); throw new IllegalArgumentException("Invalid TypeParams for a FunNType: " + tp);
return new FunNType(tp); return new FunNType(tp);
} }
private static boolean validateTypeParams(TypeParams tp) { /**
if(tp.size() == 0) * Returns the degree of the function type, e.g. 2 for FunN<Integer, Integer, Integer>.
return false; */
for(UnifyType t : tp) public int getN() {
if(t instanceof WildcardType) return typeParams.size()-1;
return false;
return true;
} }
@Override @Override
@ -30,10 +44,6 @@ public class FunNType extends UnifyType {
return getFunNType(newTp); return getFunNType(newTp);
} }
public int getN() {
return typeParams.size()-1;
}
@Override @Override
Set<UnifyType> smArg(IFiniteClosure fc) { Set<UnifyType> smArg(IFiniteClosure fc) {
return fc.smArg(this); return fc.smArg(this);
@ -46,13 +56,14 @@ public class FunNType extends UnifyType {
@Override @Override
UnifyType apply(Unifier unif) { UnifyType apply(Unifier unif) {
// TODO Auto-generated method stub // TODO this bypasses the validation of the type parameters.
return null; // Wildcard types can be unified into FunNTypes.
return new FunNType(typeParams.apply(unif));
} }
@Override @Override
public int hashCode() { public int hashCode() {
return 31 + typeParams.hashCode(); return 181 + typeParams.hashCode();
} }
@Override @Override

View File

@ -4,48 +4,90 @@ import java.util.HashSet;
import java.util.Set; import java.util.Set;
import java.util.stream.Collectors; import java.util.stream.Collectors;
/**
* A node of a directed graph.
* @author Florian Steurer
*
* @param <T> The type of the content of the node.
*/
class Node<T> { class Node<T> {
/**
* The content of the node.
*/
private T content; private T content;
/**
* The set of predecessors
*/
private HashSet<Node<T>> predecessors = new HashSet<>(); private HashSet<Node<T>> predecessors = new HashSet<>();
/**
* The set of descendants
*/
private HashSet<Node<T>> descendants = new HashSet<>(); private HashSet<Node<T>> descendants = new HashSet<>();
/**
* Creates a node containing the specified content.
*/
public Node(T content) { public Node(T content) {
this.content = content; this.content = content;
} }
public void AddDescendant(Node<T> descendant) { /**
* Adds a directed edge from this node to the descendant (this -> descendant)
*/
public void addDescendant(Node<T> descendant) {
if(descendants.contains(descendant)) if(descendants.contains(descendant))
return; return;
descendants.add(descendant); descendants.add(descendant);
descendant.AddPredecessor(this); descendant.addPredecessor(this);
} }
public void AddPredecessor(Node<T> predecessor) { /**
* Adds a directed edge from the predecessor to this node (predecessor -> this)
*/
public void addPredecessor(Node<T> predecessor) {
if(predecessors.contains(predecessor)) if(predecessors.contains(predecessor))
return; return;
predecessors.add(predecessor); predecessors.add(predecessor);
predecessor.AddDescendant(this); predecessor.addDescendant(this);
} }
/**
* The content of this node.
*/
public T getContent() { public T getContent() {
return content; return content;
} }
/**
* Returns all predecessors (nodes that have a directed edge to this node)
*/
public Set<Node<T>> getPredecessors() { public Set<Node<T>> getPredecessors() {
return predecessors; return predecessors;
} }
/**
* Returns all descendants. All nodes M, where there is a edge from this node to the node M.
* @return
*/
public Set<Node<T>> getDescendants() { public Set<Node<T>> getDescendants() {
return descendants; return descendants;
} }
/**
* Retrieves the content of all descendants.
*/
public Set<T> getContentOfDescendants() { public Set<T> getContentOfDescendants() {
return descendants.stream().map(x -> x.getContent()).collect(Collectors.toSet()); return descendants.stream().map(x -> x.getContent()).collect(Collectors.toSet());
} }
/**
* Retrieves the content of all predecessors.
*/
public Set<T> getContentOfPredecessors() { public Set<T> getContentOfPredecessors() {
return predecessors.stream().map(x -> x.getContent()).collect(Collectors.toSet()); return predecessors.stream().map(x -> x.getContent()).collect(Collectors.toSet());
} }