InstVarDecl gelöscht. Weitere Verbesserungen. Keine Lauffähige Version

This commit is contained in:
JanUlrich 2014-02-12 22:10:33 +01:00
parent 605c554ffb
commit 95d7553482
15 changed files with 594 additions and 29368 deletions

View File

@ -19,7 +19,6 @@ import mycompiler.myclass.ImportDeclarations;
import mycompiler.myclass.DeclId; import mycompiler.myclass.DeclId;
import mycompiler.myclass.ExceptionList; import mycompiler.myclass.ExceptionList;
import mycompiler.myclass.FormalParameter; import mycompiler.myclass.FormalParameter;
import mycompiler.myclass.InstVarDecl;
import mycompiler.myclass.Method; import mycompiler.myclass.Method;
import mycompiler.myclass.ParameterList; import mycompiler.myclass.ParameterList;
import mycompiler.myclass.UsedId; import mycompiler.myclass.UsedId;
@ -219,7 +218,7 @@ public Vector<Pair> testPair = new Vector<Pair>();
%type <ClassBody> classbodydeclarations %type <ClassBody> classbodydeclarations
%type <Field> classbodydeclaration %type <Field> classbodydeclaration
%type <Field> classmemberdeclaration %type <Field> classmemberdeclaration
%type <InstVarDecl> variabledeclarators %type <FieldDeclaration> variabledeclarators
%type <FieldDeclaration> fielddeclarator; %type <FieldDeclaration> fielddeclarator;
%type <DeclId> variabledeclarator %type <DeclId> variabledeclarator
%type <DeclId> variabledeclaratorid %type <DeclId> variabledeclaratorid
@ -1198,7 +1197,7 @@ type : primitivetype
} }
variabledeclarators : variabledeclarator variabledeclarators : variabledeclarator
{ {
InstVarDecl IVD = new InstVarDecl(); FieldDeclaration IVD = new FieldDeclaration();
IVD.getDeclIdVector().addElement( $1 ); IVD.getDeclIdVector().addElement( $1 );
$$ = IVD; $$ = IVD;
} }

File diff suppressed because one or more lines are too long

View File

@ -20,7 +20,6 @@ import mycompiler.myclass.DeclId;
import mycompiler.myclass.FieldDecl; import mycompiler.myclass.FieldDecl;
import mycompiler.myclass.FormalParameter; import mycompiler.myclass.FormalParameter;
import mycompiler.myclass.ImportDeclarations; import mycompiler.myclass.ImportDeclarations;
import mycompiler.myclass.InstVarDecl;
import mycompiler.myclass.Method; import mycompiler.myclass.Method;
import mycompiler.myclass.ParameterList; import mycompiler.myclass.ParameterList;
import mycompiler.myclass.UsedId; import mycompiler.myclass.UsedId;

View File

@ -579,6 +579,7 @@ public class Class extends SyntaxTreeNode implements AClassOrInterface
//-- //--
assumptions.add(globalAssumptions); assumptions.add(globalAssumptions);
/*
//Generiere Liste mit Expressions, welche zur Initialisierung von Feldern verwendet werden. //Generiere Liste mit Expressions, welche zur Initialisierung von Feldern verwendet werden.
Vector<Expr> fieldInitializers = new Vector<Expr>(); Vector<Expr> fieldInitializers = new Vector<Expr>();
for(FieldDeclaration field : body.getFieldInitializations()){ for(FieldDeclaration field : body.getFieldInitializations()){
@ -588,8 +589,14 @@ public class Class extends SyntaxTreeNode implements AClassOrInterface
fieldAssign.set_Expr(expr1, expr2); fieldAssign.set_Expr(expr1, expr2);
fieldInitializers.add(fieldAssign); fieldInitializers.add(fieldAssign);
} }
*/
ConstraintsSet oderConstraints = this.TYPE(this.getMethodList(), fieldInitializers, assumptions); //ConstraintsSet oderConstraints = this.TYPE(this.getMethodList(), fieldInitializers, assumptions);
ConstraintsSet oderConstraints = new ConstraintsSet();
for(Field f:this.body.getFields()){
oderConstraints.add(f.TYPE(assumptions));
}
typinferenzLog.debug("Erstellte Constraints: "+oderConstraints); typinferenzLog.debug("Erstellte Constraints: "+oderConstraints);
return oderConstraints; return oderConstraints;
@ -894,6 +901,7 @@ public class Class extends SyntaxTreeNode implements AClassOrInterface
Method method=(Method)fieldsAndMethods.get(i); Method method=(Method)fieldsAndMethods.get(i);
method.wandleRefTypeAttributes2GenericAttributes(paralist); method.wandleRefTypeAttributes2GenericAttributes(paralist);
}// Ist es eine InstanzVariable? }// Ist es eine InstanzVariable?
/*
else if(fieldsAndMethods.get(i) instanceof InstVarDecl){ else if(fieldsAndMethods.get(i) instanceof InstVarDecl){
InstVarDecl instVar=(InstVarDecl)fieldsAndMethods.get(i); InstVarDecl instVar=(InstVarDecl)fieldsAndMethods.get(i);
Type type=instVar.getType(); Type type=instVar.getType();
@ -904,7 +912,7 @@ public class Class extends SyntaxTreeNode implements AClassOrInterface
instVar.setType(pendant); instVar.setType(pendant);
} }
} }
} }*/
} }
} }
// ino.end // ino.end

View File

@ -7,6 +7,7 @@ import mycompiler.mybytecode.ClassFile;
import mycompiler.myexception.JVMCodeException; import mycompiler.myexception.JVMCodeException;
import mycompiler.mytype.Type; import mycompiler.mytype.Type;
import mycompiler.mytypereconstruction.replacementlistener.CReplaceTypeEvent; import mycompiler.mytypereconstruction.replacementlistener.CReplaceTypeEvent;
import typinferenz.ConstraintsSet;
import typinferenz.JavaCodeResult; import typinferenz.JavaCodeResult;
import typinferenz.ResultSet; import typinferenz.ResultSet;
import typinferenz.Typeable; import typinferenz.Typeable;
@ -21,6 +22,17 @@ public abstract class Field extends SyntaxTreeNode implements TypeInsertable, Ty
private SyntaxTreeNode parent; private SyntaxTreeNode parent;
private int offset;
@Override
public void setOffset(int offset){
this.offset = offset;
}
@Override
public int getOffset(){
return this.offset;
}
@Override @Override
public void setType(Type typ) { public void setType(Type typ) {
this.typ = typ; this.typ = typ;
@ -71,5 +83,5 @@ public abstract class Field extends SyntaxTreeNode implements TypeInsertable, Ty
*/ */
public abstract TypeAssumptions createTypeAssumptions(Class classmember); public abstract TypeAssumptions createTypeAssumptions(Class classmember);
public abstract ConstraintsSet TYPE(TypeAssumptions publicAssumptions);
} }

View File

@ -2,9 +2,11 @@ package mycompiler.myclass;
import java.util.Vector; import java.util.Vector;
import typinferenz.ConstraintsSet;
import typinferenz.JavaCodeResult; import typinferenz.JavaCodeResult;
import typinferenz.OderConstraint;
import typinferenz.ResultSet; import typinferenz.ResultSet;
import typinferenz.SingleConstraint;
import typinferenz.assumptions.TypeAssumptions; import typinferenz.assumptions.TypeAssumptions;
import mycompiler.SyntaxTreeNode; import mycompiler.SyntaxTreeNode;
import mycompiler.mybytecode.ClassFile; import mycompiler.mybytecode.ClassFile;
@ -52,8 +54,10 @@ public class FieldDeclaration extends Field{
public JavaCodeResult printJavaCode(ResultSet resultSet) { public JavaCodeResult printJavaCode(ResultSet resultSet) {
JavaCodeResult ret = new JavaCodeResult(); JavaCodeResult ret = new JavaCodeResult();
ret.attach(this.getType().printJavaCode(resultSet)).attach( " ").attach( this.getName()+" = ").attach(this.getWert().printJavaCode(resultSet) ).attach( ";"); JavaCodeResult toAttach = this.getType().printJavaCode(resultSet).attach(" ").attach( this.getName());
if(this.wert!=null)toAttach.attach(" = ").attach(this.getWert().printJavaCode(resultSet) );
toAttach.attach( ";");
ret.attach(toAttach);
return ret; return ret;
} }
@ -62,7 +66,6 @@ public class FieldDeclaration extends Field{
////////////////////////////// //////////////////////////////
//Felder: //Felder:
////////////////////////////// //////////////////////////////
TypeAssumptions assumptions = new TypeAssumptions(); TypeAssumptions assumptions = new TypeAssumptions();
/* /*
* TODO: Der Feld-Assumption muss ein TPH als Typ hinzugefügt werden, falls er Typlos initialisiert wurde. Dies kann auch der Type-Algorithmus der Inst/FieldVar - Klasse machen. * TODO: Der Feld-Assumption muss ein TPH als Typ hinzugefügt werden, falls er Typlos initialisiert wurde. Dies kann auch der Type-Algorithmus der Inst/FieldVar - Klasse machen.
@ -82,7 +85,7 @@ public class FieldDeclaration extends Field{
@Override @Override
public Vector<SyntaxTreeNode> getChildren() { public Vector<SyntaxTreeNode> getChildren() {
Vector<SyntaxTreeNode> ret = new Vector<SyntaxTreeNode>(); Vector<SyntaxTreeNode> ret = new Vector<SyntaxTreeNode>();
ret.add(this.wert); if(this.wert!=null)ret.add(this.wert);
return ret; return ret;
} }
@ -97,5 +100,23 @@ public class FieldDeclaration extends Field{
return 0; return 0;
} }
public int getVariableLength()
{
return declid.elementAt(0).get_Name().length();
}
@Override
public ConstraintsSet TYPE(TypeAssumptions publicAssumptions) {
ConstraintsSet ret = new ConstraintsSet();
SingleConstraint c1 = new SingleConstraint(this.getType(), this.getType());
ret.add(c1); //Damit die TypVariable des Felds in den Constraints auftaucht
if(this.wert!=null){
//Falls bei der Deklaration ein Wert zugewiesen wird, verhält sich das Constraintserzeugen wie bei dem Assign-Statement:
ret.add(this.wert.TYPEExpr(publicAssumptions));
ret.add(new SingleConstraint(this.wert.getType(), this.getType()));
}
return ret;
}
} }

View File

@ -14,6 +14,8 @@ import org.apache.log4j.Logger;
// ino.end // ino.end
import sun.reflect.generics.reflectiveObjects.NotImplementedException;
import typinferenz.JavaCodeResult; import typinferenz.JavaCodeResult;
import typinferenz.ResultSet; import typinferenz.ResultSet;
import typinferenz.Typeable; import typinferenz.Typeable;
@ -200,5 +202,13 @@ public class FormalParameter implements ITypeReplacementListener, Typeable, Type
return ret; return ret;
} }
@Override
public void setOffset(int offset) {
//Das Offset steht in declId
throw new NotImplementedException();
}
} }
// ino.end // ino.end

View File

@ -1,208 +0,0 @@
// ino.module.InstVarDecl.8563.package
package mycompiler.myclass;
// ino.end
// ino.module.InstVarDecl.8563.import
import java.util.Vector;
import mycompiler.mybytecode.ClassFile;
import mycompiler.MyCompiler;
import mycompiler.myexception.JVMCodeException;
import mycompiler.mytype.Type;
import mycompiler.mytype.TypePlaceholder;
import mycompiler.mytypereconstruction.replacementlistener.CReplaceTypeEvent;
import mycompiler.mytypereconstruction.replacementlistener.ITypeReplacementListener;
import mycompiler.mytypereconstruction.set.CTypeAssumptionSet;
import mycompiler.mytypereconstruction.typeassumption.CInstVarTypeAssumption;
import mycompiler.mytypereconstruction.typeassumption.CTypeAssumption;
import org.apache.log4j.Logger;
// ino.end
import sun.reflect.generics.reflectiveObjects.NotImplementedException;
import typinferenz.JavaCodeResult;
import typinferenz.ResultSet;
import typinferenz.assumptions.TypeAssumptions;
// ino.class.InstVarDecl.23441.declaration
public class InstVarDecl extends FieldDecl implements ITypeReplacementListener
// ino.end
// ino.class.InstVarDecl.23441.body
{
// ino.attribute.type.23446.declaration
protected Type type;
// ino.end
// ino.attribute.inferencelog.23449.declaration
protected static Logger inferencelog = Logger.getLogger("inference");
// ino.end
// ino.attribute.parserlog.23452.declaration
protected static Logger parserlog = Logger.getLogger("parser");
// ino.end
// ino.method.setType.23455.defdescription type=javadoc
/**
* <br/>Author: J<EFBFBD>rg B<EFBFBD>uerle
* @param t
*/
// ino.end
// ino.method.setType.23455.definition
public void setType(Type t)
// ino.end
// ino.method.setType.23455.body
{
if(this.type instanceof TypePlaceholder){
((TypePlaceholder)this.type).removeReplacementListener(this);
}
if(t instanceof TypePlaceholder){
((TypePlaceholder)t).addReplacementListener(this);
}
this.type = t;
parserlog.debug("T->InstVarDecl->set_Type->type.get_Type: " + t.getName());
}
// ino.end
// ino.method.getType.23458.definition
public Type getType()
// ino.end
// ino.method.getType.23458.body
{
return type;
}
// ino.end
// ino.method.getTypeName.23461.definition
public String getTypeName()
// ino.end
// ino.method.getTypeName.23461.body
{
if(this.getType()==null)return "null";
return this.getType().getName();
}
// ino.end
// ino.method.codegen.23464.definition
public void codegen(ClassFile classfile, Vector paralist)
throws JVMCodeException
// ino.end
// ino.method.codegen.23464.body
{
if(declid != null)
{
for(int i = 0; i < declid.size(); i++)
{
declid.elementAt(i).codegen_InstVarDecl(classfile, this.getType(), paralist);
}
}
}
// ino.end
// ino.method.getLineNumber.23467.definition
public int getLineNumber()
// ino.end
// ino.method.getLineNumber.23467.body
{
if(declid.size()<=0)
return MyCompiler.NO_LINENUMBER;
else{
return declid.elementAt(0).getLineNumber();
}
}
// ino.end
// ino.method.getOffset.23470.defdescription type=line
// hinzugef<EFBFBD>gt: hoth 09.04.2006
// ino.end
// ino.method.getOffset.23470.definition
public int getOffset()
// ino.end
// ino.method.getOffset.23470.body
{
if(declid.size()<=0)
return MyCompiler.NO_LINENUMBER;
else{
return declid.elementAt(0).getOffset();
}
}
// ino.end
// ino.method.getVariableLength.23473.definition
public int getVariableLength()
// ino.end
// ino.method.getVariableLength.23473.body
{
return declid.elementAt(0).get_Name().length();
}
// ino.end
// ino.method.replaceType.23476.defdescription type=javadoc
/**
* <br>Author: J<EFBFBD>rg B<EFBFBD>uerle
* @param e
*/
// ino.end
// ino.method.replaceType.23476.definition
public void replaceType(CReplaceTypeEvent e)
// ino.end
// ino.method.replaceType.23476.body
{
inferencelog.debug("Ersetze Typ in InstVarDecl \""+this.get_Name()+"\"");
if(type instanceof TypePlaceholder){
((TypePlaceholder)type).removeReplacementListener(this);
}
this.setType(e.getNewType());
}
// ino.end
// ino.method.getTypeLineNumber.23479.defdescription type=javadoc
/**
* <br>Author: J<EFBFBD>rg B<EFBFBD>uerle
* @return
*/
// ino.end
// ino.method.getTypeLineNumber.23479.definition
public int getTypeLineNumber()
// ino.end
// ino.method.getTypeLineNumber.23479.body
{
return this.getLineNumber();
}
// ino.end
@Override
public String toString()
{
return this.type + " " + super.getDeclIdVector().firstElement();
}
@Override
public JavaCodeResult printJavaCode(ResultSet resultSet) {
JavaCodeResult ret = new JavaCodeResult();
ret.attach( this.getType().printJavaCode(resultSet)).attach( " " ).attach( super.getDeclIdVector().firstElement() + ";");
return ret;
}
@Override
public TypeAssumptions createTypeAssumptions(Class classmember) {
TypeAssumptions assumptions = new TypeAssumptions();
//////////////////////////////
//Alle Variablendeklarationen (int a, b, c) durchgehen:
//////////////////////////////
for(int i=0; i<this.getDeclIdVector().size(); i++){
DeclId id = (DeclId)this.getDeclIdVector().elementAt(i);
if(this.getType()==null)this.setType(TypePlaceholder.fresh(this));
CInstVarTypeAssumption assum = new CInstVarTypeAssumption(classmember.getName(), id.get_Name(), this.getType(), this.getLineNumber(),this.getOffset(),new Vector<Integer>()); // Typannahme bauen...
assumptions.add(assum);
}
return assumptions;
}
}
// ino.end

File diff suppressed because it is too large Load Diff

View File

@ -19,7 +19,6 @@ import mycompiler.myclass.ImportDeclarations;
import mycompiler.myclass.DeclId; import mycompiler.myclass.DeclId;
import mycompiler.myclass.ExceptionList; import mycompiler.myclass.ExceptionList;
import mycompiler.myclass.FormalParameter; import mycompiler.myclass.FormalParameter;
import mycompiler.myclass.InstVarDecl;
import mycompiler.myclass.Method; import mycompiler.myclass.Method;
import mycompiler.myclass.ParameterList; import mycompiler.myclass.ParameterList;
import mycompiler.myclass.UsedId; import mycompiler.myclass.UsedId;
@ -219,7 +218,7 @@ public Vector<Pair> testPair = new Vector<Pair>();
%type <ClassBody> classbodydeclarations %type <ClassBody> classbodydeclarations
%type <Field> classbodydeclaration %type <Field> classbodydeclaration
%type <Field> classmemberdeclaration %type <Field> classmemberdeclaration
%type <InstVarDecl> variabledeclarators %type <FieldDeclaration> variabledeclarators
%type <FieldDeclaration> fielddeclarator; %type <FieldDeclaration> fielddeclarator;
%type <DeclId> variabledeclarator %type <DeclId> variabledeclarator
%type <DeclId> variabledeclaratorid %type <DeclId> variabledeclaratorid
@ -1198,7 +1197,7 @@ type : primitivetype
} }
variabledeclarators : variabledeclarator variabledeclarators : variabledeclarator
{ {
InstVarDecl IVD = new InstVarDecl(); FieldDeclaration IVD = new FieldDeclaration();
IVD.getDeclIdVector().addElement( $1 ); IVD.getDeclIdVector().addElement( $1 );
$$ = IVD; $$ = IVD;
} }

View File

@ -197,7 +197,7 @@ public class Assign extends Expr
ret.add(expr2.TYPEExpr(assumptions)); ret.add(expr2.TYPEExpr(assumptions));
//this.setTypeVariable( TypePlaceholder.fresh(this)); //this.setTypeVariable( TypePlaceholder.fresh(this));
this.setType(TypePlaceholder.fresh(this)); this.setType(TypePlaceholder.fresh(this));
ret.add(new SingleConstraint(expr2.getType(), expr1.getType())); //expr1.type < expr2.type ret.add(new SingleConstraint(expr2.getType(), expr1.getType())); //expr2.type <. expr1.type
ret.add(new SingleConstraint(expr1.getType(), this.getType())); ret.add(new SingleConstraint(expr1.getType(), this.getType()));
return ret; return ret;
} }

View File

@ -129,7 +129,7 @@ public class LambdaTest {
//String[] arguments = new String[1]; //String[] arguments = new String[1];
//arguments[0]="/home/janulrich/workspace/JavaCompilerCore/test/LampdaExpressions/general.java"; //arguments[0]="/home/janulrich/workspace/JavaCompilerCore/test/LampdaExpressions/general.java";
//MyCompiler.main(arguments); //MyCompiler.main(arguments);
Vector<TypeinferenceResultSet> resultSet = null; Vector<TypeinferenceResultSet> resultSet = new Vector<TypeinferenceResultSet>();
MyCompilerAPI compiler = MyCompiler.getAPI(); MyCompilerAPI compiler = MyCompiler.getAPI();
try{ try{

View File

@ -180,7 +180,7 @@ public class RefType extends Type implements IMatchable
{ {
if (parameter.elementAt(i) instanceof GenericTypeVar) if (parameter.elementAt(i) instanceof GenericTypeVar)
{ {
TypePlaceholder tlv = TypePlaceholder.fresh(); //TODO: Hier wird ein TypePlaceholder ohne ITypeReplacementListener erstellt. Kann Probleme verursachen TypePlaceholder tlv = TypePlaceholder.fresh();
sub.addElement(new CSubstitutionGenVar((GenericTypeVar)parameter.elementAt(i), tlv)); sub.addElement(new CSubstitutionGenVar((GenericTypeVar)parameter.elementAt(i), tlv));
parameter.set(i, tlv); parameter.set(i, tlv);
} }

View File

@ -4,4 +4,7 @@ import mycompiler.mytypereconstruction.replacementlistener.ITypeReplacementListe
public interface TypeInsertable extends ITypeReplacementListener { public interface TypeInsertable extends ITypeReplacementListener {
public int getOffset();
public void setOffset(int offset);
} }

View File

@ -0,0 +1,8 @@
Class DEBUG [Typeinference] Erstellte Assumptions: Set {
varString: TPH A,
methode: NOPARAS --> void,
var: TPH B,
<init>: NOPARAS --> BasicAssumptionsTest
}
Block DEBUG [Typeinference] Prozessing statement: (var = int 1)
Block DEBUG [Typeinference] Prozessing statement: (varString = null (varString.toString( [ ])))