forked from JavaTX/JavaCompilerCore
Fehler in deepCopy behoben
This commit is contained in:
parent
6321f1308d
commit
3601d11b0b
@ -810,7 +810,7 @@ public class SourceFile
|
|||||||
// In streamconstraintsclone sind die Mengen von Paar enthalten die unifiziert werden muessen
|
// In streamconstraintsclone sind die Mengen von Paar enthalten die unifiziert werden muessen
|
||||||
Stream<Menge<Pair>> streamconstraintsclone = indexeset.stream().map(x -> x.stream()
|
Stream<Menge<Pair>> streamconstraintsclone = indexeset.stream().map(x -> x.stream()
|
||||||
.map(i -> constraintsClone.elementAt(i))
|
.map(i -> constraintsClone.elementAt(i))
|
||||||
.collect(Menge::new, Menge::add, Menge::addAll));
|
.<Menge<Pair>>collect(Menge::new, Menge::add, Menge::addAll));
|
||||||
//Menge<Menge<Pair>> vecconstraintsclone = streamconstraintsclone.collect(Menge::new, Menge::add, Menge::addAll);
|
//Menge<Menge<Pair>> vecconstraintsclone = streamconstraintsclone.collect(Menge::new, Menge::add, Menge::addAll);
|
||||||
System.out.println();
|
System.out.println();
|
||||||
//Schritt 4: Unifikation
|
//Schritt 4: Unifikation
|
||||||
|
18
src/de/dhbwstuttgart/typeinference/DeepCloneable.java
Normal file
18
src/de/dhbwstuttgart/typeinference/DeepCloneable.java
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
package de.dhbwstuttgart.typeinference;
|
||||||
|
|
||||||
|
public interface DeepCloneable{
|
||||||
|
public <A> A deepClone();
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
public class CloneableMenge<A extends DeepCloneable> extends Menge<A>{
|
||||||
|
|
||||||
|
public CloneableMenge<A> deepClone(){
|
||||||
|
CloneableMenge<A> ret = new CloneableMenge<>();
|
||||||
|
for(A i : this){
|
||||||
|
ret.add(i.deepClone());
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
@ -3,6 +3,7 @@ package de.dhbwstuttgart.typeinference;
|
|||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.Vector;
|
import java.util.Vector;
|
||||||
|
|
||||||
|
|
||||||
public class Menge<A> extends Vector<A> implements Set<A>{
|
public class Menge<A> extends Vector<A> implements Set<A>{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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
|
public class Pair implements Serializable, DeepCloneable
|
||||||
// ino.end
|
// ino.end
|
||||||
// ino.class.Pair.26540.body
|
// ino.class.Pair.26540.body
|
||||||
{
|
{
|
||||||
@ -414,6 +414,7 @@ public class Pair implements Serializable
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Pair deepClone() {
|
public Pair deepClone() {
|
||||||
|
/*
|
||||||
try {
|
try {
|
||||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||||
ObjectOutputStream oos = new ObjectOutputStream(baos);
|
ObjectOutputStream oos = new ObjectOutputStream(baos);
|
||||||
@ -427,6 +428,8 @@ public class Pair implements Serializable
|
|||||||
} catch (ClassNotFoundException e) {
|
} catch (ClassNotFoundException e) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
return clone();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// ino.end
|
// ino.end
|
||||||
|
@ -11,6 +11,9 @@ import java.util.Set;
|
|||||||
|
|
||||||
import de.dhbwstuttgart.typeinference.Menge;
|
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;
|
||||||
@ -41,6 +44,7 @@ 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.ConstraintsSet;
|
||||||
|
import de.dhbwstuttgart.typeinference.DeepCloneable;
|
||||||
import de.dhbwstuttgart.typeinference.OderConstraint;
|
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;
|
||||||
@ -674,7 +678,7 @@ public class Unify
|
|||||||
for (Menge<Menge<Pair>> vecvecpair : cartProduktSets){
|
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:
|
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(cloner.deepClone(vecvecpair.firstElement()));
|
||||||
undMenge.addAll(vecvecpair.firstElement());
|
undMenge.addAll(Unify.deepClone(vecvecpair.firstElement()));
|
||||||
temp.add(vecvecpair);
|
temp.add(vecvecpair);
|
||||||
}else{//gibt es mehrere Mengen, kann gefiltert werden:
|
}else{//gibt es mehrere Mengen, kann gefiltert werden:
|
||||||
oderConstraints.add(vecvecpair); //die Menge zu den zu filternden OderConstraints anfügen
|
oderConstraints.add(vecvecpair); //die Menge zu den zu filternden OderConstraints anfügen
|
||||||
@ -2469,7 +2473,19 @@ 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;
|
||||||
if( nTypnrInPair == 1 )
|
if( nTypnrInPair == 1 )
|
||||||
@ -3632,5 +3648,11 @@ tempKlasse.get_Superclass_Name() ); System.out.println( "P. S.:
|
|||||||
return T instanceof FreshWildcardType;
|
return T instanceof FreshWildcardType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static <A extends DeepCloneable> Menge<A> deepClone(Menge<A> m){
|
||||||
|
|
||||||
|
Menge<A> ret = m.stream().<A>map((Function<A,A>)(x -> x.deepClone())).<Menge<A>>collect(Menge::new, Menge::add, Menge::addAll);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// ino.end
|
// ino.end
|
Loading…
x
Reference in New Issue
Block a user