forked from JavaTX/JavaCompilerCore
Object Type implementieren
This commit is contained in:
parent
40bfc79948
commit
3b258c3880
@ -2,15 +2,16 @@ package de.dhbwstuttgart.parser;
|
|||||||
|
|
||||||
import java.util.Vector;
|
import java.util.Vector;
|
||||||
|
|
||||||
|
import de.dhbwstuttgart.syntaxtree.type.ObjectType;
|
||||||
import de.dhbwstuttgart.syntaxtree.type.RefType;
|
import de.dhbwstuttgart.syntaxtree.type.RefType;
|
||||||
import de.dhbwstuttgart.syntaxtree.type.Type;
|
import de.dhbwstuttgart.syntaxtree.type.Type;
|
||||||
|
|
||||||
public class BoundedClassIdentifierList extends Vector<Type>{
|
public class BoundedClassIdentifierList extends Vector<ObjectType>{
|
||||||
|
|
||||||
private int endOffset;
|
private int endOffset;
|
||||||
private Vector<Type> list;
|
private Vector<ObjectType> list;
|
||||||
|
|
||||||
public BoundedClassIdentifierList(Vector<Type> list, int endOffset){
|
public BoundedClassIdentifierList(Vector<ObjectType> list, int endOffset){
|
||||||
this.endOffset = endOffset;
|
this.endOffset = endOffset;
|
||||||
this.addAll(list);
|
this.addAll(list);
|
||||||
}
|
}
|
||||||
|
@ -1561,7 +1561,7 @@ case 110:
|
|||||||
case 111:
|
case 111:
|
||||||
// line 990 "./../src/de/dhbwstuttgart/parser/JavaParser.jay"
|
// line 990 "./../src/de/dhbwstuttgart/parser/JavaParser.jay"
|
||||||
{
|
{
|
||||||
Vector<Type> vec=new Vector<Type>();
|
Vector<ObjectType> vec=new Vector<ObjectType>();
|
||||||
vec.addElement(((RefType)yyVals[0+yyTop]));
|
vec.addElement(((RefType)yyVals[0+yyTop]));
|
||||||
containedTypes.addElement(((RefType)yyVals[0+yyTop]));
|
containedTypes.addElement(((RefType)yyVals[0+yyTop]));
|
||||||
yyVal=new BoundedClassIdentifierList(vec, ((RefType)yyVals[0+yyTop]).getOffset()+((RefType)yyVals[0+yyTop]).getName().toString().length());
|
yyVal=new BoundedClassIdentifierList(vec, ((RefType)yyVals[0+yyTop]).getOffset()+((RefType)yyVals[0+yyTop]).getName().toString().length());
|
||||||
|
@ -988,7 +988,7 @@ boundedMethodParameter : IDENTIFIER
|
|||||||
// returns Vector<Type>
|
// returns Vector<Type>
|
||||||
boundedclassidentifierlist : referencetype
|
boundedclassidentifierlist : referencetype
|
||||||
{
|
{
|
||||||
Vector<Type> vec=new Vector<Type>();
|
Vector<ObjectType> vec=new Vector<ObjectType>();
|
||||||
vec.addElement($1);
|
vec.addElement($1);
|
||||||
containedTypes.addElement($1);
|
containedTypes.addElement($1);
|
||||||
$$=new BoundedClassIdentifierList(vec, $1.getOffset()+$1.getName().toString().length());
|
$$=new BoundedClassIdentifierList(vec, $1.getOffset()+$1.getName().toString().length());
|
||||||
|
@ -152,19 +152,24 @@ public class LambdaExpression extends Expr{
|
|||||||
//ArgumentAssumptions + assumptions ergeben die Assumptions für die Statements innerhalb des Lambda-Bodys:
|
//ArgumentAssumptions + assumptions ergeben die Assumptions für die Statements innerhalb des Lambda-Bodys:
|
||||||
ret.add(method_body.TYPEStmt(ArgumentAssumptions.add(assumptions))); //Es gibt die LambdaExpression nur mit einem Block als Method Body, nicht mit einer einzelnen Expression
|
ret.add(method_body.TYPEStmt(ArgumentAssumptions.add(assumptions))); //Es gibt die LambdaExpression nur mit einem Block als Method Body, nicht mit einer einzelnen Expression
|
||||||
|
|
||||||
|
//TODO: OderConstraint erstellen mit normalem Typ und ? extemds/super Type
|
||||||
//Die Typen innerhalb von FunN anpassen:
|
//Die Typen innerhalb von FunN anpassen:
|
||||||
Vector<Type> superParamTypes = new Vector<>();
|
Vector<Type> superParamTypes = new Vector<>();
|
||||||
for(Type pT : paramTypes){
|
for(Type pT : paramTypes){
|
||||||
if(pT instanceof ObjectType){
|
if(pT instanceof ObjectType){
|
||||||
superParamTypes.add(new SuperWildcardType(pT.getOffset(), (ObjectType) pT));
|
superParamTypes.add(new SuperWildcardType(pT.getOffset(), (ObjectType) pT));
|
||||||
}else{
|
}else{ //pT ist weder Void noch ein ObjectType (TPH, GTV, RefType)
|
||||||
superParamTypes.add(pT);
|
superParamTypes.add(pT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Type retType = method_body.getType();
|
Type retType = method_body.getType();
|
||||||
Type extRetType = retType;
|
Type extRetType = retType;
|
||||||
if(!(retType instanceof de.dhbwstuttgart.syntaxtree.type.Void)){
|
if(!(retType instanceof de.dhbwstuttgart.syntaxtree.type.Void)){
|
||||||
extRetType = new ExtendsWildcardType(retType.getOffset(), retType);
|
if(retType instanceof ObjectType){
|
||||||
|
extRetType = new ExtendsWildcardType(retType.getOffset(), (ObjectType) retType);
|
||||||
|
}else{ //retType ist weder Void noch ein ObjectType (TPH, GTV, RefType)
|
||||||
|
extRetType = retType;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ret.add(new SingleConstraint(new FunN(extRetType, superParamTypes).TYPE(assumptions, this),this.getType().TYPE(assumptions, this)));
|
ret.add(new SingleConstraint(new FunN(extRetType, superParamTypes).TYPE(assumptions, this),this.getType().TYPE(assumptions, this)));
|
||||||
|
@ -94,7 +94,7 @@ public class BoundedGenericTypeVar extends GenericTypeVar
|
|||||||
ConstraintType extendsType = ass.getTypeFor(ev, this);
|
ConstraintType extendsType = ass.getTypeFor(ev, this);
|
||||||
if(extendsType == null)throw new TypeinferenceException("Der Typ "+ev.getName()+" ist nicht korrekt", this);
|
if(extendsType == null)throw new TypeinferenceException("Der Typ "+ev.getName()+" ist nicht korrekt", this);
|
||||||
|
|
||||||
??? stimmt der Cast???
|
//TODO: ??? stimmt der Cast???
|
||||||
tempBounds.add((ObjectType)extendsType.getType());
|
tempBounds.add((ObjectType)extendsType.getType());
|
||||||
//ret.add(new SingleConstraint(ass.getTypeFor(this, this), extendsType ));
|
//ret.add(new SingleConstraint(ass.getTypeFor(this, this), extendsType ));
|
||||||
}
|
}
|
||||||
|
@ -152,7 +152,8 @@ public class ExtendsWildcardType extends WildcardType implements ITypeContainer,
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ConstraintType TYPE(TypeAssumptions ass, SyntaxTreeNode parent) {
|
public ConstraintType TYPE(TypeAssumptions ass, SyntaxTreeNode parent) {
|
||||||
this.extendsType = this.extendsType.TYPE(ass, parent).getType();
|
//Folgender TypeCast ist sicher. Wird ein ObjectType in einen ConstraintType umgewandelt und wieder zurück, kann kein Fehler auftreten.
|
||||||
|
this.extendsType = (ObjectType) this.extendsType.TYPE(ass, parent).getType();
|
||||||
return super.TYPE(ass, parent);
|
return super.TYPE(ass, parent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,3 @@
|
|||||||
|
class GenericParaListInsertTest{
|
||||||
|
<A, ABH extends A, C extends ABH, D, E extends D> A methode(a){return a;}
|
||||||
|
}
|
@ -0,0 +1,16 @@
|
|||||||
|
package plugindevelopment.TypeInsertTests;
|
||||||
|
|
||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
public class GenericParaListInsertTest2 {
|
||||||
|
private static final String TEST_FILE = "GenericParaListInsertTest2.jav";
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void run(){
|
||||||
|
Vector<String> mustContain = new Vector<String>();
|
||||||
|
mustContain.add("<"); //Es muss eine Parameterliste generiert werden.
|
||||||
|
MultipleTypesInsertTester.test(this.TEST_FILE, mustContain);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,17 @@
|
|||||||
|
package plugindevelopment.TypeInsertTests;
|
||||||
|
|
||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
public class GenericTypeVarTest2 {
|
||||||
|
|
||||||
|
private static final String TEST_FILE2 = "GenericTypeVarTest2.jav";
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void run2(){
|
||||||
|
Vector<String> mustContain = new Vector<String>();
|
||||||
|
mustContain.add("String var2");
|
||||||
|
MultipleTypesInsertTester.test(TEST_FILE2, mustContain);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user