forked from JavaTX/JavaCompilerCore
Aufräumen
This commit is contained in:
parent
3a8f1252a4
commit
44318ee5d8
@ -280,6 +280,7 @@ public class SourceFile
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
typinferenzLog.debug("Finite Closure: "+finiteClosure, Section.TYPEINFERENCE);
|
||||||
typinferenzLog.debug("Karthesisches Produkt der Constraints: "+xConstraints, Section.TYPEINFERENCE);
|
typinferenzLog.debug("Karthesisches Produkt der Constraints: "+xConstraints, Section.TYPEINFERENCE);
|
||||||
|
|
||||||
//finiteClosure.generateFullyNamedTypes(globalAssumptions);
|
//finiteClosure.generateFullyNamedTypes(globalAssumptions);
|
||||||
|
@ -49,13 +49,13 @@ public class UnifyTypeFactory {
|
|||||||
RefType superClass = cAss.getAssumedClass().getSuperClass();
|
RefType superClass = cAss.getAssumedClass().getSuperClass();
|
||||||
if(superClass != null){
|
if(superClass != null){
|
||||||
UnifyType tr = UnifyTypeFactory.convert(superClass);
|
UnifyType tr = UnifyTypeFactory.convert(superClass);
|
||||||
pairs.add(smaller(tl, tr));
|
pairs.add(generateSmallerPair(tl, tr));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return new FiniteClosure(pairs);
|
return new FiniteClosure(pairs);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static UnifyPair smaller(UnifyType tl, UnifyType tr){
|
public static UnifyPair generateSmallerPair(UnifyType tl, UnifyType tr){
|
||||||
return new UnifyPair(tl, tr, PairOperator.SMALLER);
|
return new UnifyPair(tl, tr, PairOperator.SMALLER);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -135,7 +135,7 @@ public class UnifyTypeFactory {
|
|||||||
|
|
||||||
public static UnifyPair convert(Pair p) {
|
public static UnifyPair convert(Pair p) {
|
||||||
if(!p.OperatorSmaller())throw new NotImplementedException();
|
if(!p.OperatorSmaller())throw new NotImplementedException();
|
||||||
UnifyPair ret = smaller(UnifyTypeFactory.convert(p.TA1)
|
UnifyPair ret = generateSmallerPair(UnifyTypeFactory.convert(p.TA1)
|
||||||
, UnifyTypeFactory.convert(p.TA2));
|
, UnifyTypeFactory.convert(p.TA2));
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,7 @@ import java.util.Vector;
|
|||||||
import de.dhbwstuttgart.logger.Logger;
|
import de.dhbwstuttgart.logger.Logger;
|
||||||
import de.dhbwstuttgart.syntaxtree.type.Type;
|
import de.dhbwstuttgart.syntaxtree.type.Type;
|
||||||
import de.dhbwstuttgart.logger.*;
|
import de.dhbwstuttgart.logger.*;
|
||||||
import de.dhbwstuttgart.typeinference.unify.Unifier;
|
import de.dhbwstuttgart.typeinference.unify.Unifikationsalgorithmus;
|
||||||
|
|
||||||
public class ConstraintsSet extends UndMenge<Pair> implements Iterable<OderConstraint>{
|
public class ConstraintsSet extends UndMenge<Pair> implements Iterable<OderConstraint>{
|
||||||
private static final Logger log = Logger.getLogger(ConstraintsSet.class.getName());
|
private static final Logger log = Logger.getLogger(ConstraintsSet.class.getName());
|
||||||
|
@ -8,7 +8,7 @@ import de.dhbwstuttgart.logger.Section;
|
|||||||
import de.dhbwstuttgart.syntaxtree.type.RefType;
|
import de.dhbwstuttgart.syntaxtree.type.RefType;
|
||||||
import de.dhbwstuttgart.syntaxtree.type.Type;
|
import de.dhbwstuttgart.syntaxtree.type.Type;
|
||||||
import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder;
|
import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder;
|
||||||
import de.dhbwstuttgart.typeinference.unify.Unifier;
|
import de.dhbwstuttgart.typeinference.unify.Unifikationsalgorithmus;
|
||||||
|
|
||||||
public class OderConstraint extends OderMenge<Pair>{
|
public class OderConstraint extends OderMenge<Pair>{
|
||||||
private Set<UndConstraint> oderConstraintPairs;
|
private Set<UndConstraint> oderConstraintPairs;
|
||||||
|
@ -10,7 +10,7 @@ import de.dhbwstuttgart.logger.Section;
|
|||||||
import de.dhbwstuttgart.syntaxtree.type.RefType;
|
import de.dhbwstuttgart.syntaxtree.type.RefType;
|
||||||
import de.dhbwstuttgart.syntaxtree.type.Type;
|
import de.dhbwstuttgart.syntaxtree.type.Type;
|
||||||
import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder;
|
import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder;
|
||||||
import de.dhbwstuttgart.typeinference.unify.Unifier;
|
import de.dhbwstuttgart.typeinference.unify.Unifikationsalgorithmus;
|
||||||
|
|
||||||
public abstract class OderMenge<A> implements KomplexeMenge<A>{
|
public abstract class OderMenge<A> implements KomplexeMenge<A>{
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@ import java.util.Vector;
|
|||||||
|
|
||||||
import de.dhbwstuttgart.syntaxtree.type.Type;
|
import de.dhbwstuttgart.syntaxtree.type.Type;
|
||||||
import de.dhbwstuttgart.typeinference.exceptions.DebugException;
|
import de.dhbwstuttgart.typeinference.exceptions.DebugException;
|
||||||
import de.dhbwstuttgart.typeinference.unify.Unifier;
|
import de.dhbwstuttgart.typeinference.unify.Unifikationsalgorithmus;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stellt ein Constraint dar, welches aus mehreren Constraint-Paaren besteht. Diese gelten alle stets gleichzeitig / sind per "Und" miteinander verknüpft.
|
* Stellt ein Constraint dar, welches aus mehreren Constraint-Paaren besteht. Diese gelten alle stets gleichzeitig / sind per "Und" miteinander verknüpft.
|
||||||
|
@ -5,7 +5,7 @@ import java.util.Set;
|
|||||||
import java.util.Vector;
|
import java.util.Vector;
|
||||||
import de.dhbwstuttgart.logger.Logger;
|
import de.dhbwstuttgart.logger.Logger;
|
||||||
import de.dhbwstuttgart.logger.*;
|
import de.dhbwstuttgart.logger.*;
|
||||||
import de.dhbwstuttgart.typeinference.unify.Unifier;
|
import de.dhbwstuttgart.typeinference.unify.Unifikationsalgorithmus;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.UnifyPair;
|
import de.dhbwstuttgart.typeinference.unify.model.UnifyPair;
|
||||||
|
|
||||||
public class UnifyConstraintsSet extends UndMenge<UnifyPair> implements Iterable<UnifyOderConstraint>{
|
public class UnifyConstraintsSet extends UndMenge<UnifyPair> implements Iterable<UnifyOderConstraint>{
|
||||||
@ -37,7 +37,7 @@ public class UnifyConstraintsSet extends UndMenge<UnifyPair> implements Iterable
|
|||||||
return constraintsSet.iterator();
|
return constraintsSet.iterator();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void filterWrongConstraints(Unifier unify) {
|
public void filterWrongConstraints(Unifikationsalgorithmus unify) {
|
||||||
/*
|
/*
|
||||||
* Das ConstraintsSet enthält nur OderConstraints, welche UND-Verknüpft sind.
|
* Das ConstraintsSet enthält nur OderConstraints, welche UND-Verknüpft sind.
|
||||||
* Hier werden Constraints in den OderConstraints kontrolliert:
|
* Hier werden Constraints in den OderConstraints kontrolliert:
|
||||||
@ -51,7 +51,7 @@ public class UnifyConstraintsSet extends UndMenge<UnifyPair> implements Iterable
|
|||||||
* Nimmt alle UndConstraints und filtert mithilfe dieser die falschen Constraints aus den OderConstraints
|
* Nimmt alle UndConstraints und filtert mithilfe dieser die falschen Constraints aus den OderConstraints
|
||||||
* @param unifier
|
* @param unifier
|
||||||
*/
|
*/
|
||||||
public void unifyUndConstraints(Unifier unifier) {
|
public void unifyUndConstraints(Unifikationsalgorithmus unifier) {
|
||||||
Vector<UnifyUndConstraint> uCons = this.filterUndConstraints();
|
Vector<UnifyUndConstraint> uCons = this.filterUndConstraints();
|
||||||
Vector<UnifyPair> alleUndConstraints = new Vector<>();
|
Vector<UnifyPair> alleUndConstraints = new Vector<>();
|
||||||
for(UnifyUndConstraint undConstraint : uCons){
|
for(UnifyUndConstraint undConstraint : uCons){
|
||||||
|
@ -8,7 +8,7 @@ import de.dhbwstuttgart.logger.Section;
|
|||||||
import de.dhbwstuttgart.syntaxtree.type.RefType;
|
import de.dhbwstuttgart.syntaxtree.type.RefType;
|
||||||
import de.dhbwstuttgart.syntaxtree.type.Type;
|
import de.dhbwstuttgart.syntaxtree.type.Type;
|
||||||
import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder;
|
import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder;
|
||||||
import de.dhbwstuttgart.typeinference.unify.Unifier;
|
import de.dhbwstuttgart.typeinference.unify.Unifikationsalgorithmus;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.UnifyPair;
|
import de.dhbwstuttgart.typeinference.unify.model.UnifyPair;
|
||||||
|
|
||||||
public class UnifyOderConstraint extends OderMenge<UnifyPair>{
|
public class UnifyOderConstraint extends OderMenge<UnifyPair>{
|
||||||
@ -83,7 +83,7 @@ public class UnifyOderConstraint extends OderMenge<UnifyPair>{
|
|||||||
* welche keinen Sinn ergeben, also beim unifizieren scheitern.
|
* welche keinen Sinn ergeben, also beim unifizieren scheitern.
|
||||||
* @param unifier - Wird für die Unifizierung benutzt
|
* @param unifier - Wird für die Unifizierung benutzt
|
||||||
*/
|
*/
|
||||||
void filterWrongConstraints(Unifier unifier) {
|
void filterWrongConstraints(Unifikationsalgorithmus unifier) {
|
||||||
Set<UnifyUndConstraint> filteredConstraints = new Menge<>();
|
Set<UnifyUndConstraint> filteredConstraints = new Menge<>();
|
||||||
for(UnifyUndConstraint cons : this.getUndConstraints()){
|
for(UnifyUndConstraint cons : this.getUndConstraints()){
|
||||||
Set<Set<UnifyPair>> unifierResult = unifier.apply(cons.getConstraintPairs());
|
Set<Set<UnifyPair>> unifierResult = unifier.apply(cons.getConstraintPairs());
|
||||||
|
@ -6,7 +6,7 @@ import java.util.Vector;
|
|||||||
|
|
||||||
import de.dhbwstuttgart.syntaxtree.type.Type;
|
import de.dhbwstuttgart.syntaxtree.type.Type;
|
||||||
import de.dhbwstuttgart.typeinference.exceptions.DebugException;
|
import de.dhbwstuttgart.typeinference.exceptions.DebugException;
|
||||||
import de.dhbwstuttgart.typeinference.unify.Unifier;
|
import de.dhbwstuttgart.typeinference.unify.Unifikationsalgorithmus;
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.UnifyPair;
|
import de.dhbwstuttgart.typeinference.unify.model.UnifyPair;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -4,7 +4,7 @@ import java.util.Set;
|
|||||||
|
|
||||||
import de.dhbwstuttgart.typeinference.unify.model.UnifyPair;
|
import de.dhbwstuttgart.typeinference.unify.model.UnifyPair;
|
||||||
|
|
||||||
public interface Unifier {
|
public interface Unifikationsalgorithmus {
|
||||||
|
|
||||||
public Set<Set<UnifyPair>> apply (Set<UnifyPair> E);
|
public Set<Set<UnifyPair>> apply (Set<UnifyPair> E);
|
||||||
|
|
@ -383,4 +383,9 @@ public class FiniteClosure implements IFiniteClosure {
|
|||||||
permuteParams(candidates, idx+1, result, current);
|
permuteParams(candidates, idx+1, result, current);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString(){
|
||||||
|
return this.inheritanceGraph.toString();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
18
test/bytecode/types/Overloading2.jav
Normal file
18
test/bytecode/types/Overloading2.jav
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
|
class Overloading2{
|
||||||
|
|
||||||
|
String method(Vector<String> v) {
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
||||||
|
Integer method(Vector<Integer> v) {
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args){
|
||||||
|
Overloading2 t;
|
||||||
|
t = new Overloading2();
|
||||||
|
t.method(new Vector<String>());
|
||||||
|
}
|
||||||
|
}
|
71
test/bytecode/types/Overloading2Test.java
Normal file
71
test/bytecode/types/Overloading2Test.java
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
package bytecode.types;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLClassLoader;
|
||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import bytecode.SourceFileBytecodeTest;
|
||||||
|
|
||||||
|
public class Overloading2Test extends SourceFileBytecodeTest{
|
||||||
|
@Override
|
||||||
|
protected void init() {
|
||||||
|
testName = "Overloading2";
|
||||||
|
rootDirectory = System.getProperty("user.dir")+"/test/bytecode/types/";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testString() {
|
||||||
|
try{
|
||||||
|
ClassLoader classLoader = getClassLoader();
|
||||||
|
|
||||||
|
Class cls = classLoader.loadClass(testName);
|
||||||
|
|
||||||
|
Object obj = cls.newInstance();
|
||||||
|
|
||||||
|
File file = new File(rootDirectory);
|
||||||
|
URL url = file.toURL();
|
||||||
|
URL[] urls = new URL[]{url};
|
||||||
|
|
||||||
|
Class stringVector = classLoader.loadClass("java%util%Vector%%java%lang%String%");
|
||||||
|
|
||||||
|
Class[] params = new Class[1];
|
||||||
|
params[0] = stringVector;
|
||||||
|
|
||||||
|
Method method = cls.getDeclaredMethod("method", params);
|
||||||
|
method.invoke(obj, stringVector.newInstance());
|
||||||
|
assertTrue(true);
|
||||||
|
}catch(Exception e){
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testInteger() {
|
||||||
|
try{
|
||||||
|
ClassLoader classLoader = getClassLoader();
|
||||||
|
|
||||||
|
Class cls = classLoader.loadClass(testName);
|
||||||
|
|
||||||
|
Object obj = cls.newInstance();
|
||||||
|
|
||||||
|
Class integerVector = classLoader.loadClass("java%util%Vector%%java%lang%Integer%");
|
||||||
|
|
||||||
|
Class[] params = new Class[1];
|
||||||
|
params[0] = integerVector;
|
||||||
|
|
||||||
|
Method method = cls.getDeclaredMethod("method", params);
|
||||||
|
method.invoke(obj, integerVector.newInstance());
|
||||||
|
assertTrue(true);
|
||||||
|
}catch(Exception e){
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -102,12 +102,13 @@ public class MultipleTypesInsertTester extends TypeInsertTester{
|
|||||||
} catch (IOException | yyException e) {
|
} catch (IOException | yyException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
TestCase.fail();
|
TestCase.fail();
|
||||||
|
}finally{
|
||||||
|
writeLog(sourceFileToInfere+".log");
|
||||||
}
|
}
|
||||||
for(String containString : mustContain){
|
for(String containString : mustContain){
|
||||||
TestCase.assertTrue("\""+containString+"\" muss in den inferierten Lösungen vorkommen",gesamterSrc.contains(containString));
|
TestCase.assertTrue("\""+containString+"\" muss in den inferierten Lösungen vorkommen",gesamterSrc.contains(containString));
|
||||||
}
|
}
|
||||||
|
|
||||||
writeLog(sourceFileToInfere+".log");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void writeLog(String toFile){
|
private static void writeLog(String toFile){
|
||||||
|
@ -30,6 +30,11 @@ import de.dhbwstuttgart.typeinference.unify.model.UnifyType;
|
|||||||
public class UnifyTypeFactoryTest {
|
public class UnifyTypeFactoryTest {
|
||||||
private static TypeFactory tf = new TypeFactory();
|
private static TypeFactory tf = new TypeFactory();
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void convertUnifyTypes(){
|
||||||
|
//UnifyType ut =
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void convertConstraintSet(){
|
public void convertConstraintSet(){
|
||||||
ConstraintsSet cons = new ConstraintsSet();
|
ConstraintsSet cons = new ConstraintsSet();
|
||||||
|
Loading…
Reference in New Issue
Block a user