forked from JavaTX/JavaCompilerCore
Unify auf commit 144c31a4cb96bf327bebeb78be18be4e2b6f13ac ändern
This commit is contained in:
parent
61891177a1
commit
b8c0d87056
@ -6,25 +6,11 @@ package de.dhbwstuttgart.typeinference.unify;
|
|||||||
import java.util.Enumeration;
|
import java.util.Enumeration;
|
||||||
import java.util.Hashtable;
|
import java.util.Hashtable;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import de.dhbwstuttgart.typeinference.Menge;
|
|
||||||
|
|
||||||
import java.util.function.BiConsumer;
|
|
||||||
import java.util.function.Function;
|
|
||||||
import java.util.function.Supplier;
|
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
import com.google.common.collect.Sets;
|
|
||||||
import com.google.common.collect.Sets.SetView;
|
|
||||||
import com.rits.cloning.Cloner;
|
|
||||||
|
|
||||||
import de.dhbwstuttgart.logger.Logger;
|
import de.dhbwstuttgart.logger.Logger;
|
||||||
import de.dhbwstuttgart.logger.Section;
|
import de.dhbwstuttgart.logger.Section;
|
||||||
import de.dhbwstuttgart.logger.SectionLogger;
|
import de.dhbwstuttgart.logger.SectionLogger;
|
||||||
import de.dhbwstuttgart.logger.Timestamp;
|
|
||||||
import de.dhbwstuttgart.logger.Timewatch;
|
|
||||||
import de.dhbwstuttgart.core.MyCompiler;
|
import de.dhbwstuttgart.core.MyCompiler;
|
||||||
import de.dhbwstuttgart.myexception.CTypeReconstructionException;
|
import de.dhbwstuttgart.myexception.CTypeReconstructionException;
|
||||||
import de.dhbwstuttgart.myexception.MatchException;
|
import de.dhbwstuttgart.myexception.MatchException;
|
||||||
@ -44,19 +30,16 @@ import de.dhbwstuttgart.syntaxtree.type.Type;
|
|||||||
import de.dhbwstuttgart.syntaxtree.type.ObjectType;
|
import de.dhbwstuttgart.syntaxtree.type.ObjectType;
|
||||||
import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder;
|
import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder;
|
||||||
import de.dhbwstuttgart.syntaxtree.type.WildcardType;
|
import de.dhbwstuttgart.syntaxtree.type.WildcardType;
|
||||||
import de.dhbwstuttgart.typeinference.ConstraintsSet;
|
import de.dhbwstuttgart.typeinference.Menge;
|
||||||
import de.dhbwstuttgart.typeinference.DeepCloneable;
|
|
||||||
import de.dhbwstuttgart.typeinference.OderConstraint;
|
|
||||||
import de.dhbwstuttgart.typeinference.Pair;
|
import de.dhbwstuttgart.typeinference.Pair;
|
||||||
import de.dhbwstuttgart.typeinference.Pair.PairOperator;
|
import de.dhbwstuttgart.typeinference.Pair.PairOperator;
|
||||||
import de.dhbwstuttgart.typeinference.UndConstraint;
|
|
||||||
|
|
||||||
// ino.end
|
// ino.end
|
||||||
|
|
||||||
// ino.class.Unify.28049.description type=javadoc
|
// ino.class.Unify.28049.description type=javadoc
|
||||||
/**
|
/**
|
||||||
* Implementierung des Unifizierungsalgorithmus
|
* Implementierung des Unifizierungsalgorithmus
|
||||||
* @author Martin Pl�micke, Thomas Ott
|
* @author Martin Pl<EFBFBD>micke, Thomas Ott
|
||||||
* @version $Date: 2013/05/22 22:23:50 $
|
* @version $Date: 2013/05/22 22:23:50 $
|
||||||
*/
|
*/
|
||||||
// ino.end
|
// ino.end
|
||||||
@ -67,7 +50,7 @@ public class Unify
|
|||||||
{
|
{
|
||||||
|
|
||||||
// ino.attribute.inferencelog.28052.declaration
|
// ino.attribute.inferencelog.28052.declaration
|
||||||
protected static SectionLogger inferencelog = Logger.getSectionLogger(Unify.class.getName(), Section.UNIFY);
|
protected static SectionLogger inferencelog = Logger.getSectionLogger("inference", Section.UNIFY);
|
||||||
// ino.end
|
// ino.end
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -126,21 +109,13 @@ public class Unify
|
|||||||
* Entweder alle Elemente in solved Form [A =. type, B =. type2, ...]
|
* Entweder alle Elemente in solved Form [A =. type, B =. type2, ...]
|
||||||
* oder alle Elemente in der Form [A <. B, C <. D, ..., E <? F, G <? H, .... I =. type, J =. type2, ...]
|
* oder alle Elemente in der Form [A <. B, C <. D, ..., E <? F, G <? H, .... I =. type, J =. type2, ...]
|
||||||
* oder [] = fail
|
* oder [] = fail
|
||||||
* Für den Argumenttype FunN<...> in Typ A<FunN<...> ...> werden keine ? extends-, ? super-Typen erzeugt
|
* F<EFBFBD>r den Argumenttype FunN<...> in Typ A<FunN<...> ...> werden keine ? extends-, ? super-Typen erzeugt
|
||||||
*/
|
*/
|
||||||
|
//public static Menge<Menge<Pair>> unifyWC (Menge<Pair> E, FC_TTO fc_tto)
|
||||||
public static Menge<Menge<Pair>> unify (Menge<Pair> E, FC_TTO fc_tto)
|
public static Menge<Menge<Pair>> unify (Menge<Pair> E, FC_TTO fc_tto)
|
||||||
{
|
{
|
||||||
return unifyFiltered(E, fc_tto,true);
|
|
||||||
}
|
|
||||||
|
|
||||||
//public static Menge<Menge<Pair>> unifyWC (Menge<Pair> E, FC_TTO fc_tto)
|
|
||||||
public static Menge<Menge<Pair>> unifyFiltered (Menge<Pair> E, FC_TTO fc_tto, boolean filter)
|
|
||||||
{
|
|
||||||
SectionLogger log = Logger.getSectionLogger(Unify.class.getName(), Section.UNIFY);
|
|
||||||
|
|
||||||
//Schritt 1: Aufrufen der Regeln durch sub_unify.
|
//Schritt 1: Aufrufen der Regeln durch sub_unify.
|
||||||
Menge<Pair> Eq = sub_unify(E,fc_tto);
|
Menge<Pair> Eq = sub_unify(E,fc_tto);
|
||||||
log.debug("Eq Set nach Schritt 1: "+Eq);
|
|
||||||
/* Schritt 2: Rausfiltern der Typen die entweder beides Typvariablen sind oder nicht.
|
/* Schritt 2: Rausfiltern der Typen die entweder beides Typvariablen sind oder nicht.
|
||||||
* Sobald ein Paar auftauch, bei denen kein Typ mehr eine Typvariable ist, kann dieses Paar
|
* Sobald ein Paar auftauch, bei denen kein Typ mehr eine Typvariable ist, kann dieses Paar
|
||||||
* nicht mehr unifiziert werden, deshalb abbruch.*/
|
* nicht mehr unifiziert werden, deshalb abbruch.*/
|
||||||
@ -153,7 +128,7 @@ public class Unify
|
|||||||
}
|
}
|
||||||
else if(!(p.TA1 instanceof TypePlaceholder) && !(p.TA2 instanceof TypePlaceholder))
|
else if(!(p.TA1 instanceof TypePlaceholder) && !(p.TA2 instanceof TypePlaceholder))
|
||||||
{
|
{
|
||||||
//Diese Paare können nicht mehr Unifiziert werden. fail.
|
//Diese Paare k<EFBFBD>nnen nicht mehr Unifiziert werden. fail.
|
||||||
inferencelog.debug("UNIFY FAIL:" + p.TA1 + " <. " + p.TA2 + " muesste mindestens einen TPH enthalten.");
|
inferencelog.debug("UNIFY FAIL:" + p.TA1 + " <. " + p.TA2 + " muesste mindestens einen TPH enthalten.");
|
||||||
return new Menge<Menge<Pair>>();
|
return new Menge<Menge<Pair>>();
|
||||||
}
|
}
|
||||||
@ -165,8 +140,8 @@ public class Unify
|
|||||||
if(!Eq1.contains(p))
|
if(!Eq1.contains(p))
|
||||||
Eq2.add(p);
|
Eq2.add(p);
|
||||||
}
|
}
|
||||||
/* Schritt 4, Teil 1: Einsammeln der Sets für das Kartesiche Produkt.
|
/* Schritt 4, Teil 1: Einsammeln der Sets f<EFBFBD>r das Kartesiche Produkt.
|
||||||
* Hier werden die Paare verglichen. Je nach Struktur können neue Paare erzeugt
|
* Hier werden die Paare verglichen. Je nach Struktur k<EFBFBD>nnen neue Paare erzeugt
|
||||||
* werden, aus denen dann das kartesische Produkt gebildet wird.*/
|
* werden, aus denen dann das kartesische Produkt gebildet wird.*/
|
||||||
Menge<Menge<Menge<Pair>>> cartProduktSets = new Menge<Menge<Menge<Pair>>>();
|
Menge<Menge<Menge<Pair>>> cartProduktSets = new Menge<Menge<Menge<Pair>>>();
|
||||||
for(Pair p : Eq2)
|
for(Pair p : Eq2)
|
||||||
@ -178,7 +153,7 @@ public class Unify
|
|||||||
p.TA2 = ((SuperWildcardType)p.TA2).get_SuperType();
|
p.TA2 = ((SuperWildcardType)p.TA2).get_SuperType();
|
||||||
//HIER GIBT ES EIN PROBLEM, WENN get_SuperType ein TPH LIEFERT PL 15-03-12
|
//HIER GIBT ES EIN PROBLEM, WENN get_SuperType ein TPH LIEFERT PL 15-03-12
|
||||||
//Dann ist THP <. TPH in Eq2 anstatt in Eq1
|
//Dann ist THP <. TPH in Eq2 anstatt in Eq1
|
||||||
//Muesste mit folgendem if gelöst sein. PL 15-03-17
|
//Muesste mit folgendem if gel<EFBFBD>st sein. PL 15-03-17
|
||||||
if (p.TA2 instanceof TypePlaceholder) {
|
if (p.TA2 instanceof TypePlaceholder) {
|
||||||
Eq1.addElement(p);
|
Eq1.addElement(p);
|
||||||
// Eq2.remove(p);
|
// Eq2.remove(p);
|
||||||
@ -229,7 +204,7 @@ public class Unify
|
|||||||
unifyErgs.add(unifyErgsElement.firstElement());
|
unifyErgs.add(unifyErgsElement.firstElement());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Nach dem Unifizieren wird das Ergebnis überprüft, und evtl. durch die FC entstandene TPHs werden gelöscht.
|
// Nach dem Unifizieren wird das Ergebnis <EFBFBD>berpr<EFBFBD>ft, und evtl. durch die FC entstandene TPHs werden gel<EFBFBD>scht.
|
||||||
if((p_fc.TA2 instanceof RefType && !unifyErgs.isEmpty())
|
if((p_fc.TA2 instanceof RefType && !unifyErgs.isEmpty())
|
||||||
|| p_fc.TA2.equals(p_TA2)) //Bedingung fuer Reflexifitaet BRAURHT MAN VERMUTLIRH NIRHT PL 07-08-05
|
|| p_fc.TA2.equals(p_TA2)) //Bedingung fuer Reflexifitaet BRAURHT MAN VERMUTLIRH NIRHT PL 07-08-05
|
||||||
{
|
{
|
||||||
@ -328,7 +303,7 @@ public class Unify
|
|||||||
}
|
}
|
||||||
else if(p.OperatorSmaller() && p.TA2 instanceof GenericTypeVar)
|
else if(p.OperatorSmaller() && p.TA2 instanceof GenericTypeVar)
|
||||||
{
|
{
|
||||||
//Paar unverändert lassen, wenn eine GenericTypeVar ist
|
//Paar unver<EFBFBD>ndert lassen, wenn eine GenericTypeVar ist
|
||||||
Menge<Menge<Pair>> setofsetofpairs = new Menge<Menge<Pair>>();
|
Menge<Menge<Pair>> setofsetofpairs = new Menge<Menge<Pair>>();
|
||||||
Menge<Pair> vTmp = new Menge<Pair>();
|
Menge<Pair> vTmp = new Menge<Pair>();
|
||||||
vTmp.add(p);
|
vTmp.add(p);
|
||||||
@ -370,7 +345,7 @@ public class Unify
|
|||||||
unifyErgs.add(unifyErgsElement.firstElement());
|
unifyErgs.add(unifyErgsElement.firstElement());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//Nach dem Unifizieren wird das Ergebnis überprüft, und evtl. durch die FC entstandene TPHs werden gelöscht.
|
//Nach dem Unifizieren wird das Ergebnis <EFBFBD>berpr<EFBFBD>ft, und evtl. durch die FC entstandene TPHs werden gel<EFBFBD>scht.
|
||||||
if((p_fc.TA2 instanceof RefType && !unifyErgs.isEmpty())
|
if((p_fc.TA2 instanceof RefType && !unifyErgs.isEmpty())
|
||||||
|| p_fc.TA2.equals(p_TA2)) //Bedingung fuer Reflexifitaet BRAURHT MAN VERMUTLIRH NIRHT PL 07-08-05
|
|| p_fc.TA2.equals(p_TA2)) //Bedingung fuer Reflexifitaet BRAURHT MAN VERMUTLIRH NIRHT PL 07-08-05
|
||||||
{
|
{
|
||||||
@ -545,7 +520,7 @@ public class Unify
|
|||||||
unifyErgs.add(unifyErgsElement.firstElement());
|
unifyErgs.add(unifyErgsElement.firstElement());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Nach dem Unifizieren wird das Ergebnis überprüft, und evtl. durch die FC entstandene TPHs werden gelöscht.
|
// Nach dem Unifizieren wird das Ergebnis <EFBFBD>berpr<EFBFBD>ft, und evtl. durch die FC entstandene TPHs werden gel<EFBFBD>scht.
|
||||||
if((p_fc.TA2 instanceof RefType && !unifyErgs.isEmpty())
|
if((p_fc.TA2 instanceof RefType && !unifyErgs.isEmpty())
|
||||||
|| p_fc.TA2.equals(p_TA1)) //Bedingung fuer Reflexifitaet BRAURHT MAN VERMUTLIRH NIRHT PL 07-08-05
|
|| p_fc.TA2.equals(p_TA1)) //Bedingung fuer Reflexifitaet BRAURHT MAN VERMUTLIRH NIRHT PL 07-08-05
|
||||||
{
|
{
|
||||||
@ -644,91 +619,8 @@ public class Unify
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
//Schritt 4, Teil 2: Kartesisches Produkt bilden.
|
//Schritt 4, Teil 2: Kartesisches Produkt bilden.
|
||||||
log.debug("Unify Sets nach Schritt 4 vor dem Erstellen des Karthesischen Produkts: "+cartProduktSets);
|
//TODO: Vor der Bildung des Karthesischen Produkts unm<EFBFBD>gliche Kombinationen ausfiltern
|
||||||
/*
|
//Hier wird aus den in Schritt 4, Teil 1 erzeugten Vektoren das Kartesische Produkt gebilden.
|
||||||
//TODO: Vor der Bildung des Karthesischen Produkts unmögliche Kombinationen ausfiltern
|
|
||||||
//cartProduktSets kontrollieren:
|
|
||||||
ConstraintsSet cSet = new ConstraintsSet();
|
|
||||||
UndConstraint eq1cons = new UndConstraint();
|
|
||||||
for(Pair p : Eq1){
|
|
||||||
eq1cons.addConstraint(p.TA1, p.TA2);
|
|
||||||
}
|
|
||||||
cSet.add(eq1cons);
|
|
||||||
for(Menge<Menge<Pair>> vecvecpair : cartProduktSets){
|
|
||||||
OderConstraint orConstraints = new OderConstraint();
|
|
||||||
for(Menge<Pair> pairs : vecvecpair){
|
|
||||||
UndConstraint uCons = new UndConstraint();
|
|
||||||
for(Pair p : pairs){
|
|
||||||
uCons.addConstraint(p.TA1, p.TA2);
|
|
||||||
}
|
|
||||||
orConstraints.addConstraint(uCons);
|
|
||||||
}
|
|
||||||
cSet.add(orConstraints);
|
|
||||||
}
|
|
||||||
|
|
||||||
Menge<Menge<Pair>> bigCartProductErg3 = cSet.cartesianProduct();
|
|
||||||
if(filter)log.debug("Karthesisches Produkt nach Filterung: "+bigCartProductErg3);
|
|
||||||
Sets.cartesianProduct(bigCartProductErg3);
|
|
||||||
*/
|
|
||||||
|
|
||||||
if(filter){
|
|
||||||
//Cloner cloner = new Cloner();
|
|
||||||
Menge<Menge<Menge<Pair>>> temp = new Menge<>(); //hier werden gefilterte Constraints gesammelt
|
|
||||||
Menge<Pair> undMenge = new Menge<Pair>(); //Die Menge von Pairs, welche in jedem Kartesischen Produkt enthalten sind.
|
|
||||||
//undMenge.addAll(cloner.deepClone(Eq1));
|
|
||||||
undMenge.addAll(Unify.deepClone(Eq1));
|
|
||||||
Menge<Menge<Menge<Pair>>> oderConstraints = new Menge<>();//Die zu filternden Constraints
|
|
||||||
for (Menge<Menge<Pair>> vecvecpair : cartProduktSets){
|
|
||||||
if(vecvecpair.size() == 1){//gibt es nur eine UndMenge in diesem Set, dann kommt diese in jedem Karthesischen Produkt vor:
|
|
||||||
//undMenge.addAll(cloner.deepClone(vecvecpair.firstElement()));
|
|
||||||
undMenge.addAll(Unify.deepClone(vecvecpair.firstElement()));
|
|
||||||
temp.add(vecvecpair);
|
|
||||||
}else{//gibt es mehrere Mengen, kann gefiltert werden:
|
|
||||||
oderConstraints.add(vecvecpair); //die Menge zu den zu filternden OderConstraints anfügen
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//Filtere die OderConstraints:
|
|
||||||
for(Menge<Menge<Pair>> oderConstraint : oderConstraints){
|
|
||||||
Menge<Menge<Pair>> filteredOCons = new Menge<>(); //diese Menge sammelt nur Cons
|
|
||||||
for(Menge<Pair> pairs : oderConstraint){
|
|
||||||
Menge<Pair> testMenge = new Menge<Pair>();
|
|
||||||
//testMenge.addAll(cloner.deepClone(undMenge));
|
|
||||||
//testMenge.addAll(cloner.deepClone(pairs));
|
|
||||||
testMenge.addAll(Unify.deepClone(undMenge));
|
|
||||||
testMenge.addAll(Unify.deepClone(pairs));
|
|
||||||
Menge<Menge<Pair>> test = Unify.unifyFiltered(testMenge, fc_tto, false);
|
|
||||||
if(test.size()>0){
|
|
||||||
filteredOCons.add(pairs);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
log.debug("Ausgesondertes Constraint: "+pairs);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
temp.add(filteredOCons);
|
|
||||||
}
|
|
||||||
SetView<Menge<Menge<Pair>>> difference = Sets.difference(cartProduktSets, temp);
|
|
||||||
log.debug("Ausgelöschte Constraints: "+difference.toString());
|
|
||||||
cartProduktSets = temp;
|
|
||||||
/*
|
|
||||||
Unifier filterUnify = (pairs)->{
|
|
||||||
String pairsString = pairs.toString();
|
|
||||||
Menge<Menge<Pair>> retValue = new Menge<>();
|
|
||||||
retValue = Unify.unifyFiltered(pairs,fc_tto,false);
|
|
||||||
//Unify.unify(pairs, fc_tto, (i)->{});
|
|
||||||
log.debug("Filtere Constraints:\n"+pairsString);
|
|
||||||
log.debug("Ergebnis: "+ retValue);
|
|
||||||
return retValue;
|
|
||||||
};
|
|
||||||
|
|
||||||
log.debug("Filtere mithilfe von 'filterWrongConstraints': "+cSet);
|
|
||||||
cSet.filterWrongConstraints(filterUnify);
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
//*/
|
|
||||||
|
|
||||||
///* Altes Karthesisches Produkt: Auskommentiert durch Andreas Stadelmeier
|
|
||||||
//Hier wird aus den in Schritt 4, Teil 1 erzeugten Vektoren das Kartesische Produkt gebildet.
|
|
||||||
Menge<Pair> helpvp;
|
Menge<Pair> helpvp;
|
||||||
Menge<Menge<Pair>> bigCartProductErg = new Menge<Menge<Pair>>();
|
Menge<Menge<Pair>> bigCartProductErg = new Menge<Menge<Pair>>();
|
||||||
bigCartProductErg.addElement(copyMengePair(Eq1));
|
bigCartProductErg.addElement(copyMengePair(Eq1));
|
||||||
@ -748,32 +640,12 @@ public class Unify
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
if(! bigCartProductErg.equals(bigCartProductErg3)){
|
|
||||||
for(int i = 0; i<bigCartProductErg3.size();i++){
|
|
||||||
if(! (bigCartProductErg.get(i).equals(bigCartProductErg3.get(i)))){
|
|
||||||
System.out.println();
|
|
||||||
//TODO: Hier testen, wo der Unterschied zwischen den beiden Karthesischen Produkten ist
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
//*/
|
|
||||||
|
|
||||||
//Schritt 5: Einsetzen der Subst Regel
|
//Schritt 5: Einsetzen der Subst Regel
|
||||||
//Hier werden die TPHs substituiert, und dann nach geänderten und nicht geänderten Sets sortiert.
|
//Hier werden die TPHs substituiert, und dann nach ge<EFBFBD>nderten und nicht ge<EFBFBD>nderten Sets sortiert.
|
||||||
Menge<Menge<Pair>> changedSets = new Menge<Menge<Pair>>();
|
Menge<Menge<Pair>> changedSets = new Menge<Menge<Pair>>();
|
||||||
Menge<Menge<Pair>> notChangedSets = new Menge<Menge<Pair>>();
|
Menge<Menge<Pair>> notChangedSets = new Menge<Menge<Pair>>();
|
||||||
int counter = 0;
|
|
||||||
for(Menge<Pair> vecpair : bigCartProductErg)
|
for(Menge<Pair> vecpair : bigCartProductErg)
|
||||||
{
|
{
|
||||||
//Klone die Menge vecpair, bevor substituiert wird. Viele Paare sind doppelt referenziert und müssen vor dem Substituieren geklont werden
|
|
||||||
vecpair = vecpair.stream().map(x -> x.clone()).collect(Menge::new, Menge::add, Menge::addAll);
|
|
||||||
|
|
||||||
counter++;
|
|
||||||
if(counter > 1000){
|
|
||||||
System.out.println(counter + " von "+bigCartProductErg.size());
|
|
||||||
}
|
|
||||||
boolean change = false; //eingefuegt PL 13-05-22
|
boolean change = false; //eingefuegt PL 13-05-22
|
||||||
Pair substPair = null;
|
Pair substPair = null;
|
||||||
do
|
do
|
||||||
@ -823,29 +695,29 @@ public class Unify
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Eq2Set ist das eigentliche Ergebnis, dass zurückgegeben wird.
|
//Eq2Set ist das eigentliche Ergebnis, dass zur<EFBFBD>ckgegeben wird.
|
||||||
Menge<Menge<Pair>> Eq2Set = new Menge<Menge<Pair>>();
|
Menge<Menge<Pair>> Eq2Set = new Menge<Menge<Pair>>();
|
||||||
|
|
||||||
//Schritt 6A: Beginnen mit Schritt 1 bei den geänderten.
|
//Schritt 6A: Beginnen mit Schritt 1 bei den ge<EFBFBD>nderten.
|
||||||
for(Menge<Pair> vecpair : changedSets)
|
for(Menge<Pair> vecpair : changedSets)
|
||||||
{
|
{
|
||||||
Menge<Menge<Pair>> unifyErgs = unify(vecpair,fc_tto);
|
Menge<Menge<Pair>> unifyErgs = unify(vecpair,fc_tto);
|
||||||
//Die Ergebnissvektoren sind schon im Schritt 7 von dem Rekursiven Aufruf geprüft worden. Sie können direkt eingefügt werden.
|
//Die Ergebnissvektoren sind schon im Schritt 7 von dem Rekursiven Aufruf gepr<EFBFBD>ft worden. Sie k<EFBFBD>nnen direkt eingef<EFBFBD>gt werden.
|
||||||
Eq2Set.addAll(unifyErgs);
|
Eq2Set.addAll(unifyErgs);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Schritt 6B Einfügen der nicht geänderten.
|
//Schritt 6B Einf<EFBFBD>gen der nicht ge<EFBFBD>nderten.
|
||||||
//Schritt 7: Aussortieren der falschen Sets
|
//Schritt 7: Aussortieren der falschen Sets
|
||||||
/*
|
/*
|
||||||
* Durch die Rekursion in Schritt 6A sind die Ergebnisse, welche in 6A dazukommen auf jeden Fall korrekt.
|
* Durch die Rekursion in Schritt 6A sind die Ergebnisse, welche in 6A dazukommen auf jeden Fall korrekt.
|
||||||
* Es müssen nur die Ergebnisse aus 6B geprüft werden.
|
* Es m<EFBFBD>ssen nur die Ergebnisse aus 6B gepr<EFBFBD>ft werden.
|
||||||
*/
|
*/
|
||||||
for(Menge<Pair> vecpair : notChangedSets)
|
for(Menge<Pair> vecpair : notChangedSets)
|
||||||
{
|
{
|
||||||
//Ãberprüfen ob Menge in SolvedForm ist.
|
//<EFBFBD>berpr<EFBFBD>fen ob Menge in SolvedForm ist.
|
||||||
if(hasSolvedForm(vecpair)) //PL 13-05-22 hasSolvedForm angepasst
|
if(hasSolvedForm(vecpair)) //PL 13-05-22 hasSolvedForm angepasst
|
||||||
{
|
{
|
||||||
//Ãberprüfung auf FreshTypeVars in den Typen
|
//<EFBFBD>berpr<EFBFBD>fung auf FreshTypeVars in den Typen
|
||||||
boolean foundFresh = false;
|
boolean foundFresh = false;
|
||||||
for(Pair p : vecpair)
|
for(Pair p : vecpair)
|
||||||
{
|
{
|
||||||
@ -863,14 +735,14 @@ public class Unify
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Ergebnis zurückgeben.
|
//Ergebnis zur<EFBFBD>ckgeben.
|
||||||
return Eq2Set;
|
return Eq2Set;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* PL 2014-10-25
|
* PL 2014-10-25
|
||||||
* schnitt1 checkt ob die Typeplaceholders aus in den Elemeneten aus vars enthalten sind
|
* schnitt1 checkt ob die Typeplaceholders aus in den Elemeneten aus vars enthalten sind
|
||||||
* Rückgabe ist die Menge der Indizies von vars der Schnittmengen mit var nicht leer sind.
|
* R<EFBFBD>ckgabe ist die Menge der Indizies von vars der Schnittmengen mit var nicht leer sind.
|
||||||
* @param var
|
* @param var
|
||||||
* @param vars
|
* @param vars
|
||||||
* @param indexe
|
* @param indexe
|
||||||
@ -921,10 +793,10 @@ public class Unify
|
|||||||
* Beispiel: unifyERgs = [[a = Integer, b = Number ]], test = Menge<a>
|
* Beispiel: unifyERgs = [[a = Integer, b = Number ]], test = Menge<a>
|
||||||
* In diesm fall wird b = Number aus dem Menge entfernt.
|
* In diesm fall wird b = Number aus dem Menge entfernt.
|
||||||
*
|
*
|
||||||
* Durch das Entfernen entstehen evtl. Identische Mengeen, diese werden auch gelöscht.
|
* Durch das Entfernen entstehen evtl. Identische Mengeen, diese werden auch gel<EFBFBD>scht.
|
||||||
*
|
*
|
||||||
* @param unifyErgs - Ergebnisse des Unify, die geprüft werden sollen.
|
* @param unifyErgs - Ergebnisse des Unify, die gepr<EFBFBD>ft werden sollen.
|
||||||
* @param test - RefType gegen den geprüft werden soll.
|
* @param test - RefType gegen den gepr<EFBFBD>ft werden soll.
|
||||||
*/
|
*/
|
||||||
private static void testUnifyErg(Menge<Menge<Pair>> unifyErgs, RefType test)
|
private static void testUnifyErg(Menge<Menge<Pair>> unifyErgs, RefType test)
|
||||||
{
|
{
|
||||||
@ -938,7 +810,7 @@ public class Unify
|
|||||||
vec--;
|
vec--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//Gleiche Mengeen löschen
|
//Gleiche Mengeen l<EFBFBD>schen
|
||||||
for(int i = 0; i < unifyErgs.size(); i++)
|
for(int i = 0; i < unifyErgs.size(); i++)
|
||||||
{
|
{
|
||||||
Menge<Pair> p1 = unifyErgs.elementAt(i);
|
Menge<Pair> p1 = unifyErgs.elementAt(i);
|
||||||
@ -967,13 +839,13 @@ public class Unify
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Diese Methode generiert einen Menge<Menge<Pair>> wobei immer der übergebene TA1 vorne steht, und jeder Typ aus otherPairTypes hinten.
|
* Diese Methode generiert einen Menge<Menge<Pair>> wobei immer der <EFBFBD>bergebene TA1 vorne steht, und jeder Typ aus otherPairTypes hinten.
|
||||||
* Beispiel: otherPairTypes = [Integer, Number, Menge<Integer>], TA1 = TPH a.
|
* Beispiel: otherPairTypes = [Integer, Number, Menge<Integer>], TA1 = TPH a.
|
||||||
* return: [[TPH a = Integer],[TPH a = Number],[TPH a = Menge<Integer>]]
|
* return: [[TPH a = Integer],[TPH a = Number],[TPH a = Menge<Integer>]]
|
||||||
*
|
*
|
||||||
* @param TA1 - Der Typ der immer vorne steht
|
* @param TA1 - Der Typ der immer vorne steht
|
||||||
* @param otherPairTypes - Die anderen Typen
|
* @param otherPairTypes - Die anderen Typen
|
||||||
* @return - Ein Menge<Menge<Pair>> der alle Paare enthält.
|
* @return - Ein Menge<Menge<Pair>> der alle Paare enth<EFBFBD>lt.
|
||||||
*/
|
*/
|
||||||
private static Menge<Menge<Pair>> generateSetOfSetOfPair(Type TA1, Menge<? extends Type> otherPairTypes)
|
private static Menge<Menge<Pair>> generateSetOfSetOfPair(Type TA1, Menge<? extends Type> otherPairTypes)
|
||||||
{
|
{
|
||||||
@ -1074,7 +946,7 @@ public class Unify
|
|||||||
//Menge wird geclont, Elemente nicht
|
//Menge wird geclont, Elemente nicht
|
||||||
//Menge<RefType> Mub = (Menge<RefType>)ub.clone();
|
//Menge<RefType> Mub = (Menge<RefType>)ub.clone();
|
||||||
|
|
||||||
//Elemente die nicht kleinste obere Schranken sind, werden gel�scht
|
//Elemente die nicht kleinste obere Schranken sind, werden gel<EFBFBD>scht
|
||||||
//FUNKTIONIERT NICHT. SIEHE iftest.java PL 08-08-13
|
//FUNKTIONIERT NICHT. SIEHE iftest.java PL 08-08-13
|
||||||
for (int i = 0; i < ub.size(); i++) {
|
for (int i = 0; i < ub.size(); i++) {
|
||||||
for (int j = 0; j < ub.size(); j++) {
|
for (int j = 0; j < ub.size(); j++) {
|
||||||
@ -1130,7 +1002,7 @@ throws MatchException
|
|||||||
// ino.method.match.28064.body
|
// ino.method.match.28064.body
|
||||||
{
|
{
|
||||||
//PL 05-01-22
|
//PL 05-01-22
|
||||||
//gibt eine Substitution zur�ck, die den Variablen aus FCtype
|
//gibt eine Substitution zur<EFBFBD>ck, die den Variablen aus FCtype
|
||||||
//die Typterme aus tomatch zu ordnet. Es wird davon ausgegangen, dass
|
//die Typterme aus tomatch zu ordnet. Es wird davon ausgegangen, dass
|
||||||
//FCtype gegen tomatch gematcht werden kann.
|
//FCtype gegen tomatch gematcht werden kann.
|
||||||
if (FCtype.getTypeName().equals(tomatch.getTypeName())) {
|
if (FCtype.getTypeName().equals(tomatch.getTypeName())) {
|
||||||
@ -1174,7 +1046,7 @@ throws MatchException
|
|||||||
// ino.method.sub_unify.28067.body
|
// ino.method.sub_unify.28067.body
|
||||||
{
|
{
|
||||||
//PL 05-01-21 umbenannt in sub_unify
|
//PL 05-01-21 umbenannt in sub_unify
|
||||||
//Luar boolean useSubst hinzugefügt, um bei bedarf zu Steuern ob Subst Regel angewendet wird oder nicht.
|
//Luar boolean useSubst hinzugef<EFBFBD>gt, um bei bedarf zu Steuern ob Subst Regel angewendet wird oder nicht.
|
||||||
// otth: Unifikation - Versuch 1 :-)
|
// otth: Unifikation - Versuch 1 :-)
|
||||||
|
|
||||||
//Menge FC = fc_tto.getFC();
|
//Menge FC = fc_tto.getFC();
|
||||||
@ -1199,7 +1071,7 @@ throws MatchException
|
|||||||
inferencelog.debug("Ausgewaehltes Paar = " + P.toString() + "");
|
inferencelog.debug("Ausgewaehltes Paar = " + P.toString() + "");
|
||||||
inferencelog.debug( "--------------------------------------------------");
|
inferencelog.debug( "--------------------------------------------------");
|
||||||
|
|
||||||
// Bei allen Erase erfolgt keine Kopie nach H, dadurch wird das Pair gelöscht.
|
// Bei allen Erase erfolgt keine Kopie nach H, dadurch wird das Pair gel<EFBFBD>scht.
|
||||||
//ERASE3
|
//ERASE3
|
||||||
if( P.isEqual() && P.OperatorEqual() )
|
if( P.isEqual() && P.OperatorEqual() )
|
||||||
{
|
{
|
||||||
@ -1321,13 +1193,13 @@ throws MatchException
|
|||||||
}
|
}
|
||||||
catch( SCException Ex )
|
catch( SCException Ex )
|
||||||
{
|
{
|
||||||
inferencelog.debug("---- Unifikation nicht m�glich: Permutation fehlgeschlagen!");
|
inferencelog.debug("---- Unifikation nicht m<EFBFBD>glich: Permutation fehlgeschlagen!");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
inferencelog.info("---- Unifikation nicht m�glich: Anzahl der Parameter verschieden!");
|
inferencelog.info("---- Unifikation nicht m<EFBFBD>glich: Anzahl der Parameter verschieden!");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1378,13 +1250,13 @@ throws MatchException
|
|||||||
}
|
}
|
||||||
catch( SCException Ex )
|
catch( SCException Ex )
|
||||||
{
|
{
|
||||||
inferencelog.debug("---- Unifikation nicht m�glich: Permutation fehlgeschlagen!");
|
inferencelog.debug("---- Unifikation nicht m<EFBFBD>glich: Permutation fehlgeschlagen!");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
inferencelog.info("---- Unifikation nicht m�glich: Anzahl der Parameter verschieden!");
|
inferencelog.info("---- Unifikation nicht m<EFBFBD>glich: Anzahl der Parameter verschieden!");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1455,7 +1327,7 @@ throws MatchException
|
|||||||
|
|
||||||
RefType TA1 = null;
|
RefType TA1 = null;
|
||||||
RefType TA2 = null;
|
RefType TA2 = null;
|
||||||
//Hier werden die RefTypes gefüllt.
|
//Hier werden die RefTypes gef<EFBFBD>llt.
|
||||||
if(P.TA1 instanceof RefType && P.TA2 instanceof RefType)
|
if(P.TA1 instanceof RefType && P.TA2 instanceof RefType)
|
||||||
{
|
{
|
||||||
TA1 = (RefType)P.TA1;
|
TA1 = (RefType)P.TA1;
|
||||||
@ -1477,7 +1349,7 @@ throws MatchException
|
|||||||
}
|
}
|
||||||
catch( SCException Ex )
|
catch( SCException Ex )
|
||||||
{
|
{
|
||||||
inferencelog.error("---- Unifikation nicht m�glich: Permutation fehlgeschlagen!");
|
inferencelog.error("---- Unifikation nicht m<EFBFBD>glich: Permutation fehlgeschlagen!");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1510,7 +1382,7 @@ throws MatchException
|
|||||||
}
|
}
|
||||||
catch( SCException Ex )
|
catch( SCException Ex )
|
||||||
{
|
{
|
||||||
inferencelog.debug("---- Unifikation nicht m�glich: Permutation fehlgeschlagen!");
|
inferencelog.debug("---- Unifikation nicht m<EFBFBD>glich: Permutation fehlgeschlagen!");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1530,7 +1402,7 @@ throws MatchException
|
|||||||
}
|
}
|
||||||
catch( SCException Ex )
|
catch( SCException Ex )
|
||||||
{
|
{
|
||||||
inferencelog.error("---- Unifikation nicht m�glich: Permutation fehlgeschlagen!");
|
inferencelog.error("---- Unifikation nicht m<EFBFBD>glich: Permutation fehlgeschlagen!");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1643,7 +1515,7 @@ throws MatchException
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Subst --> noch zu pr�fen
|
// Subst --> noch zu pr<EFBFBD>fen
|
||||||
if( P.TA1 instanceof TypePlaceholder && P.OperatorEqual() && useSubst) //&& P.TA2 instanceof RefType )
|
if( P.TA1 instanceof TypePlaceholder && P.OperatorEqual() && useSubst) //&& P.TA2 instanceof RefType )
|
||||||
//PL 05-02-09 P.TA@ duerfen auch TypePlaceholder sein
|
//PL 05-02-09 P.TA@ duerfen auch TypePlaceholder sein
|
||||||
/* BEISPIEL:
|
/* BEISPIEL:
|
||||||
@ -1797,7 +1669,7 @@ throws MatchException
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Implementiert die reduceEq Regel des sub_unify
|
* Implementiert die reduceEq Regel des sub_unify
|
||||||
* Da in reduce2 unnötigerweise pi verwendet wird (siehe Kommentar in reduce2), kann reduceEq einfach an reduce2 deligieren.
|
* Da in reduce2 unn<EFBFBD>tigerweise pi verwendet wird (siehe Kommentar in reduce2), kann reduceEq einfach an reduce2 deligieren.
|
||||||
*/
|
*/
|
||||||
private static void reduceEq(Menge<Pair> H, RefType TA1, RefType TA2, Menge TTO) throws SCException
|
private static void reduceEq(Menge<Pair> H, RefType TA1, RefType TA2, Menge TTO) throws SCException
|
||||||
{
|
{
|
||||||
@ -1819,11 +1691,11 @@ throws MatchException
|
|||||||
inferencelog.debug("---- Parameteranzahl gleich");
|
inferencelog.debug("---- Parameteranzahl gleich");
|
||||||
inferencelog.debug("---- Reduce !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! (" + L1.size() + ") neue(s) Paar(e)");
|
inferencelog.debug("---- Reduce !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! (" + L1.size() + ") neue(s) Paar(e)");
|
||||||
|
|
||||||
// hier mu� die PERMUTATION erfolgen
|
// hier mu<EFBFBD> die PERMUTATION erfolgen
|
||||||
inferencelog.debug("---- PAARBILDUNG ");
|
inferencelog.debug("---- PAARBILDUNG ");
|
||||||
for( int k = 0; k < L1.size(); k++ )
|
for( int k = 0; k < L1.size(); k++ )
|
||||||
{
|
{
|
||||||
// pi eig. bei reduce2 �berfl�ssig, schadet aber hoff. auch nicht :-)
|
// pi eig. bei reduce2 <EFBFBD>berfl<EFBFBD>ssig, schadet aber hoff. auch nicht :-)
|
||||||
//luar 19-04-2007 durch das pi kann reduce2 auch als reduceEq verwendet werden. Wenn das pi durch k ersetzt wird, muss reduceEq entsprechend ausprogrammiert werden.
|
//luar 19-04-2007 durch das pi kann reduce2 auch als reduceEq verwendet werden. Wenn das pi durch k ersetzt wird, muss reduceEq entsprechend ausprogrammiert werden.
|
||||||
Pair P2 = new Pair( L1.elementAt( pi(k, TA1.getTypeName(), TA2.getTypeName(), TTO ) ), L2.elementAt(k), PairOperator.Equal );
|
Pair P2 = new Pair( L1.elementAt( pi(k, TA1.getTypeName(), TA2.getTypeName(), TTO ) ), L2.elementAt(k), PairOperator.Equal );
|
||||||
inferencelog.debug("---- Paar1: (" + (L1.elementAt( pi(k, TA1.getTypeName(), TA2.getTypeName(), TTO ) )).getName() + ", " + (L2.elementAt(k)).getName() + P2.OperatorEqual() + ")");
|
inferencelog.debug("---- Paar1: (" + (L1.elementAt( pi(k, TA1.getTypeName(), TA2.getTypeName(), TTO ) )).getName() + ", " + (L2.elementAt(k)).getName() + P2.OperatorEqual() + ")");
|
||||||
@ -2122,7 +1994,7 @@ throws MatchException
|
|||||||
//LIEGT
|
//LIEGT
|
||||||
//erlegigt 06-04-28
|
//erlegigt 06-04-28
|
||||||
Menge<Pair> res = sub_unify(subunifypair, fc_tto);
|
Menge<Pair> res = sub_unify(subunifypair, fc_tto);
|
||||||
if (hasSolvedForm(res)) { //PL 13-05-22: hasSolvedForm geaendert, es nicht geklärt, ob es funktioniert.
|
if (hasSolvedForm(res)) { //PL 13-05-22: hasSolvedForm geaendert, es nicht gekl<EFBFBD>rt, ob es funktioniert.
|
||||||
inferencelog.debug("HasSolvedForm: ");
|
inferencelog.debug("HasSolvedForm: ");
|
||||||
printMenge("RES_SMALLER", res, 6);
|
printMenge("RES_SMALLER", res, 6);
|
||||||
ht = MengePair2SubstHashtableMengePair(res);
|
ht = MengePair2SubstHashtableMengePair(res);
|
||||||
@ -2237,27 +2109,6 @@ throws MatchException
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
// ino.end
|
// ino.end
|
||||||
|
|
||||||
/*
|
|
||||||
// ino.method.allGreater.29428.definition
|
|
||||||
public static Menge<RefType> allGreater (BoundedGenericTypeVar ty, Menge<Pair> FC)
|
|
||||||
// ino.end
|
|
||||||
// ino.method.allGreater.29428.body
|
|
||||||
{
|
|
||||||
CRefTypeSet ret = new CRefTypeSet();
|
|
||||||
Iterator<ObjectType> typeIt = ty.getBounds().iterator();
|
|
||||||
while(typeIt.hasNext()) {
|
|
||||||
CRefTypeSet grBounds = new CRefTypeSet();
|
|
||||||
RefType act = (RefType)typeIt.next();
|
|
||||||
grBounds.setMenge(allGreater(act, FC));
|
|
||||||
grBounds.addElement(act);
|
|
||||||
ret.unite(grBounds);
|
|
||||||
}
|
|
||||||
return ret.getMenge();
|
|
||||||
}
|
|
||||||
// ino.end
|
|
||||||
*/
|
|
||||||
|
|
||||||
// ino.method.allGreater.28094.definition
|
// ino.method.allGreater.28094.definition
|
||||||
public static Menge<RefType> allGreater (RefType ty, Menge<Pair> FC)
|
public static Menge<RefType> allGreater (RefType ty, Menge<Pair> FC)
|
||||||
// ino.end
|
// ino.end
|
||||||
@ -2305,7 +2156,7 @@ throws MatchException
|
|||||||
{
|
{
|
||||||
// otth: Funktion, die prueft, ob Paar( R1, R2 ) in FC liegt,
|
// otth: Funktion, die prueft, ob Paar( R1, R2 ) in FC liegt,
|
||||||
// bzw. deren rechten Seiten, ohne die TypePlaceholder-Variablen zu beachten
|
// bzw. deren rechten Seiten, ohne die TypePlaceholder-Variablen zu beachten
|
||||||
// z.B. Menge<A> w�re hier gleich wie Menge<Integer>
|
// z.B. Menge<A> w<EFBFBD>re hier gleich wie Menge<Integer>
|
||||||
|
|
||||||
// z.B. FC = { ( AA<a, b> <=* CC< DD<b, a> > ) ,...}
|
// z.B. FC = { ( AA<a, b> <=* CC< DD<b, a> > ) ,...}
|
||||||
// R1 = AA<Integer, b>
|
// R1 = AA<Integer, b>
|
||||||
@ -2353,7 +2204,7 @@ throws MatchException
|
|||||||
{
|
{
|
||||||
// otth: Funktion, die prueft, ob Paar( R1, \sigma(R2) ) in FC liegt,
|
// otth: Funktion, die prueft, ob Paar( R1, \sigma(R2) ) in FC liegt,
|
||||||
// bzw. deren rechten Seiten, ohne die TypePlaceholders zu beachten
|
// bzw. deren rechten Seiten, ohne die TypePlaceholders zu beachten
|
||||||
// z.B. Menge<A> w�re hier gleich wie Menge<Integer>
|
// z.B. Menge<A> w<EFBFBD>re hier gleich wie Menge<Integer>
|
||||||
|
|
||||||
// z.B. FC = { ( AA<a, b> <=* CC< DD<b, a> > ) ,...}
|
// z.B. FC = { ( AA<a, b> <=* CC< DD<b, a> > ) ,...}
|
||||||
// R1 = AA<Integer, b>
|
// R1 = AA<Integer, b>
|
||||||
@ -2391,7 +2242,7 @@ throws MatchException
|
|||||||
Menge<Pair> vp = sub_unify(R2vec, fc_tto);
|
Menge<Pair> vp = sub_unify(R2vec, fc_tto);
|
||||||
|
|
||||||
printMenge("VP", vp, 6);
|
printMenge("VP", vp, 6);
|
||||||
if ( hasSolvedForm(vp) ) //PL 13-05-22: hasSolvedForm geaendert, es nicht geklärt, ob es funktioniert.
|
if ( hasSolvedForm(vp) ) //PL 13-05-22: hasSolvedForm geaendert, es nicht gekl<EFBFBD>rt, ob es funktioniert.
|
||||||
//if( isRXSimilarRY( RFC, R2 ) )
|
//if( isRXSimilarRY( RFC, R2 ) )
|
||||||
{
|
{
|
||||||
inferencelog.debug("SIMILAR2");
|
inferencelog.debug("SIMILAR2");
|
||||||
@ -2476,18 +2327,6 @@ throws MatchException
|
|||||||
inferencelog.debug("Nummer: " + nTypnrInPair);
|
inferencelog.debug("Nummer: " + nTypnrInPair);
|
||||||
inferencelog.debug("TV: " + a.getName());
|
inferencelog.debug("TV: " + a.getName());
|
||||||
inferencelog.debug("Bedingung: " + bMitVorbedingung);
|
inferencelog.debug("Bedingung: " + bMitVorbedingung);
|
||||||
/*
|
|
||||||
Cloner cloner = new Cloner();
|
|
||||||
cloner.setDumpClonedClasses(true);
|
|
||||||
SectionLogger log = Logger.getSectionLogger("Subst-Methode", Section.UNIFY);
|
|
||||||
Timewatch timer = Timewatch.getTimewatch();
|
|
||||||
de.dhbwstuttgart.logger.Timestamp timestamp = timer.start("Unify-Subst");
|
|
||||||
P = cloner.deepClone(P);
|
|
||||||
a = cloner.deepClone(a);
|
|
||||||
o = cloner.deepClone(o);
|
|
||||||
long time = timestamp.stop();
|
|
||||||
log.debug("Benötigte Zeit für DeepClone: "+time);
|
|
||||||
*/
|
|
||||||
|
|
||||||
// richtiger Typ aus Pair raussuchen
|
// richtiger Typ aus Pair raussuchen
|
||||||
Type T = null;
|
Type T = null;
|
||||||
@ -2500,7 +2339,7 @@ throws MatchException
|
|||||||
if (o instanceof RefType) {//PL 05-02-09 eingefuegt siehe Methodenkopf
|
if (o instanceof RefType) {//PL 05-02-09 eingefuegt siehe Methodenkopf
|
||||||
if( bMitVorbedingung && isTVinRefType( a, (RefType)o ) )
|
if( bMitVorbedingung && isTVinRefType( a, (RefType)o ) )
|
||||||
{
|
{
|
||||||
inferencelog.debug(" Subst nicht m�glich, da TV " + a.getName() + " in RefType " + o.getName());
|
inferencelog.debug(" Subst nicht m<EFBFBD>glich, da TV " + a.getName() + " in RefType " + o.getName());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2510,7 +2349,7 @@ throws MatchException
|
|||||||
{
|
{
|
||||||
// Parameterliste durchgehen
|
// Parameterliste durchgehen
|
||||||
Menge vTemp = ((RefType)T).get_ParaList();
|
Menge vTemp = ((RefType)T).get_ParaList();
|
||||||
boolean ret = true; //EINGEFUEGT PL 14-01-16: Return darf erst am Ende zurückgegeben werden und nicht in den ifs
|
Boolean ret = true; //EINGEFUEGT PL 14-01-16: Return darf erst am Ende zur<EFBFBD>ckgegeben werden und nicht in den ifs
|
||||||
//sonst werden nicht alle Elemente der Forschleife durchlaufen
|
//sonst werden nicht alle Elemente der Forschleife durchlaufen
|
||||||
for( int i = 0; i < vTemp.size(); i++ )
|
for( int i = 0; i < vTemp.size(); i++ )
|
||||||
{
|
{
|
||||||
@ -2556,7 +2395,7 @@ throws MatchException
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//Wildcard ergänzt PL 14-12-05
|
//Wildcard erg<EFBFBD>nzt PL 14-12-05
|
||||||
if ( T instanceof ExtendsWildcardType )
|
if ( T instanceof ExtendsWildcardType )
|
||||||
{
|
{
|
||||||
Type Temp = ((ExtendsWildcardType) T).get_ExtendsType();
|
Type Temp = ((ExtendsWildcardType) T).get_ExtendsType();
|
||||||
@ -2571,7 +2410,7 @@ throws MatchException
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//Wildcard ergänzt PL 14-12-05
|
//Wildcard erg<EFBFBD>nzt PL 14-12-05
|
||||||
if ( T instanceof SuperWildcardType )
|
if ( T instanceof SuperWildcardType )
|
||||||
{
|
{
|
||||||
Type Temp = ((SuperWildcardType) T).get_SuperType();
|
Type Temp = ((SuperWildcardType) T).get_SuperType();
|
||||||
@ -2652,7 +2491,7 @@ throws MatchException
|
|||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
// otth: Funktion pr�ft, ob Klasse 'Basis' von Klasse 'Mutter' direkt oder indirekt abgeleitet ist
|
// otth: Funktion pr<EFBFBD>ft, ob Klasse 'Basis' von Klasse 'Mutter' direkt oder indirekt abgeleitet ist
|
||||||
|
|
||||||
// Basisklasse suchen
|
// Basisklasse suchen
|
||||||
Menge tto = fc_tto.getTTO();
|
Menge tto = fc_tto.getTTO();
|
||||||
@ -2676,9 +2515,9 @@ throws MatchException
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Hier wird überprüft ob in der Paraliste ein anderes Element als ein GTV drinne ist.
|
* Hier wird <EFBFBD>berpr<EFBFBD>ft ob in der Paraliste ein anderes Element als ein GTV drinne ist.
|
||||||
* Sollte ein anderes Element gefunden werden ist Reduce nicht möglich.
|
* Sollte ein anderes Element gefunden werden ist Reduce nicht m<EFBFBD>glich.
|
||||||
* Beispiel: Matrix <. Menge<Menge<Integer>> ist nur durch adapt möglich.
|
* Beispiel: Matrix <. Menge<Menge<Integer>> ist nur durch adapt m<EFBFBD>glich.
|
||||||
*/
|
*/
|
||||||
for(Type t : s)
|
for(Type t : s)
|
||||||
{
|
{
|
||||||
@ -2812,7 +2651,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
if( n >= vD.size() )
|
if( n >= vD.size() )
|
||||||
throw F;
|
throw F;
|
||||||
|
|
||||||
// Permuationswert f�r 'n' berechnen
|
// Permuationswert f<EFBFBD>r 'n' berechnen
|
||||||
Type TV = (Type)vD.elementAt(n);
|
Type TV = (Type)vD.elementAt(n);
|
||||||
|
|
||||||
int nPos = -1;
|
int nPos = -1;
|
||||||
@ -2844,12 +2683,12 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
// ino.method.printMengeUnifier.28121.body
|
// ino.method.printMengeUnifier.28121.body
|
||||||
{
|
{
|
||||||
//PL 05-01-21
|
//PL 05-01-21
|
||||||
//Ruft f�r eine Menge von Unifikatoren die Methode
|
//Ruft f<EFBFBD>r eine Menge von Unifikatoren die Methode
|
||||||
//printMenge auf
|
//printMenge auf
|
||||||
for (int i = 0; i < Uni.size(); i++) {
|
for (int i = 0; i < Uni.size(); i++) {
|
||||||
inferencelog.debug((i+1) + ". Unifier");
|
inferencelog.debug((i+1) + ". Unifier");
|
||||||
printMenge(strMenge, Uni.elementAt(i), nDebug);
|
printMenge(strMenge, Uni.elementAt(i), nDebug);
|
||||||
if( hasSolvedForm( Uni.elementAt(i) ) ) { //PL 13-05-22: hasSolvedForm geaendert, es nicht geklärt, ob es funktioniert.
|
if( hasSolvedForm( Uni.elementAt(i) ) ) { //PL 13-05-22: hasSolvedForm geaendert, es nicht gekl<EFBFBD>rt, ob es funktioniert.
|
||||||
inferencelog.debug((i+1) + ". Unifier ist in 'Solved form'!\n");
|
inferencelog.debug((i+1) + ". Unifier ist in 'Solved form'!\n");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -2876,7 +2715,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
}
|
}
|
||||||
|
|
||||||
for( int tt = 0; tt < E.size(); tt++ ) {
|
for( int tt = 0; tt < E.size(); tt++ ) {
|
||||||
//luar 13-03-07 If Else Block gelöscht, da sinnlos.
|
//luar 13-03-07 If Else Block gel<EFBFBD>scht, da sinnlos.
|
||||||
if( tt > 0 )
|
if( tt > 0 )
|
||||||
strTemp = strTemp + ",\n" + E.elementAt(tt).toString();
|
strTemp = strTemp + ",\n" + E.elementAt(tt).toString();
|
||||||
else
|
else
|
||||||
@ -2969,7 +2808,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Implementiert die CaptureConversion. Wendet diese auf jeden Typ im Menge TVec an.
|
* Implementiert die CaptureConversion. Wendet diese auf jeden Typ im Menge TVec an.
|
||||||
* Rückgabe ist ein ErgebnisMenge
|
* R<EFBFBD>ckgabe ist ein ErgebnisMenge
|
||||||
*/
|
*/
|
||||||
private static Menge<ObjectType> CaptureConversion(Menge<ObjectType> TVec, FC_TTO fc_tto)
|
private static Menge<ObjectType> CaptureConversion(Menge<ObjectType> TVec, FC_TTO fc_tto)
|
||||||
{
|
{
|
||||||
@ -2977,7 +2816,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
for(ObjectType t : TVec)
|
for(ObjectType t : TVec)
|
||||||
{
|
{
|
||||||
ObjectType ccT = (ObjectType)CaptureConversion(t,fc_tto);
|
ObjectType ccT = (ObjectType)CaptureConversion(t,fc_tto);
|
||||||
//CaptureConversion kann nur ObjectTypes zurückliefern, laesst sich aber nicht zurziehen.
|
//CaptureConversion kann nur ObjectTypes zur<EFBFBD>ckliefern, laesst sich aber nicht zurziehen.
|
||||||
if(ccT != null)
|
if(ccT != null)
|
||||||
retVec.add(ccT);
|
retVec.add(ccT);
|
||||||
}
|
}
|
||||||
@ -2987,7 +2826,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
/**
|
/**
|
||||||
* Erzeugt die CaptureConversion von einem Typ.
|
* Erzeugt die CaptureConversion von einem Typ.
|
||||||
*
|
*
|
||||||
* @param T - Ãbergebener Typ, von welchem die CaptureConversion gemacht werden soll.
|
* @param T - <EFBFBD>bergebener Typ, von welchem die CaptureConversion gemacht werden soll.
|
||||||
* @param fc_tto - Hilfsklasse.
|
* @param fc_tto - Hilfsklasse.
|
||||||
* @return - CC(T)
|
* @return - CC(T)
|
||||||
*/
|
*/
|
||||||
@ -3022,7 +2861,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
if(t instanceof WildcardType)
|
if(t instanceof WildcardType)
|
||||||
{
|
{
|
||||||
FreshWildcardType fwcT = ((WildcardType)t).GetFreshWildcardType();
|
FreshWildcardType fwcT = ((WildcardType)t).GetFreshWildcardType();
|
||||||
//Wenn beim Original Typ an der Stelle eine BoundedGenericTypeVar ist werden die Bounds zu der Wildcard hinzugefügt.
|
//Wenn beim Original Typ an der Stelle eine BoundedGenericTypeVar ist werden die Bounds zu der Wildcard hinzugef<EFBFBD>gt.
|
||||||
if(cl.get_ParaList().elementAt(i) instanceof BoundedGenericTypeVar)
|
if(cl.get_ParaList().elementAt(i) instanceof BoundedGenericTypeVar)
|
||||||
{
|
{
|
||||||
BoundedGenericTypeVar bgv = (BoundedGenericTypeVar)cl.get_ParaList().elementAt(i);
|
BoundedGenericTypeVar bgv = (BoundedGenericTypeVar)cl.get_ParaList().elementAt(i);
|
||||||
@ -3036,7 +2875,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
}
|
}
|
||||||
refT.set_ParaList(ccTypes);
|
refT.set_ParaList(ccTypes);
|
||||||
}
|
}
|
||||||
//Wenn eine CaptureConversion durchgeführt wurde den Typ zurückgeben.
|
//Wenn eine CaptureConversion durchgef<EFBFBD>hrt wurde den Typ zur<EFBFBD>ckgeben.
|
||||||
if(ccDone)
|
if(ccDone)
|
||||||
return refT;
|
return refT;
|
||||||
else
|
else
|
||||||
@ -3053,13 +2892,13 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
|
|
||||||
//Von hier an Greater implementierung 28-03-07
|
//Von hier an Greater implementierung 28-03-07
|
||||||
/**
|
/**
|
||||||
* Der Komplette Ablauf von greater und was die einzelnen Teilschritte machen kann anhand von Aktivitätsdiagrammen
|
* Der Komplette Ablauf von greater und was die einzelnen Teilschritte machen kann anhand von Aktivit<EFBFBD>tsdiagrammen
|
||||||
* im Inovator Projekt, oder in der Studienarbeit Arne Lüdtke, 2007 nachgelesen werden.
|
* im Inovator Projekt, oder in der Studienarbeit Arne L<EFBFBD>dtke, 2007 nachgelesen werden.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Erzeugt alle Typen die greater sind als T. Gibt diese zurück.
|
* Erzeugt alle Typen die greater sind als T. Gibt diese zur<EFBFBD>ck.
|
||||||
* Für den Argumenttype FunN<...> in Typ A<FunN<...> ...> werden keine ? extends-, ? super-Typen erzeugt
|
* F<EFBFBD>r den Argumenttype FunN<...> in Typ A<FunN<...> ...> werden keine ? extends-, ? super-Typen erzeugt
|
||||||
*/
|
*/
|
||||||
private static Menge<ObjectType> greater(ObjectType T, FC_TTO fc_tto)
|
private static Menge<ObjectType> greater(ObjectType T, FC_TTO fc_tto)
|
||||||
//an die Aenderungen im Skript anpassen 07-11-03
|
//an die Aenderungen im Skript anpassen 07-11-03
|
||||||
@ -3084,22 +2923,22 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
//greater1 Erzeugen
|
//greater1 Erzeugen
|
||||||
Menge<ObjectType> greater1Erg = greater1(T,fc_tto);
|
Menge<ObjectType> greater1Erg = greater1(T,fc_tto);
|
||||||
|
|
||||||
//Reflexivität, deshalb T hinzufügen.
|
//Reflexivit<EFBFBD>t, deshalb T hinzuf<EFBFBD>gen.
|
||||||
if(!greater1Erg.contains(T))
|
if(!greater1Erg.contains(T))
|
||||||
greater1Erg.add(T);
|
greater1Erg.add(T);
|
||||||
|
|
||||||
//Falls in greater1Erg Typen doppelt vorhanden sind werden diese nicht in retVec übernommen.
|
//Falls in greater1Erg Typen doppelt vorhanden sind werden diese nicht in retVec <EFBFBD>bernommen.
|
||||||
for(ObjectType t : greater1Erg)
|
for(ObjectType t : greater1Erg)
|
||||||
if(!retVec.contains(t))
|
if(!retVec.contains(t))
|
||||||
retVec.add(t);
|
retVec.add(t);
|
||||||
|
|
||||||
//Ergebnis von greater1 an greater2 durchreichen, ERgebnisse in retVec einfügen
|
//Ergebnis von greater1 an greater2 durchreichen, ERgebnisse in retVec einf<EFBFBD>gen
|
||||||
Menge<ObjectType> greater2Erg = greater2(greater1Erg,fc_tto);
|
Menge<ObjectType> greater2Erg = greater2(greater1Erg,fc_tto);
|
||||||
for(ObjectType t : greater2Erg)
|
for(ObjectType t : greater2Erg)
|
||||||
if(!retVec.contains(t))
|
if(!retVec.contains(t))
|
||||||
retVec.add(t);
|
retVec.add(t);
|
||||||
|
|
||||||
//Ergebnis von greater2 an greater3 durchreichen, ERgebnisse in retVec einfügen
|
//Ergebnis von greater2 an greater3 durchreichen, ERgebnisse in retVec einf<EFBFBD>gen
|
||||||
Menge<ObjectType> greater3Erg = greater3(greater2Erg,fc_tto);
|
Menge<ObjectType> greater3Erg = greater3(greater2Erg,fc_tto);
|
||||||
for(ObjectType t : greater3Erg)
|
for(ObjectType t : greater3Erg)
|
||||||
if(!retVec.contains(t))
|
if(!retVec.contains(t))
|
||||||
@ -3110,7 +2949,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* greater1 Schritt von greater.
|
* greater1 Schritt von greater.
|
||||||
* Für den Argumenttype FunN<...> in Typ A<FunN<...> ...> werden keine ? extends-, ? super-Typen erzeugt
|
* F<EFBFBD>r den Argumenttype FunN<...> in Typ A<FunN<...> ...> werden keine ? extends-, ? super-Typen erzeugt
|
||||||
*/
|
*/
|
||||||
private static Menge<ObjectType> greater1(ObjectType T, FC_TTO fc_tto)
|
private static Menge<ObjectType> greater1(ObjectType T, FC_TTO fc_tto)
|
||||||
{
|
{
|
||||||
@ -3148,8 +2987,8 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ãberladung der Funktion cartProductType, damit der Programmierer beim ersten Aufruf nicht den 2. Parameter
|
* <EFBFBD>berladung der Funktion cartProductType, damit der Programmierer beim ersten Aufruf nicht den 2. Parameter
|
||||||
* welcher für die rekursion erforderlich ist mit übergeben muss.
|
* welcher f<EFBFBD>r die rekursion erforderlich ist mit <EFBFBD>bergeben muss.
|
||||||
*/
|
*/
|
||||||
private static Menge<Menge<Type>> cartProductType (Menge<Menge<Type>> vec)
|
private static Menge<Menge<Type>> cartProductType (Menge<Menge<Type>> vec)
|
||||||
{
|
{
|
||||||
@ -3158,7 +2997,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Erzeugt das Kartesische Product von mehreren Mengeen von Typen.
|
* Erzeugt das Kartesische Product von mehreren Mengeen von Typen.
|
||||||
* Für den Startaufruf ist der index = 0. Danach ruft sich cartProductType rekursiv auf.
|
* F<EFBFBD>r den Startaufruf ist der index = 0. Danach ruft sich cartProductType rekursiv auf.
|
||||||
*/
|
*/
|
||||||
private static Menge<Menge<Type>> cartProductType (Menge<Menge<Type>> vec, int index)
|
private static Menge<Menge<Type>> cartProductType (Menge<Menge<Type>> vec, int index)
|
||||||
{
|
{
|
||||||
@ -3193,8 +3032,8 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ãberladung der Funktion cartProductPair, damit der Programmierer beim ersten Aufruf nicht den 2. Parameter
|
* <EFBFBD>berladung der Funktion cartProductPair, damit der Programmierer beim ersten Aufruf nicht den 2. Parameter
|
||||||
* welcher für die rekursion erforderlich ist mit übergeben muss.
|
* welcher f<EFBFBD>r die rekursion erforderlich ist mit <EFBFBD>bergeben muss.
|
||||||
*/
|
*/
|
||||||
private static Menge<Menge<Pair>> cartProductPair (Menge<Menge<Pair>> vec)
|
private static Menge<Menge<Pair>> cartProductPair (Menge<Menge<Pair>> vec)
|
||||||
{
|
{
|
||||||
@ -3203,7 +3042,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Erzeugt das Kartesische Product von mehreren Mengeen von Paaren.
|
* Erzeugt das Kartesische Product von mehreren Mengeen von Paaren.
|
||||||
* Für den Startaufruf ist der index = 0. Danach ruft sich cartProductPair rekursiv auf.
|
* F<EFBFBD>r den Startaufruf ist der index = 0. Danach ruft sich cartProductPair rekursiv auf.
|
||||||
*/
|
*/
|
||||||
private static Menge<Menge<Pair>> cartProductPair (Menge<Menge<Pair>> vec, int index)
|
private static Menge<Menge<Pair>> cartProductPair (Menge<Menge<Pair>> vec, int index)
|
||||||
{
|
{
|
||||||
@ -3263,7 +3102,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* greaterArg Schritt von greater
|
* greaterArg Schritt von greater
|
||||||
* Für den Argumenttype FunN<...> werden keine ? extends-, ? super-Typen erzeugt
|
* F<EFBFBD>r den Argumenttype FunN<...> werden keine ? extends-, ? super-Typen erzeugt
|
||||||
*/
|
*/
|
||||||
private static Menge<Type> greaterArg(Type T, FC_TTO fc_tto)
|
private static Menge<Type> greaterArg(Type T, FC_TTO fc_tto)
|
||||||
{
|
{
|
||||||
@ -3319,7 +3158,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
return new Menge<Type>();
|
return new Menge<Type>();
|
||||||
*/
|
*/
|
||||||
|
|
||||||
//Diese Abfrage sorgt für grArg(a) = {a} //Luar 07-07-31
|
//Diese Abfrage sorgt f<EFBFBD>r grArg(a) = {a} //Luar 07-07-31
|
||||||
else if(T instanceof TypePlaceholder)
|
else if(T instanceof TypePlaceholder)
|
||||||
retVec.add(T);
|
retVec.add(T);
|
||||||
//Diese Abfrage verhindert, dass bei FunN Wildcard-Typen generiert werden //PL 13-05-22
|
//Diese Abfrage verhindert, dass bei FunN Wildcard-Typen generiert werden //PL 13-05-22
|
||||||
@ -3348,7 +3187,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
Menge<ObjectType> retVec = new Menge<ObjectType>();
|
Menge<ObjectType> retVec = new Menge<ObjectType>();
|
||||||
/*
|
/*
|
||||||
* luar 02-05-07: Beschreibung der Funktion:
|
* luar 02-05-07: Beschreibung der Funktion:
|
||||||
* Für Jeden Typ aus greater1 durch die FC laufen, und auf der Linken seite einen Match versuchen.
|
* F<EFBFBD>r Jeden Typ aus greater1 durch die FC laufen, und auf der Linken seite einen Match versuchen.
|
||||||
* Wenn das Funktioniert, dann ist der Typ auf der rechten Seite auch greater.
|
* Wenn das Funktioniert, dann ist der Typ auf der rechten Seite auch greater.
|
||||||
* */
|
* */
|
||||||
Hashtable<JavaClassName,Type> ht = new Hashtable<JavaClassName,Type>();
|
Hashtable<JavaClassName,Type> ht = new Hashtable<JavaClassName,Type>();
|
||||||
@ -3373,7 +3212,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
RefType TA2neu = ((RefType)p.TA2).clone();
|
RefType TA2neu = ((RefType)p.TA2).clone();
|
||||||
SubstHashtableGeneric(TA2neu,ht);
|
SubstHashtableGeneric(TA2neu,ht);
|
||||||
|
|
||||||
//TA2neu ist greater als T. Einfügen in retVec
|
//TA2neu ist greater als T. Einf<EFBFBD>gen in retVec
|
||||||
if(!retVec.contains(TA2neu))
|
if(!retVec.contains(TA2neu))
|
||||||
retVec.add(TA2neu);
|
retVec.add(TA2neu);
|
||||||
}
|
}
|
||||||
@ -3403,12 +3242,12 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
|
|
||||||
//Von hier an Smaller implementierung luar 28-03-07
|
//Von hier an Smaller implementierung luar 28-03-07
|
||||||
/**
|
/**
|
||||||
* Der Komplette Ablauf von smaller und was die einzelnen Teilschritte machen kann anhand von Aktivitätsdiagrammen
|
* Der Komplette Ablauf von smaller und was die einzelnen Teilschritte machen kann anhand von Aktivit<EFBFBD>tsdiagrammen
|
||||||
* im Inovator Projekt, oder in der Studienarbeit Arne Lüdtke, 2007 nachgelesen werden.
|
* im Inovator Projekt, oder in der Studienarbeit Arne L<EFBFBD>dtke, 2007 nachgelesen werden.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Erzeugt alle Typen die smaller sind als T. Gibt diese zurück.
|
* Erzeugt alle Typen die smaller sind als T. Gibt diese zur<EFBFBD>ck.
|
||||||
*/
|
*/
|
||||||
private static Menge<ObjectType> smaller(ObjectType T, FC_TTO fc_tto)
|
private static Menge<ObjectType> smaller(ObjectType T, FC_TTO fc_tto)
|
||||||
//an die Aenderungen im Skript anpassen 07-11-03
|
//an die Aenderungen im Skript anpassen 07-11-03
|
||||||
@ -3444,18 +3283,18 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
if(!smaller12Erg.contains(T))
|
if(!smaller12Erg.contains(T))
|
||||||
smaller12Erg.add(T);
|
smaller12Erg.add(T);
|
||||||
|
|
||||||
//Ergebnise in retVec einfügen. Doppelte werden gelöscht.
|
//Ergebnise in retVec einf<EFBFBD>gen. Doppelte werden gel<EFBFBD>scht.
|
||||||
for(ObjectType t : smaller12Erg)
|
for(ObjectType t : smaller12Erg)
|
||||||
if(!retVec.contains(t))
|
if(!retVec.contains(t))
|
||||||
retVec.add(t);
|
retVec.add(t);
|
||||||
|
|
||||||
//Ergebnis von smaller1 und smaller2 an smaller3 weitergeben, Ergebnisse einfügen.
|
//Ergebnis von smaller1 und smaller2 an smaller3 weitergeben, Ergebnisse einf<EFBFBD>gen.
|
||||||
Menge<ObjectType> smaller3Erg = smaller3(smaller12Erg,fc_tto);
|
Menge<ObjectType> smaller3Erg = smaller3(smaller12Erg,fc_tto);
|
||||||
for(ObjectType t : smaller3Erg)
|
for(ObjectType t : smaller3Erg)
|
||||||
if(!retVec.contains(t))
|
if(!retVec.contains(t))
|
||||||
retVec.add(t);
|
retVec.add(t);
|
||||||
|
|
||||||
//Ergebnisse von smaller3 an smaller4 weitergeben, Ergebnisse einfügen.
|
//Ergebnisse von smaller3 an smaller4 weitergeben, Ergebnisse einf<EFBFBD>gen.
|
||||||
Menge<ObjectType> smaller4Erg = smaller4(smaller3Erg);
|
Menge<ObjectType> smaller4Erg = smaller4(smaller3Erg);
|
||||||
for(ObjectType t : smaller4Erg)
|
for(ObjectType t : smaller4Erg)
|
||||||
if(!retVec.contains(t))
|
if(!retVec.contains(t))
|
||||||
@ -3504,7 +3343,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
Menge<Type> retVec = new Menge<Type>();
|
Menge<Type> retVec = new Menge<Type>();
|
||||||
if(T instanceof ExtendsWildcardType)
|
if(T instanceof ExtendsWildcardType)
|
||||||
{
|
{
|
||||||
//Für eine ExtendsWildcard rekursiv smaller0 aufrufen, und neue Wildcards erzeugen.
|
//F<EFBFBD>r eine ExtendsWildcard rekursiv smaller0 aufrufen, und neue Wildcards erzeugen.
|
||||||
ExtendsWildcardType exT = (ExtendsWildcardType)T;
|
ExtendsWildcardType exT = (ExtendsWildcardType)T;
|
||||||
Menge<ObjectType> smallerTypes = smaller0(exT.get_ExtendsType(),fc_tto);
|
Menge<ObjectType> smallerTypes = smaller0(exT.get_ExtendsType(),fc_tto);
|
||||||
for(ObjectType t : smallerTypes)
|
for(ObjectType t : smallerTypes)
|
||||||
@ -3515,7 +3354,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
}
|
}
|
||||||
else if(T instanceof SuperWildcardType)
|
else if(T instanceof SuperWildcardType)
|
||||||
{
|
{
|
||||||
//Für eine SuperWildcard rekursiv greater0 aufrufen, unr neue Wildcards erzeugen.
|
//F<EFBFBD>r eine SuperWildcard rekursiv greater0 aufrufen, unr neue Wildcards erzeugen.
|
||||||
SuperWildcardType suT = (SuperWildcardType)T;
|
SuperWildcardType suT = (SuperWildcardType)T;
|
||||||
Menge<ObjectType> greaterTypes = greater0(suT.get_SuperType(),fc_tto);
|
Menge<ObjectType> greaterTypes = greater0(suT.get_SuperType(),fc_tto);
|
||||||
for(ObjectType t : greaterTypes)
|
for(ObjectType t : greaterTypes)
|
||||||
@ -3554,7 +3393,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
Menge<ObjectType> retVec = new Menge<ObjectType>();
|
Menge<ObjectType> retVec = new Menge<ObjectType>();
|
||||||
/*
|
/*
|
||||||
* luar 02-05-07: Beschreibung der Funktion:
|
* luar 02-05-07: Beschreibung der Funktion:
|
||||||
* Für Jeden Typ aus Smaller12 durch die FC laufen, und auf der Rechten seite einen Match versuchen.
|
* F<EFBFBD>r Jeden Typ aus Smaller12 durch die FC laufen, und auf der Rechten seite einen Match versuchen.
|
||||||
* Wenn das Funktioniert, dann ist der Typ auf der linken Seite auch smaller.
|
* Wenn das Funktioniert, dann ist der Typ auf der linken Seite auch smaller.
|
||||||
* */
|
* */
|
||||||
Hashtable<JavaClassName,Type> ht = new Hashtable<JavaClassName,Type>();
|
Hashtable<JavaClassName,Type> ht = new Hashtable<JavaClassName,Type>();
|
||||||
@ -3577,7 +3416,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
//Macht hat funktioniert. In Linker Seite Typen substituieren
|
//Macht hat funktioniert. In Linker Seite Typen substituieren
|
||||||
RefType TA1neu = ((RefType)p.TA1).clone();
|
RefType TA1neu = ((RefType)p.TA1).clone();
|
||||||
SubstHashtableGeneric(TA1neu,ht);
|
SubstHashtableGeneric(TA1neu,ht);
|
||||||
//TA1neu ist smaller als T. Einfügen in retVec
|
//TA1neu ist smaller als T. Einf<EFBFBD>gen in retVec
|
||||||
if(!retVec.contains(TA1neu))
|
if(!retVec.contains(TA1neu))
|
||||||
retVec.add(TA1neu);
|
retVec.add(TA1neu);
|
||||||
}
|
}
|
||||||
@ -3627,12 +3466,12 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gibt True zurück, wenn T eine FreshWildcard ist, oder im Falle eines RefTypes oder WildcardTypes eine FreshWildcard enthält.
|
* Gibt True zur<EFBFBD>ck, wenn T eine FreshWildcard ist, oder im Falle eines RefTypes oder WildcardTypes eine FreshWildcard enth<EFBFBD>lt.
|
||||||
*/
|
*/
|
||||||
private static boolean DelFreshWildcardTypeVar(Type T)
|
private static boolean DelFreshWildcardTypeVar(Type T)
|
||||||
{
|
{
|
||||||
//luar 29-05-2007
|
//luar 29-05-2007
|
||||||
//Ãberprüft rekursiv ob in dem RefType ein FreshWildcardType enthalten ist.
|
//<EFBFBD>berpr<EFBFBD>ft rekursiv ob in dem RefType ein FreshWildcardType enthalten ist.
|
||||||
if(T instanceof RefType)
|
if(T instanceof RefType)
|
||||||
{
|
{
|
||||||
RefType refT = (RefType)T;
|
RefType refT = (RefType)T;
|
||||||
@ -3641,7 +3480,7 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
if(DelFreshWildcardTypeVar(t))
|
if(DelFreshWildcardTypeVar(t))
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
//Im Falle einer Wildcard, Typen aus der WC rausnehmen und diesen rekursiv prüfen.
|
//Im Falle einer Wildcard, Typen aus der WC rausnehmen und diesen rekursiv pr<EFBFBD>fen.
|
||||||
if(T instanceof ExtendsWildcardType)
|
if(T instanceof ExtendsWildcardType)
|
||||||
return DelFreshWildcardTypeVar(((ExtendsWildcardType)T).get_ExtendsType());
|
return DelFreshWildcardTypeVar(((ExtendsWildcardType)T).get_ExtendsType());
|
||||||
|
|
||||||
@ -3651,12 +3490,5 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
return T instanceof FreshWildcardType;
|
return T instanceof FreshWildcardType;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static <A extends DeepCloneable> Menge<A> deepClone(Menge<A> m){
|
|
||||||
Timewatch watch = Timewatch.getTimewatch();
|
|
||||||
Timestamp timer = watch.start("Unify - deepClone");
|
|
||||||
Menge<A> ret = m.stream().<A>map((Function<A,A>)(x -> x.deepClone())).<Menge<A>>collect(Menge::new, Menge::add, Menge::addAll);
|
|
||||||
timer.stop();
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
// ino.end
|
// ino.end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user