Code aufgeräumt

This commit is contained in:
JanUlrich 2014-08-05 12:34:09 +02:00
parent 2925926e58
commit 69668434da
6 changed files with 47 additions and 176 deletions

View File

@ -18,6 +18,8 @@ import mycompiler.mytype.TypePlaceholder;
/** /**
* Ein InsertPoint für Generische Variablen * Ein InsertPoint für Generische Variablen
* Wird beim Einsetzen eines TIP generiert.
* Steht für die Einsetzung aller Generischen Variablendeklarationen zugehörig zu einem Punkt in der SourceFile.
* @author janulrich * @author janulrich
* *
*/ */
@ -34,55 +36,16 @@ public class GenericTypeInsertPoint extends SourcePatchPoint {
this.genericInsertPoint = syntaxTreeNode; this.genericInsertPoint = syntaxTreeNode;
} }
/* /**
public GenericTypeInsertPoint(TypeInsertable syntaxTreeNode, * Der TypeInsertString wird im Falle des GTIP von dem zugehörigen SyntaxTreeNode generiert.
Vector<Pair> pairs,ResultSet resultSet) { * @return
super(syntaxTreeNode, null, resultSet); */
this.genericPairs = pairs;
if(this.genericPairs.size() == 0)throw new DebugException("Menge der generischen Paare ist leer");
}
*/
public String getTypeInsertString() { public String getTypeInsertString() {
String genericVar = this.patch.getInsertString(this.resultSet); String genericVar = this.patch.getInsertString(this.resultSet);
if(genericVar.length()==0)return ""; if(genericVar.length()==0)return "";
return this.genericInsertPoint.getGenericVarDeclarationString(genericVar)+" "; return this.genericInsertPoint.getGenericVarDeclarationString(genericVar)+" ";
} }
/*
@Override
protected Type getInsertType(){
if(genericPairs.size()==0){
return new RefType("<"+this.type.printJavaCode(resultSet)+">",-1);
}
Vector<Pair> pairs = new Vector<Pair>();
//Problem: <P1 extends P2> ist falsch! Es muss: <P2, P1 extends P2> heißen:
Vector<Type> P1s = new Vector<Type>();
Vector<Type> P2s = new Vector<Type>();
for(Pair p : genericPairs){
P1s.add(p.TA1);
P2s.add(p.TA2);
}
for(Type t : P2s){
if(!P1s.contains(t))pairs.add(new Pair(t,null));
}
pairs.addAll(this.genericPairs);
Iterator<Pair> it = pairs.iterator();
String genericTypeParameters = "<";
while(it.hasNext()){
genericTypeParameters += new GenericTypeVar(it.next(), 0).printJavaCode(this.getResultSet());
if(it.hasNext())genericTypeParameters += ", ";
}
genericTypeParameters += ">";
//Der Generische Variablen String zum Einsetzen ist nun vorhanden
this.type = new RefType(genericTypeParameters,0);
return this.type;
}
*/
@Override @Override
public boolean equals(Object obj){ public boolean equals(Object obj){
if(obj instanceof GenericTypeInsertPoint)return super.equals(obj); if(obj instanceof GenericTypeInsertPoint)return super.equals(obj);
@ -96,63 +59,14 @@ public class GenericTypeInsertPoint extends SourcePatchPoint {
return ret; return ret;
} }
/**
* Versucht den GenericTypeInsertPoint mit dem <FC>bergebenenen p2 zusam
* basierend auf ihren insertPoints.
* @param p2
* @return - Die bei der Zusammenf<FC>hrung entstandene GenericTypeInser
public Vector<GenericTypeInsertPoint> merge(GenericTypeInsertPoint p2) {
Vector<GenericTypeInsertPoint> ret = new Vector<GenericTypeInsertPoint>();
if(this.getInsertNode().equals(p2.getInsertNode())){
for(Pair p : p2.genericPairs)this.addGenericPair(p);
ret.add(this);
}else{
ret.add(this);
ret.add(p2);
}
return ret;
}
*/
@Override @Override
public JavaCodeResult patch(String fileContent, int additionalOffset) { public JavaCodeResult patch(String fileContent, int additionalOffset) {
/* JavaCodeResult ret = new JavaCodeResult(fileContent.substring(0, this.getOffset()+additionalOffset));
int offset = additionalOffset;
String insertString = "";
if(this.genericParameters != null){
offset += this.genericParameters.getOffsetOfLastElement();
insertString = ", "+genericVarDecl;
}else{
offset += this.offset;
}
return sourceCode.substring(0,offset) + insertString + sourceCode.substring(offset);
*/
//TODO: Es kann sein, dass eine Methode bereits Generische Variablen hat, diese müssen dann an diese Liste angefügt werden.
JavaCodeResult ret = new JavaCodeResult(fileContent.substring(0, this.getOffset()+additionalOffset));
JavaCodeResult mitte = new JavaCodeResult(this.getTypeInsertString()).attach(fileContent.substring(this.getOffset()+additionalOffset)); JavaCodeResult mitte = new JavaCodeResult(this.getTypeInsertString()).attach(fileContent.substring(this.getOffset()+additionalOffset));
ret.attach(mitte); ret.attach(mitte);
//this.
return ret; return ret;
} }
/*
public boolean associatedWith(TypeInsertPoint tip, ResultSet resultSet) {
if((tip.type instanceof TypePlaceholder)){
Vector<TypePlaceholder> tphs = new Vector<>();
tphs.add((TypePlaceholder)tip.type);
for(Pair p : resultSet.getConstraintsFor(tphs)){
if(p.TA1.equals(this.type))return true;
if(p.TA2.equals(this.type))return true;
if(this.genericPairs.contains(p))return true;
}
}
return false;
}
*/
@Override @Override
public int getOffset() { public int getOffset() {
return genericInsertPoint.getGenericVarDeclarationOffset(); return genericInsertPoint.getGenericVarDeclarationOffset();

View File

@ -22,7 +22,6 @@ import mycompiler.mytypereconstruction.replacementlistener.ITypeReplacementListe
*/ */
public class TypeInsertPoint extends SourcePatchPoint { public class TypeInsertPoint extends SourcePatchPoint {
public Type type; public Type type;
private TypeInsertable point; private TypeInsertable point;
private SyntaxTreeNode node; private SyntaxTreeNode node;
@ -59,12 +58,6 @@ public class TypeInsertPoint extends SourcePatchPoint {
return this.getTypeInsertString().toString().length(); return this.getTypeInsertString().toString().length();
} }
public Vector<TypePlaceholder> getUnresolvedTPH(){
Vector<TypePlaceholder> ret = new Vector<TypePlaceholder>();
ret.addAll(this.getInsertType().getUnresolvedTPH(resultSet));
return ret;
}
/** /**
* *
* @return Der Offset des TypeInsertPoints in dem geparsten Source für dessen Klasse er erstellt wurde. * @return Der Offset des TypeInsertPoints in dem geparsten Source für dessen Klasse er erstellt wurde.
@ -102,7 +95,7 @@ public class TypeInsertPoint extends SourcePatchPoint {
if(! (obj instanceof TypeInsertPoint))return false; if(! (obj instanceof TypeInsertPoint))return false;
TypeInsertPoint equals = (TypeInsertPoint) obj; TypeInsertPoint equals = (TypeInsertPoint) obj;
if(!(equals.getInsertPoint().equals(this.getInsertPoint())))return false; if(!(equals.getInsertPoint().equals(this.getInsertPoint())))return false;
if(!(equals.getResultSet().equals(this.getResultSet())))return false; //ResultSet spielt bei Equals keine Rolle if(!(equals.getResultSet().equals(this.getResultSet())))return false;
if(!(equals.getInsertType().equals(this.getInsertType())))return false; if(!(equals.getInsertType().equals(this.getInsertType())))return false;
return true; return true;

View File

@ -17,20 +17,10 @@ import mycompiler.mytype.Pair;
import mycompiler.mytype.RefType; import mycompiler.mytype.RefType;
import mycompiler.mytype.TypePlaceholder; import mycompiler.mytype.TypePlaceholder;
/*
* Der Plan:
* SyntaxTreeNode generiert die TypeInsertPoints.
* SyntaxTreeNode berechnet nicht die GenericInsertPoints. Das wird vom InsertSet übernommen.
* Das funktioniert mithilfe des ResultSets. Denn es müssen alle Constraints mit einbezogen werden, da der Unify
* Algorithmus als Ergebnis nur die zu einem RefType aufgelösten TPHs ausgibt.
*/
/** /**
* Bündelt ein Set von TypeInsertPoints, die alle zu einem TypePlaceholder gehören. * Bündelt ein Set von TypeInsertPoints, welche zu einem TypeInferenceResultSet gehören.
* Diese müssen gemeinsam eingesetzt werden.
* Das TypeInsertSet löst zudem Abhängigkeiten auf. Wird eine Generische Variable eingesetzt, * Das TypeInsertSet löst zudem Abhängigkeiten auf. Wird eine Generische Variable eingesetzt,
* müssen alle mit ihr in Verbindung stehenden Typen ebenfalls eingesetzt werden. * müssen alle mit ihr in Verbindung stehenden Typen ebenfalls eingesetzt werden.
* TODO: Es müssen eigentlich nur die generischen Variablendeklarationen eingesetzt werden.
* TODO: Einsetzen von generischen Variablen in eine bereits vorhanden Parameterliste funktioniert nicht.
* @author janulrich * @author janulrich
* *
*/ */
@ -39,7 +29,6 @@ public class TypeInsertSet {
protected Logger typinferenzLog = Logger.getLogger("Typeinference"); protected Logger typinferenzLog = Logger.getLogger("Typeinference");
public Vector<TypeInsertPoint> points = new Vector<TypeInsertPoint>(); public Vector<TypeInsertPoint> points = new Vector<TypeInsertPoint>();
private Vector<GenericTypeInsertPoint> genericTypeInsertPoints = new Vector<GenericTypeInsertPoint>();
private ResultSet resultSet; private ResultSet resultSet;
public TypeInsertSet(ResultSet resultSet) { public TypeInsertSet(ResultSet resultSet) {
@ -57,11 +46,6 @@ public class TypeInsertSet {
} }
} }
public void add(GenericTypeInsertPoint typeInsertPoint) {
//this.add((TypeInsertPoint)typeInsertPoint);
if(!this.genericTypeInsertPoints.contains(typeInsertPoint))this.genericTypeInsertPoints.add(typeInsertPoint);
}
/** /**
* Fügt nur einen einzelnen TypeInsertPoint in fileContent ein. * Fügt nur einen einzelnen TypeInsertPoint in fileContent ein.
* @param tip * @param tip
@ -114,47 +98,13 @@ public class TypeInsertSet {
* @param fileContent * @param fileContent
* @return * @return
*/ */
@Deprecated
public String insertAllTypes(String fileContent) { public String insertAllTypes(String fileContent) {
//TODO: Das hier kann nicht funktionieren. Nach jedem einsetzen eines TIP muss momentan neu geparst werden
TypePatchJob tpj = new TypePatchJob(); TypePatchJob tpj = new TypePatchJob();
for(TypeInsertPoint tip : this.points){ for(TypeInsertPoint tip : this.points){
this.insertType(tip, tpj); this.insertType(tip, tpj);
} }
return tpj.run(fileContent); return tpj.run(fileContent);
/*
int additionalOffset = 0;
String ret = fileContent;
Vector<GenericTypeInsertPoint> mergedPoints = new Vector<GenericTypeInsertPoint>();
//GenericTypeInsertPoints mergen und dem TypeInsertSet anfügen:
for(GenericTypeInsertPoint p : this.genericTypeInsertPoints){
GenericTypeInsertPoint mergePoint = null;
for(GenericTypeInsertPoint mp : mergedPoints){
if(mp.getOffset() == p.getOffset())mergePoint = mp;
}
if(mergePoint == null){
mergedPoints.add(p);
}else{
mergePoint.merge(p);
}
}
for(TypeInsertPoint mp : mergedPoints){
this.add(mp);
}
//Anschließend sortieren (nach dem Offset der InsertPoints):
Collections.sort(points);
for(TypeInsertPoint p : points){
//Zuerst den Typ einsetzen
JavaCodeResult insertCode = p.insertType(ret, additionalOffset);
ret = insertCode.toString();
//Dann Additional Offset korrigieren:
additionalOffset += p.getInsertLength();
}
return ret;
*/
} }
/** /**
@ -182,12 +132,6 @@ public class TypeInsertSet {
//... aber nicht öfter als 1x : //... aber nicht öfter als 1x :
if(equals.points.lastIndexOf(point)!=equals.points.indexOf(point))return false; if(equals.points.lastIndexOf(point)!=equals.points.indexOf(point))return false;
} }
for(GenericTypeInsertPoint point : this.genericTypeInsertPoints){
//Jeder TypeInsertPoint muss auch in equals vorkommen:
if(!equals.genericTypeInsertPoints.contains(point))return false;
//... aber nicht öfter als 1x :
if(equals.genericTypeInsertPoints.lastIndexOf(point)!=equals.genericTypeInsertPoints.indexOf(point))return false;
}
return true; return true;
} }
@ -201,20 +145,6 @@ public class TypeInsertSet {
} }
} }
/**
* Durchsucht alle bisher angefügten TypeInsertPoints nach nicht aufgelösten TypePlaceholdern.
* Diese sollten als Generische Variablen eingesetzt werden.
* TODO: Es dürfen nur die TypePlaceholder zurückgegeben werden, welche noch in keinem GenericVarTypeInsertPoint verwendet wurden.
* @return
*/
public Vector<TypePlaceholder> getUnresolvedTPHs(){
Vector<TypePlaceholder> ret = new Vector<TypePlaceholder>();
for(TypeInsertPoint p : this.points){
ret.addAll(p.getUnresolvedTPH());
}
return ret;
}
} }
/** /**

View File

@ -12,6 +12,7 @@ import org.junit.Test;
import junit.framework.TestCase; import junit.framework.TestCase;
import mycompiler.MyCompiler; import mycompiler.MyCompiler;
import mycompiler.MyCompilerAPI; import mycompiler.MyCompilerAPI;
import mycompiler.SyntaxTreeNode;
import mycompiler.myparser.JavaParser.yyException; import mycompiler.myparser.JavaParser.yyException;
import mycompiler.mytype.Pair; import mycompiler.mytype.Pair;
import mycompiler.mytype.Pair.PairOperator; import mycompiler.mytype.Pair.PairOperator;
@ -65,7 +66,7 @@ public class TRMEqualTest {
} }
} }
class TestNode implements TypeInsertable{ class TestNode extends SyntaxTreeNode implements TypeInsertable{
@Override @Override
public void replaceType(CReplaceTypeEvent e) { public void replaceType(CReplaceTypeEvent e) {
@ -112,7 +113,7 @@ class TestNode implements TypeInsertable{
@Override @Override
public TypeInsertPoint createTypeInsertPoint(TypePlaceholder tph, public TypeInsertPoint createTypeInsertPoint(TypePlaceholder tph,
ResultSet resultSet) { ResultSet resultSet) {
return new TypeInsertPoint( this, resultSet.getTypeEqualTo(tph), resultSet); return new TypeInsertPoint( this, this, resultSet.getTypeEqualTo(tph), resultSet);
} }
@Override @Override
@ -121,5 +122,11 @@ class TestNode implements TypeInsertable{
return 0; return 0;
} }
@Override
public Vector<SyntaxTreeNode> getChildren() {
// TODO Auto-generated method stub
return new Vector<>();
}
} }

View File

@ -0,0 +1,11 @@
class Overload{
void method( x ){
String varS;
Integer varI;
x.apply(varI);
x.apply(varS);
}
}

View File

@ -0,0 +1,16 @@
package plugindevelopment.TypeInsertTests;
import java.util.Vector;
import org.junit.Test;
public class LambdaTest15 {
private static final String TEST_FILE = "LambdaTest15.jav";
@Test
public void run(){
Vector<String> mustContain = new Vector<String>();
//mustContain.add("A a");
MultipleTypesInsertTester.testSingleInsert(this.TEST_FILE, mustContain);
}
}