forked from JavaTX/JavaCompilerCore
.
This commit is contained in:
parent
5f9452cfda
commit
11fc7a4512
@ -18,9 +18,11 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
- Transitiven Abschluss von FC bilden um schneller Subtypen bestimmen zu können
|
||||||
|
- Problem: 2 FCs für Pairs und MPairs durch das Mapping
|
||||||
- Equals der Typen schreiben um instanceof Prüfungen zu vermeiden
|
- Equals der Typen schreiben um instanceof Prüfungen zu vermeiden
|
||||||
|
|
||||||
|
- Refactoring der Klassen Menge und Pair erlaubt?
|
||||||
|
|
||||||
SPEED UP
|
SPEED UP
|
||||||
- Anwendungsreihenfolge der Regeln (wahrscheinlichste zuerst, evtl ist nach regel 1 regel 2 nie möglich etc...)
|
- Anwendungsreihenfolge der Regeln (wahrscheinlichste zuerst, evtl ist nach regel 1 regel 2 nie möglich etc...)
|
||||||
|
5
src/de/dhbwstuttgart/typeinference/IPair.java
Normal file
5
src/de/dhbwstuttgart/typeinference/IPair.java
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
package de.dhbwstuttgart.typeinference;
|
||||||
|
|
||||||
|
public interface IPair {
|
||||||
|
|
||||||
|
}
|
@ -31,7 +31,7 @@ import de.dhbwstuttgart.syntaxtree.type.WildcardType;
|
|||||||
// Klasse, die ein Paar in der Menge Eq speichern kann
|
// Klasse, die ein Paar in der Menge Eq speichern kann
|
||||||
// ino.end
|
// ino.end
|
||||||
// ino.class.Pair.26540.declaration
|
// ino.class.Pair.26540.declaration
|
||||||
public class Pair implements Serializable, DeepCloneable
|
public class Pair implements IPair, Serializable, DeepCloneable
|
||||||
// ino.end
|
// ino.end
|
||||||
// ino.class.Pair.26540.body
|
// ino.class.Pair.26540.body
|
||||||
{
|
{
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
package de.dhbwstuttgart.typeinference.unify.interfaces;
|
package de.dhbwstuttgart.typeinference.unify.interfaces;
|
||||||
|
|
||||||
public interface IFiniteClosure {
|
import de.dhbwstuttgart.typeinference.IPair;
|
||||||
|
|
||||||
|
public interface IFiniteClosure<T extends IPair> {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,11 +1,7 @@
|
|||||||
package de.dhbwstuttgart.typeinference.unifynew;
|
package de.dhbwstuttgart.typeinference.unifynew;
|
||||||
|
|
||||||
import java.util.AbstractQueue;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.LinkedHashSet;
|
import java.util.LinkedHashSet;
|
||||||
import java.util.LinkedList;
|
|
||||||
import java.util.Queue;
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import de.dhbwstuttgart.typeinference.Menge;
|
import de.dhbwstuttgart.typeinference.Menge;
|
||||||
|
@ -1,7 +1,13 @@
|
|||||||
package de.dhbwstuttgart.typinference.unify.model;
|
package de.dhbwstuttgart.typinference.unify.model;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import de.dhbwstuttgart.typeinference.IPair;
|
||||||
import de.dhbwstuttgart.typeinference.unify.interfaces.IFiniteClosure;
|
import de.dhbwstuttgart.typeinference.unify.interfaces.IFiniteClosure;
|
||||||
|
|
||||||
public class FiniteClosure implements IFiniteClosure {
|
public class FiniteClosure<T extends IPair> implements IFiniteClosure<T> {
|
||||||
|
|
||||||
|
public FiniteClosure(Set<T> pairs) {
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,9 @@
|
|||||||
package de.dhbwstuttgart.typinference.unify.model;
|
package de.dhbwstuttgart.typinference.unify.model;
|
||||||
|
|
||||||
|
import de.dhbwstuttgart.typeinference.IPair;
|
||||||
import de.dhbwstuttgart.typeinference.Pair.PairOperator;
|
import de.dhbwstuttgart.typeinference.Pair.PairOperator;
|
||||||
|
|
||||||
public class MPair {
|
public class MPair implements IPair {
|
||||||
|
|
||||||
private MType type1;
|
private MType type1;
|
||||||
private MType type2;
|
private MType type2;
|
||||||
|
38
src/de/dhbwstuttgart/typinference/unify/model/Node.java
Normal file
38
src/de/dhbwstuttgart/typinference/unify/model/Node.java
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
package de.dhbwstuttgart.typinference.unify.model;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.LinkedList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
public class Node<T> {
|
||||||
|
private T content;
|
||||||
|
|
||||||
|
private HashSet<Node<T>> predecessors = new HashSet<>();
|
||||||
|
private HashSet<Node<T>> descendants = new HashSet<>();
|
||||||
|
|
||||||
|
public Node(T content) {
|
||||||
|
this.content = content;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void AddDescendant(Node<T> descendant) {
|
||||||
|
descendants.add(descendant);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void AddPredecessor(Node<T> predecessor) {
|
||||||
|
predecessors.add(predecessor);
|
||||||
|
predecessor.AddDescendant(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
public T getContent() {
|
||||||
|
return content;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Set<Node<T>> getPredecessors() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Set<Node<T>> getDescendants() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user