Merge branch 'bytecode' into refactoring

This commit is contained in:
JanUlrich 2015-06-16 17:44:45 +02:00
commit 302d7d05f3
48 changed files with 1229 additions and 777 deletions

View File

@ -9,3 +9,4 @@
<classpathentry kind="lib" path="lib/bcel-5.2.jar"/> <classpathentry kind="lib" path="lib/bcel-5.2.jar"/>
<classpathentry kind="output" path="bin"/> <classpathentry kind="output" path="bin"/>
</classpath> </classpath>

View File

@ -36,6 +36,7 @@ import de.dhbwstuttgart.syntaxtree.type.ITypeContainer;
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.ByteCodeResult;
import de.dhbwstuttgart.typeinference.FunNInterface; import de.dhbwstuttgart.typeinference.FunNInterface;
import de.dhbwstuttgart.typeinference.Pair; import de.dhbwstuttgart.typeinference.Pair;
import de.dhbwstuttgart.typeinference.ResultSet; import de.dhbwstuttgart.typeinference.ResultSet;
@ -852,5 +853,24 @@ public class MyCompiler implements MyCompilerAPI
this.m_AbstractSyntaxTree.add(ret); this.m_AbstractSyntaxTree.add(ret);
return ret; return ret;
} }
@Override
public ByteCodeResult generateBytecode() {
/*
* TODO Für das Bytecode-Team:
* - generateBytecode-Methode implementieren
* - Sich einen passenden Container für den Bytecode überlegen
* - Dieser wird von generateBytecode zurückgeliefert und sollte die Möglichkeit zum schreiben von Bytecode in eine Datei bieten.
* - wird der Rückgabetyp von generateBytecode in MyCompiler geändert, so muss auch der Rückgabetyp im Interface MyCompilerAPI geändert werden
*/
try {
SourceFile parsedFile = this.m_AbstractSyntaxTree.firstElement();
Class parsedClass = parsedFile.KlassenVektor.firstElement();
return parsedClass.genByteCode();
} catch (IOException e) {
e.printStackTrace();
return null;
}
}
} }
// ino.end // ino.end

View File

@ -6,12 +6,13 @@ package de.dhbwstuttgart.core;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.parser.JavaParser; import de.dhbwstuttgart.parser.JavaParser;
import de.dhbwstuttgart.syntaxtree.SourceFile; import de.dhbwstuttgart.syntaxtree.SourceFile;
import de.dhbwstuttgart.typeinference.ByteCodeResult;
import de.dhbwstuttgart.typeinference.ResultSet; import de.dhbwstuttgart.typeinference.ResultSet;
import de.dhbwstuttgart.typeinference.TypeinferenceResultSet; import de.dhbwstuttgart.typeinference.TypeinferenceResultSet;
import de.dhbwstuttgart.typeinference.exceptions.ParserError; import de.dhbwstuttgart.typeinference.exceptions.ParserError;
@ -121,5 +122,6 @@ public interface MyCompilerAPI
*/ */
public SourceFile parse(String sourceCode) throws ParserError; public SourceFile parse(String sourceCode) throws ParserError;
public ByteCodeResult generateBytecode();
} }
// ino.end // ino.end

View File

@ -16,9 +16,9 @@ import org.apache.bcel.generic.InstructionList;
import org.apache.bcel.generic.MethodGen; import org.apache.bcel.generic.MethodGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.logger.Section; import de.dhbwstuttgart.logger.Section;
import de.dhbwstuttgart.logger.SectionLogger;
import de.dhbwstuttgart.core.AClassOrInterface; import de.dhbwstuttgart.core.AClassOrInterface;
import de.dhbwstuttgart.core.IItemWithOffset; import de.dhbwstuttgart.core.IItemWithOffset;
import de.dhbwstuttgart.parser.JavaClassName; import de.dhbwstuttgart.parser.JavaClassName;
@ -27,6 +27,7 @@ import de.dhbwstuttgart.syntaxtree.modifier.Modifiers;
import de.dhbwstuttgart.syntaxtree.statement.Block; import de.dhbwstuttgart.syntaxtree.statement.Block;
import de.dhbwstuttgart.syntaxtree.statement.Expr; import de.dhbwstuttgart.syntaxtree.statement.Expr;
import de.dhbwstuttgart.syntaxtree.statement.Statement; import de.dhbwstuttgart.syntaxtree.statement.Statement;
import de.dhbwstuttgart.syntaxtree.statement.SuperCall;
import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar; import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar;
import de.dhbwstuttgart.syntaxtree.type.RefType; import de.dhbwstuttgart.syntaxtree.type.RefType;
import de.dhbwstuttgart.syntaxtree.type.SuperWildcardType; import de.dhbwstuttgart.syntaxtree.type.SuperWildcardType;
@ -37,13 +38,16 @@ import de.dhbwstuttgart.typeinference.*;
import de.dhbwstuttgart.typeinference.assumptions.ClassAssumption; import de.dhbwstuttgart.typeinference.assumptions.ClassAssumption;
import de.dhbwstuttgart.typeinference.assumptions.TypeAssumptions; import de.dhbwstuttgart.typeinference.assumptions.TypeAssumptions;
import de.dhbwstuttgart.typeinference.exceptions.DebugException; import de.dhbwstuttgart.typeinference.exceptions.DebugException;
import de.dhbwstuttgart.typeinference.exceptions.NotImplementedException;
import de.dhbwstuttgart.typeinference.exceptions.TypeinferenceException; import de.dhbwstuttgart.typeinference.exceptions.TypeinferenceException;
import de.dhbwstuttgart.typeinference.typedeployment.TypeInsertPoint; import de.dhbwstuttgart.typeinference.typedeployment.TypeInsertPoint;
import de.dhbwstuttgart.typeinference.unify.FC_TTO; import de.dhbwstuttgart.typeinference.unify.FC_TTO;
import de.dhbwstuttgart.typeinference.unify.Unify; import de.dhbwstuttgart.typeinference.unify.Unify;
import org.apache.bcel.generic.*; import org.apache.bcel.generic.*;
import org.apache.bcel.classfile.*; import org.apache.bcel.classfile.*;
import org.apache.bcel.*; import org.apache.bcel.*;
import java.io.*; import java.io.*;
@ -57,8 +61,8 @@ public class Class extends GTVDeclarationContext implements AClassOrInterface, I
* Log4j - Loggerinstanzen * Log4j - Loggerinstanzen
*/ */
protected static Logger inferencelog = Logger.getLogger("inference"); protected static Logger inferencelog = Logger.getLogger("inference");
//protected static Logger codegenlog = Logger.getLogger("codegen"); protected static Logger codegenlog = Logger.getLogger("codegen");
//protected static Logger parserlog = Logger.getLogger("parser"); protected static Logger parserlog = Logger.getLogger("parser");
protected UsedId pkgName; protected UsedId pkgName;
protected Modifiers modifiers; protected Modifiers modifiers;
protected String name; protected String name;
@ -70,33 +74,26 @@ public class Class extends GTVDeclarationContext implements AClassOrInterface, I
//Method created with BCEL to generate ByteCode //Method created with BCEL to generate ByteCode
public ByteCodeResult genByteCode() throws IOException { public ByteCodeResult genByteCode() throws IOException {
ByteCodeResult code = new ByteCodeResult(); SectionLogger logger = Logger.getSectionLogger(this.getClass().getName(), Section.CODEGEN);
logger.debug("Test");
_cg = new ClassGen(pkgName.get_Name() + "/" + name, superClass.get_Name(), name + ".java", Constants.ACC_PUBLIC , new String[] { }); //new String necessary? if(pkgName != null)throw new NotImplementedException();
_cg = new ClassGen(name, superClass.get_Name(), name + ".java", Constants.ACC_PUBLIC , new String[] { }); //new String necessary?
_cp = _cg.getConstantPool(); _cp = _cg.getConstantPool();
_factory = new InstructionFactory(_cg, _cp); _factory = new InstructionFactory(_cg, _cp);
ByteArrayOutputStream out = new ByteArrayOutputStream();
InstructionList il = new InstructionList(); for(Field field : this.fielddecl){
MethodGen method = new MethodGen(Constants.ACC_PUBLIC, org.apache.bcel.generic.Type.VOID, org.apache.bcel.generic.Type.NO_ARGS, new String[] { }, "<init>", pkgName.get_Name() + "." + name, il, _cp); field.genByteCode(_cg);
}
InstructionHandle ih_0 = il.append(_factory.createLoad(org.apache.bcel.generic.Type.OBJECT, 0)); //creates Constructor
il.append(_factory.createInvoke("java.lang.Object", "<init>", org.apache.bcel.generic.Type.VOID, org.apache.bcel.generic.Type.NO_ARGS, Constants.INVOKESPECIAL));
InstructionHandle ih_4 = il.append(_factory.createReturn(org.apache.bcel.generic.Type.VOID)); //creates Constructor
method.setMaxStack();
method.setMaxLocals();
_cg.addMethod(method.getMethod());
il.dispose();
_cg.getJavaClass().dump(out);
code.attach(out.toString());
ByteCodeResult code = new ByteCodeResult(_cg);
return code; return code;
/*ByteCodeResult bc = new ByteCodeResult(); //ByteCodeResult bc = new ByteCodeResult();
_cg = new ClassGen(pkgName.get_Name() + "/" + name, superClass.get_Name(), name + ".java", Constants.ACC_PUBLIC , new String[] { }); //_cg = new ClassGen(pkgName.get_Name() + "/" + name, superClass.get_Name(), name + ".java", Constants.ACC_PUBLIC , new String[] { });
//_cg zurückgeben //_cg zur<EFBFBD>ckgeben
bc.append(BCELByteCodeOutput); //bc.append(BCELByteCodeOutput);
return _cg;*/ //return _cg;
} }
private Menge<Type> superif = new Menge<Type>(); private Menge<Type> superif = new Menge<Type>();
@ -1251,7 +1248,11 @@ public class Class extends GTVDeclarationContext implements AClassOrInterface, I
} }
} }
if(!constructorVorhanden){//Falls kein Konstruktor vorhanden ist, muss noch der Standardkonstruktor angefügt werden: if(!constructorVorhanden){//Falls kein Konstruktor vorhanden ist, muss noch der Standardkonstruktor angefügt werden:
Block konstruktorBlock = new Block();
konstruktorBlock.statements.add(new SuperCall(konstruktorBlock));
//Constructor standardKonstruktor = new Constructor(Method.createEmptyMethod(konstruktorBlock,this.getName().toString(), this));
Constructor standardKonstruktor = new Constructor(Method.createEmptyMethod(this.getName().toString(), this)); Constructor standardKonstruktor = new Constructor(Method.createEmptyMethod(this.getName().toString(), this));
this.addField(standardKonstruktor); this.addField(standardKonstruktor);
} }

View File

@ -1,7 +1,15 @@
package de.dhbwstuttgart.syntaxtree; package de.dhbwstuttgart.syntaxtree;
import de.dhbwstuttgart.typeinference.Menge; import org.apache.bcel.Constants;
import org.apache.bcel.classfile.ConstantPool;
import org.apache.bcel.generic.ClassGen;
import org.apache.bcel.generic.ConstantPoolGen;
import org.apache.bcel.generic.InstructionFactory;
import org.apache.bcel.generic.InstructionHandle;
import org.apache.bcel.generic.InstructionList;
import org.apache.bcel.generic.MethodGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.parser.JavaClassName; import de.dhbwstuttgart.parser.JavaClassName;
import de.dhbwstuttgart.syntaxtree.misc.DeclId; import de.dhbwstuttgart.syntaxtree.misc.DeclId;
@ -42,7 +50,30 @@ public class Constructor extends Method {
ret.addAssumption(new ConstructorAssumption(this, parentClass)); ret.addAssumption(new ConstructorAssumption(this, parentClass));
return ret; return ret;
} }
/*
@Override
public void genByteCode(ClassGen cg) {
ConstantPoolGen _cp = cg.getConstantPool();
//InstructionFactory _factory = new InstructionFactory(cg, _cp);
InstructionList il = new InstructionList(); //sollte nicht new sein sondern aus Block kommen
Class parentClass = this.getParentClass();
//Hier m<EFBFBD>sste drin stehen: Kreiere einen Block, welcher ein Statement enth<EFBFBD>lt, welches ein Super Statement ist.
//TODO: Alles dynamisch gestalten
//init darf nur drin stehen, wenn Konstruktor;
methode.method = new MethodGen(Constants.ACC_PUBLIC, org.apache.bcel.generic.Type.getReturnType(methode.getType().get_Name()), org.apache.bcel.generic.Type.NO_ARGS , new String[] { }, "<init>", parentClass.name, il, _cp);
methode.genByteCode(cg); //Aufrufen um Iteration <EFBFBD>ber Block zu starten
}
// super statement muss drin sein
// stmt genByteCode + im block genByteCode implementieren & dann Hierarchie ausprobieren
// de.dhbw.systanxtree.stmts supercall
// Aufrufhierarchie: Class->Felder->Konstruktor->Methode innerhalb Konstruktor->Block->Statements (in diesem Fall nur super())->hier wird bytecode f<EFBFBD>r superaufruf generiert
@Override @Override
public void parserPostProcessing(SyntaxTreeNode parent){ public void parserPostProcessing(SyntaxTreeNode parent){
if(this.parameterlist != null){ if(this.parameterlist != null){
@ -54,7 +85,7 @@ public class Constructor extends Method {
gtv.parserPostProcessing(this); gtv.parserPostProcessing(this);
} }
} }
*/
@Override @Override
public ConstraintsSet TYPE(TypeAssumptions ass) { public ConstraintsSet TYPE(TypeAssumptions ass) {
//super.setType(this.getParentClass().getType()); //super.setType(this.getParentClass().getType());
@ -67,13 +98,13 @@ public class Constructor extends Method {
//throw new TypeinferenceException("Einem Konstruktor kann kein Typ zugewiesen werden", this); //throw new TypeinferenceException("Einem Konstruktor kann kein Typ zugewiesen werden", this);
//this.methode.setType(t); //this.methode.setType(t);
} }
/*
public Constructor(Method methode){ /*public Constructor(Method methode){
super(methode.getOffset()); super(methode.getOffset());
this.methode = methode; this.methode = methode;
this.setDeclIdMenge(methode.getDeclIdMenge()); this.setDeclIdMenge(methode.getDeclIdMenge());
this.methode.setType(this.methode.getParentClass().getType()); this.methode.setType(this.methode.getParentClass().getType());
} }*/
@Override @Override
public Menge<GenericTypeVar> getGenericParameter() { public Menge<GenericTypeVar> getGenericParameter() {
@ -198,11 +229,11 @@ public class Constructor extends Method {
this.methode.setOverloadedID(overloadedID); this.methode.setOverloadedID(overloadedID);
} }
@Override /*@Override
public String get_codegen_Param_Type(Menge paralist) { public String get_codegen_Param_Type(Menge paralist) {
return this.methode.get_codegen_Param_Type(paralist); return this.methode.get_codegen_Param_Type(paralist);
} }*/
@Override @Override
public String get_Method_Name() { public String get_Method_Name() {
@ -216,12 +247,12 @@ public class Constructor extends Method {
return this.methode.get_Type_Paralist(); return this.methode.get_Type_Paralist();
} }
@Override /*@Override
public void codegen(ClassFile classfile, Menge paralist) public void codegen(ClassFile classfile, Menge paralist)
throws JVMCodeException { throws JVMCodeException {
this.methode.codegen(classfile, paralist); this.methode.codegen(classfile, paralist);
} }*/
@Override @Override
public int getLineNumber() { public int getLineNumber() {
@ -285,15 +316,14 @@ public class Constructor extends Method {
@Override @Override
public void set_Method_Name(String string) { public void set_Method_Name(String string) {
this.methode.set_Method_Name(string); this.methode.set_Method_Name(string);
} }
public ConstraintsSet TYPE(TypeAssumptions ass) { /*public ConstraintsSet TYPE(TypeAssumptions ass) {
ConstraintsSet ret = new ConstraintsSet(); ConstraintsSet ret = new ConstraintsSet();
ret.add(this.methode.get_Block().TYPEStmt(ass)); ret.add(this.methode.get_Block().TYPEStmt(ass));
return ret; return ret;
} }*/
@Override @Override
public String getTypeInformation() { public String getTypeInformation() {
@ -307,24 +337,24 @@ public class Constructor extends Method {
return this.methode.printJavaCode(resultSet); return this.methode.printJavaCode(resultSet);
} }
@Override /*@Override
public TypeAssumptions createTypeAssumptions(Class classmember) { public TypeAssumptions createTypeAssumptions(Class classmember) {
Class parentClass = this.getParentClass(); Class parentClass = this.getParentClass();
TypeAssumptions ret = new TypeAssumptions(); TypeAssumptions ret = new TypeAssumptions();
ret.addAssumption(new ConstructorAssumption(this, parentClass)); ret.addAssumption(new ConstructorAssumption(this, parentClass));
return ret; return ret;
} }*/
@Override @Override
public SyntaxTreeNode getParent(){ public SyntaxTreeNode getParent(){
return this.methode.getParent(); return this.methode.getParent();
} }
@Override /*@Override
public void parserPostProcessing(SyntaxTreeNode parent) { public void parserPostProcessing(SyntaxTreeNode parent) {
this.methode.parserPostProcessing(parent); this.methode.parserPostProcessing(parent);
} }*/
@Override @Override
public Menge<SyntaxTreeNode> getChildren() { public Menge<SyntaxTreeNode> getChildren() {
@ -332,11 +362,11 @@ public class Constructor extends Method {
return this.methode.getChildren(); return this.methode.getChildren();
} }
@Override /*@Override
public void setType(Type t) { public void setType(Type t) {
throw new TypeinferenceException("Einem Konstruktor kann kein Typ zugewiesen werden", this); throw new TypeinferenceException("Einem Konstruktor kann kein Typ zugewiesen werden", this);
//this.methode.setType(t); //this.methode.setType(t);
} }*/
@Override @Override
public Type getType() { public Type getType() {
@ -390,7 +420,7 @@ public class Constructor extends Method {
public Class getParentClass() { public Class getParentClass() {
return this.methode.getParentClass(); return this.methode.getParentClass();
} }
*/
} }

View File

@ -1,7 +1,8 @@
package de.dhbwstuttgart.syntaxtree; package de.dhbwstuttgart.syntaxtree;
import de.dhbwstuttgart.typeinference.Menge; import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.syntaxtree.misc.DeclId; import de.dhbwstuttgart.syntaxtree.misc.DeclId;
import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar; import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar;
@ -171,4 +172,11 @@ public abstract class Field extends GTVDeclarationContext implements TypeInserta
public boolean isClass() { public boolean isClass() {
return false; return false;
} }
/**
* Fügt das das Feld zu ClassGen hinzu
* @param cg
*/
public abstract void genByteCode(ClassGen cg);
} }

View File

@ -1,7 +1,8 @@
package de.dhbwstuttgart.syntaxtree; package de.dhbwstuttgart.syntaxtree;
import de.dhbwstuttgart.typeinference.Menge; import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.syntaxtree.misc.DeclId; import de.dhbwstuttgart.syntaxtree.misc.DeclId;
import de.dhbwstuttgart.syntaxtree.statement.Expr; import de.dhbwstuttgart.syntaxtree.statement.Expr;
@ -157,4 +158,16 @@ public class FieldDeclaration extends Field{
if(this.getWert()!=null)this.getWert().wandleRefTypeAttributes2GenericAttributes(paralist, new Menge<GenericTypeVar>()); //FieldDeclaration hat keine Generischen Variablen, daher leere Liste übergeben if(this.getWert()!=null)this.getWert().wandleRefTypeAttributes2GenericAttributes(paralist, new Menge<GenericTypeVar>()); //FieldDeclaration hat keine Generischen Variablen, daher leere Liste übergeben
} }
@Override
public void genByteCode(ClassGen cg) {
// TODO Auto-generated method stub
}
/*@Override
public void genByteCode(ClassGen cg) {
// TODO Auto-generated method stub
}*/
} }

View File

@ -1,14 +1,22 @@
// ino.module.Method.8564.package // ino.module.Method.8564.package
package de.dhbwstuttgart.syntaxtree; package de.dhbwstuttgart.syntaxtree;
// ino.end // ino.end
// ino.module.Method.8564.import // ino.module.Method.8564.import
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.Constants;
import org.apache.bcel.generic.ClassGen;
import org.apache.bcel.generic.ConstantPoolGen;
import org.apache.bcel.generic.InstructionFactory;
import org.apache.bcel.generic.InstructionHandle;
import org.apache.bcel.generic.InstructionList;
import org.apache.bcel.generic.MethodGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.core.IItemWithOffset; import de.dhbwstuttgart.core.IItemWithOffset;
import de.dhbwstuttgart.core.MyCompiler; import de.dhbwstuttgart.core.MyCompiler;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -19,6 +27,7 @@ import de.dhbwstuttgart.syntaxtree.misc.DeclId;
import de.dhbwstuttgart.syntaxtree.modifier.Modifiers; import de.dhbwstuttgart.syntaxtree.modifier.Modifiers;
import de.dhbwstuttgart.syntaxtree.statement.Block; import de.dhbwstuttgart.syntaxtree.statement.Block;
import de.dhbwstuttgart.syntaxtree.statement.Return; import de.dhbwstuttgart.syntaxtree.statement.Return;
import de.dhbwstuttgart.syntaxtree.statement.Statement;
import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar; import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar;
import de.dhbwstuttgart.syntaxtree.type.RefType; import de.dhbwstuttgart.syntaxtree.type.RefType;
import de.dhbwstuttgart.syntaxtree.type.Type; import de.dhbwstuttgart.syntaxtree.type.Type;
@ -34,13 +43,12 @@ import de.dhbwstuttgart.typeinference.assumptions.TypeAssumptions;
import de.dhbwstuttgart.typeinference.exceptions.TypeinferenceException; import de.dhbwstuttgart.typeinference.exceptions.TypeinferenceException;
import de.dhbwstuttgart.typeinference.typedeployment.TypeInsertPoint; import de.dhbwstuttgart.typeinference.typedeployment.TypeInsertPoint;
// ino.class.Method.23482.declaration // ino.class.Method.23482.declaration
/** /**
* Stellt eine Methode dar. * Stellt eine Methode dar. Problem: Parser kann nicht zwischen Methode und
* Problem: Parser kann nicht zwischen Methode und Konstruktor unterscheiden. Daher kann diese Klasse beides sein. Dies wird mit dem ParserPostProcessing behoben. * Konstruktor unterscheiden. Daher kann diese Klasse beides sein. Dies wird mit
* dem ParserPostProcessing behoben.
*
* @author janulrich * @author janulrich
* *
*/ */
@ -60,17 +68,17 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
// ino.attribute.returntype.23497.declaration // ino.attribute.returntype.23497.declaration
private Type returntype; private Type returntype;
// ino.end // ino.end
protected MethodGen method;
// ino.attribute.genericMethodParameters.23500.decldescription type=javadoc // ino.attribute.genericMethodParameters.23500.decldescription type=javadoc
/** /**
* HOTI 4.5.06 * HOTI 4.5.06 Dieser Vektor beinhaltet alle Generischen Typen und v.a. die
* Dieser Vektor beinhaltet alle Generischen Typen und v.a. die * F-Bounded-Generics, die die Methode besitzt size()==0, falls es keine
* F-Bounded-Generics, die die Methode besitzt * gibt
* size()==0, falls es keine gibt
*/ */
// ino.end // ino.end
// ino.attribute.genericMethodParameters.23500.declaration // ino.attribute.genericMethodParameters.23500.declaration
//private Menge<GenericTypeVar> genericMethodParameters=new Menge<GenericTypeVar>(); // private Menge<GenericTypeVar> genericMethodParameters=new
// Menge<GenericTypeVar>();
// ino.end // ino.end
// ino.attribute.overloadedID.23503.declaration // ino.attribute.overloadedID.23503.declaration
@ -91,18 +99,20 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
// ino.end // ino.end
// ino.attribute.parserlog.23518.declaration // ino.attribute.parserlog.23518.declaration
protected static Logger parserlog = Logger.getLogger("parser"); protected static Logger parserlog = Logger.getLogger("parser");
// ino.end // ino.end
public Method(int offset) { public Method(int offset) {
super(offset); super(offset);
} }
public Method(String name, Type returnType, ParameterList parameterList, Block block, GenericDeclarationList gtvDeclarations, int offset){ public Method(String name, Type returnType, ParameterList parameterList,
Block block, GenericDeclarationList gtvDeclarations, int offset) {
this(offset); this(offset);
/* /*
if(parameterList != null)parameterList.parserPostProcessing(this); * if(parameterList != null)parameterList.parserPostProcessing(this);
if(block != null)block.parserPostProcessing(this); * if(block != null)block.parserPostProcessing(this); if(gtvDeclarations
if(gtvDeclarations != null)gtvDeclarations.parserPostProcessing(this); * != null)gtvDeclarations.parserPostProcessing(this);
*/ */
this.set_Method_Name(name); this.set_Method_Name(name);
this.setParameterList(parameterList); this.setParameterList(parameterList);
@ -112,65 +122,40 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
} }
/* /*
// ino.method.setGenericMethodParameters.23521.definition * // ino.method.setGenericMethodParameters.23521.definition public void
public void setGenericMethodParameters(Menge<GenericTypeVar> genericMethodParameters) * setGenericMethodParameters(Menge<GenericTypeVar> genericMethodParameters)
// ino.end * // ino.end // ino.method.setGenericMethodParameters.23521.body {
// ino.method.setGenericMethodParameters.23521.body * this.genericMethodParameters=genericMethodParameters; } // ino.end //
{ * ino.method.getGenericMethodParameters.23524.definition public
this.genericMethodParameters=genericMethodParameters; * Menge<GenericTypeVar> getGenericMethodParameters() // ino.end //
} * ino.method.getGenericMethodParameters.23524.body {
// ino.end * return(genericMethodParameters); } // ino.end
// ino.method.getGenericMethodParameters.23524.definition
public Menge<GenericTypeVar> getGenericMethodParameters()
// ino.end
// ino.method.getGenericMethodParameters.23524.body
{
return(genericMethodParameters);
}
// ino.end
*/ */
/* /*
// ino.method.sc_init_parameterlist.23530.definition * // ino.method.sc_init_parameterlist.23530.definition public void
public void sc_init_parameterlist(boolean ext) * sc_init_parameterlist(boolean ext) // ino.end //
// ino.end * ino.method.sc_init_parameterlist.23530.body { DeclId hilf=null;
// ino.method.sc_init_parameterlist.23530.body * Menge<FormalParameter> list; FormalParameter para; String typeofpara; int
{ * i=1; if(this.getParameterList()!=null) //es gibt Parameter, dann: {
DeclId hilf=null; * hilf=declid.elementAt(0); if(ext)
Menge<FormalParameter> list; * parserlog.debug("Semantik-Check hat in Methode "
FormalParameter para; * +hilf.get_Name()+" bergabewerte gefunden:");
String typeofpara; * list=this.getParameterList().sc_get_Formalparalist(); //Menge
int i=1; * Formalparalist aus FormalParameterList wird zwischen gesichert
if(this.getParameterList()!=null) //es gibt Parameter, dann: * for(Enumeration<FormalParameter> el2=list.elements();
{ * el2.hasMoreElements();) { para=el2.nextElement();
hilf=declid.elementAt(0); * typeofpara=para.getTypeName(); if(ext)
if(ext) * parserlog.debug(" "+i+". Parameter hat Typ "+typeofpara);
parserlog.debug("Semantik-Check hat in Methode "+hilf.get_Name()+" bergabewerte gefunden:"); * types_in_parameterlist.addElement(typeofpara); //Typ der Parameter werden
list=this.getParameterList().sc_get_Formalparalist(); //Menge Formalparalist aus FormalParameterList wird zwischen gesichert * im Menge abgelegt i++; } } else //keine Parameter vorhanden: { if(ext) {
for(Enumeration<FormalParameter> el2=list.elements(); el2.hasMoreElements();) * hilf=declid.elementAt(0);
{ * parserlog.debug("Semantik-Check hat in Methode "
para=el2.nextElement(); * +hilf.get_Name()+" keine bergabewerte gefunden."); } } if(ext) {
typeofpara=para.getTypeName(); * parserlog.debug("Semantik-Check hat in Methode "+hilf.get_Name()+" "+
if(ext) * types_in_parameterlist.size()+" bergabeparameter gefunden.");
parserlog.debug(" "+i+". Parameter hat Typ "+typeofpara); * parserlog.debug
types_in_parameterlist.addElement(typeofpara); //Typ der Parameter werden im Menge abgelegt * (" namentlich: "+types_in_parameterlist.toString()); } } //
i++; * ino.end
}
}
else //keine Parameter vorhanden:
{
if(ext)
{
hilf=declid.elementAt(0);
parserlog.debug("Semantik-Check hat in Methode "+hilf.get_Name()+" keine bergabewerte gefunden.");
}
}
if(ext)
{
parserlog.debug("Semantik-Check hat in Methode "+hilf.get_Name()+" "+ types_in_parameterlist.size()+" bergabeparameter gefunden.");
parserlog.debug(" namentlich: "+types_in_parameterlist.toString());
}
}
// ino.end
*/ */
// ino.method.getTypeName.23533.defdescription type=line // ino.method.getTypeName.23533.defdescription type=line
// Eine der beiden Funktionen ist ueberflssig. Wer sich daran strt kann die // Eine der beiden Funktionen ist ueberflssig. Wer sich daran strt kann die
@ -187,6 +172,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
else else
return this.getType().getName(); return this.getType().getName();
} }
// ino.end // ino.end
// ino.method.get_Block.23536.definition // ino.method.get_Block.23536.definition
@ -196,11 +182,14 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
return block; return block;
} }
// ino.end // ino.end
// ino.method.setReturnType.23539.defdescription type=javadoc // ino.method.setReturnType.23539.defdescription type=javadoc
/** /**
* <br/>Author: Jrg Buerle * <br/>
* Author: Jrg Buerle
*
* @param type * @param type
*/ */
// ino.end // ino.end
@ -211,6 +200,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
this.returntype = type; this.returntype = type;
} }
// ino.end // ino.end
// ino.method.set_Block.23542.definition // ino.method.set_Block.23542.definition
@ -218,9 +208,11 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
// ino.end // ino.end
// ino.method.set_Block.23542.body // ino.method.set_Block.23542.body
{ {
if(blo.getType() == null)blo.setType(this.returntype); if (blo.getType() == null)
blo.setType(this.returntype);
this.block = blo; this.block = blo;
} }
// ino.end // ino.end
// ino.method.set_Modifiers.23545.definition // ino.method.set_Modifiers.23545.definition
@ -231,6 +223,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
declid.firstElement().set_Modifiers(modif); declid.firstElement().set_Modifiers(modif);
// this.modi = modif; // this.modi = modif;
} }
// ino.end // ino.end
// ino.method.set_ExceptionList.23548.definition // ino.method.set_ExceptionList.23548.definition
@ -240,6 +233,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
this.exceptionlist = exlist; this.exceptionlist = exlist;
} }
// ino.end // ino.end
// ino.method.setParameterList.23551.definition // ino.method.setParameterList.23551.definition
@ -249,6 +243,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
this.parameterlist = paralist; this.parameterlist = paralist;
} }
// ino.end // ino.end
// ino.method.getParameterList.23554.definition // ino.method.getParameterList.23554.definition
@ -259,11 +254,13 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
// otth: gibt die Parameterliste zurueck // otth: gibt die Parameterliste zurueck
return this.parameterlist; return this.parameterlist;
} }
// ino.end // ino.end
// ino.method.getParameterCount.23557.defdescription type=javadoc // ino.method.getParameterCount.23557.defdescription type=javadoc
/** /**
* Author: Jrg Buerle<br/> * Author: Jrg Buerle<br/>
*
* @return Die Anzahl der Methoden-Paramater * @return Die Anzahl der Methoden-Paramater
*/ */
// ino.end // ino.end
@ -277,6 +274,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
else else
return this.getParameterList().getParameterCount(); return this.getParameterList().getParameterCount();
} }
// ino.end // ino.end
// ino.method.get_ExceptionList.23560.definition // ino.method.get_ExceptionList.23560.definition
@ -287,6 +285,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
// otth: gibt die Exceptionliste zurueck // otth: gibt die Exceptionliste zurueck
return this.exceptionlist; return this.exceptionlist;
} }
// ino.end // ino.end
// ino.method.getOverloadedID.23563.definition // ino.method.getOverloadedID.23563.definition
@ -296,6 +295,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
return (overloadedID); return (overloadedID);
} }
// ino.end // ino.end
// ino.method.setOverloadedID.23566.definition // ino.method.setOverloadedID.23566.definition
@ -305,12 +305,9 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
this.overloadedID = overloadedID; this.overloadedID = overloadedID;
} }
// ino.end // ino.end
// ino.method.get_Method_Name.23575.definition // ino.method.get_Method_Name.23575.definition
public String get_Method_Name() public String get_Method_Name()
// ino.end // ino.end
@ -319,6 +316,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
DeclId hilf = declid.elementAt(0); DeclId hilf = declid.elementAt(0);
return hilf.get_Name(); return hilf.get_Name();
} }
// ino.end // ino.end
// ino.method.get_Type_Paralist.23578.definition // ino.method.get_Type_Paralist.23578.definition
@ -328,10 +326,9 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
return types_in_parameterlist; return types_in_parameterlist;
} }
// ino.end // ino.end
// ino.method.getLineNumber.23584.definition // ino.method.getLineNumber.23584.definition
public int getLineNumber() public int getLineNumber()
// ino.end // ino.end
@ -339,6 +336,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
return m_LineNumber; return m_LineNumber;
} }
// ino.end // ino.end
// ino.method.setLineNumber.23587.definition // ino.method.setLineNumber.23587.definition
@ -348,6 +346,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
m_LineNumber = lineNumber; m_LineNumber = lineNumber;
} }
// ino.end // ino.end
// ino.method.getOffset.23590.defdescription type=line // ino.method.getOffset.23590.defdescription type=line
@ -360,6 +359,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
return m_Offset; return m_Offset;
} }
// ino.end // ino.end
// ino.method.getVariableLength.23593.definition // ino.method.getVariableLength.23593.definition
@ -369,6 +369,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
return get_Method_Name().length(); return get_Method_Name().length();
} }
// ino.end // ino.end
// ino.method.setOffset.23596.defdescription type=line // ino.method.setOffset.23596.defdescription type=line
@ -381,12 +382,14 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
m_Offset = Offset; m_Offset = Offset;
} }
// ino.end
// ino.end
// ino.method.getTypeLineNumber.23602.defdescription type=javadoc // ino.method.getTypeLineNumber.23602.defdescription type=javadoc
/** /**
* <br>Author: Jrg Buerle * <br>
* Author: Jrg Buerle
*
* @return * @return
*/ */
// ino.end // ino.end
@ -397,11 +400,14 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
return this.getLineNumber(); return this.getLineNumber();
} }
// ino.end // ino.end
// ino.method.toString.23605.defdescription type=javadoc // ino.method.toString.23605.defdescription type=javadoc
/** /**
* <br/>Author: Martin Pl�micke * <br/>
* Author: Martin Pl�micke
*
* @return * @return
*/ */
// ino.end // ino.end
@ -410,14 +416,16 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
// ino.end // ino.end
// ino.method.toString.23605.body // ino.method.toString.23605.body
{ {
return this.getType() + " "+ this.get_Name() +( (block!=null)?block.toString():""); return this.getType() + " " + this.get_Name()
+ ((block != null) ? block.toString() : "");
} }
// ino.end // ino.end
// ino.method.setAbstract.23608.defdescription type=javadoc // ino.method.setAbstract.23608.defdescription type=javadoc
/** /**
* Legt fuer die ByteCodeGen fest, ob Bytecode * Legt fuer die ByteCodeGen fest, ob Bytecode innerhalb der Methode
* innerhalb der Methode generiert wird. * generiert wird.
*/ */
// ino.end // ino.end
// ino.method.setAbstract.23608.definition // ino.method.setAbstract.23608.definition
@ -427,12 +435,12 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
{ {
isAbstract = b; isAbstract = b;
} }
// ino.end // ino.end
// ino.method.isAbstract.23611.defdescription type=javadoc // ino.method.isAbstract.23611.defdescription type=javadoc
/** /**
* Gibt zurueck, ob ByteCode innerhabl der Methode * Gibt zurueck, ob ByteCode innerhabl der Methode generiert wird.
* generiert wird.
*/ */
// ino.end // ino.end
// ino.method.isAbstract.23611.definition // ino.method.isAbstract.23611.definition
@ -444,50 +452,47 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
} }
@Override @Override
public void wandleRefTypeAttributes2GenericAttributes(Menge<Type> classParalist) public void wandleRefTypeAttributes2GenericAttributes(
{ Menge<Type> classParalist) {
/* /*
Menge<Type> paralist = new Menge<Type>();//Mit den Generischen Typen der Methode * Menge<Type> paralist = new Menge<Type>();//Mit den Generischen Typen
paralist.addAll(classParalist); * der Methode paralist.addAll(classParalist);
paralist.addAll(this.genericMethodParameters); * paralist.addAll(this.genericMethodParameters);
*
// Zuerst Returntype untersuchen * // Zuerst Returntype untersuchen Type returnType=getType(); Type
Type returnType=getType(); * pendantReturnType = null; if(returnType instanceof
Type pendantReturnType = null; * RefType)pendantReturnType =
if(returnType instanceof RefType)pendantReturnType = ((RefType)returnType).findGenericType(paralist, new Menge<GenericTypeVar>()); * ((RefType)returnType).findGenericType(paralist, new
//GenericTypeVar pendantReturnType=ClassHelper.findGenericType(returnType, paralist,genericMethodParameters); * Menge<GenericTypeVar>()); //GenericTypeVar
if(pendantReturnType!=null){ //Wenn generisch, dann modifizieren * pendantReturnType=ClassHelper.findGenericType(returnType,
setReturnType(pendantReturnType); * paralist,genericMethodParameters); if(pendantReturnType!=null){
} * //Wenn generisch, dann modifizieren setReturnType(pendantReturnType);
* }
// Dann parameterlist untersuchen *
for(int par=0;par<getParameterCount();par++){ * // Dann parameterlist untersuchen for(int
FormalParameter fp=parameterlist.formalparameter.get(par); * par=0;par<getParameterCount();par++){ FormalParameter
Type fpType=fp.getType(); * fp=parameterlist.formalparameter.get(par); Type fpType=fp.getType();
// Nur wenn es sich um ein RefType-Field handelt * // Nur wenn es sich um ein RefType-Field handelt Type pendantPara =
Type pendantPara = null; * null; if(fpType instanceof RefType)pendantPara =
if(fpType instanceof RefType)pendantPara = ((RefType)fpType).findGenericType(paralist, new Menge<GenericTypeVar>()); * ((RefType)fpType).findGenericType(paralist, new
//GenericTypeVar pendantPara=ClassHelper.findGenericType(fpType,paralist,genericMethodParameters); * Menge<GenericTypeVar>()); //GenericTypeVar
if(pendantPara!=null){ //Wenn generisch, dann modifizieren * pendantPara=ClassHelper.findGenericType
fp.setType(pendantPara); * (fpType,paralist,genericMethodParameters); if(pendantPara!=null){
} * //Wenn generisch, dann modifizieren fp.setType(pendantPara); } }
} *
* // Zuletzt alle Lokalen Variablendeklarationen durchgehen
// Zuletzt alle Lokalen Variablendeklarationen durchgehen * if(block!=null){
if(block!=null){ * block.wandleRefTypeAttributes2GenericAttributes(paralist
block.wandleRefTypeAttributes2GenericAttributes(paralist,genericMethodParameters); * ,genericMethodParameters); }
}
*/ */
} }
public void set_Method_Name(String string) public void set_Method_Name(String string) {
{ if (declid.size() == 0)
if(declid.size()==0)declid.add(0, new DeclId(string)); declid.add(0, new DeclId(string));
declid.set(0, new DeclId(string)); declid.set(0, new DeclId(string));
} }
public ConstraintsSet TYPE(TypeAssumptions ass) { public ConstraintsSet TYPE(TypeAssumptions ass) {
ConstraintsSet ret = new ConstraintsSet(); ConstraintsSet ret = new ConstraintsSet();
TypeAssumptions localAss = new TypeAssumptions(); TypeAssumptions localAss = new TypeAssumptions();
@ -503,34 +508,36 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
// TypeCheck, falls es sich um einen RefType handelt: // TypeCheck, falls es sich um einen RefType handelt:
this.returntype = this.returntype.checkTYPE(localAss, this); this.returntype = this.returntype.checkTYPE(localAss, this);
/* /*
if(this.returntype!=null && (this.returntype instanceof RefType)&& * if(this.returntype!=null && (this.returntype instanceof RefType)&&
!(this.returntype instanceof mycompiler.mytype.Void)){//Sonderfall der Methode: Ihr Typ darf Void definiert werden. * !(this.returntype instanceof mycompiler.mytype.Void)){//Sonderfall
Type replaceType = null; * der Methode: Ihr Typ darf Void definiert werden. Type replaceType =
replaceType = ass.getTypeFor((RefType)this.returntype); * null; replaceType = ass.getTypeFor((RefType)this.returntype);
if(replaceType == null)throw new TypeinferenceException("Der Typ "+this.getType().getName()+" ist nicht korrekt",this); * if(replaceType == null)throw new
this.returntype = replaceType; * TypeinferenceException("Der Typ "+this
} * .getType().getName()+" ist nicht korrekt",this); this.returntype =
* replaceType; }
*/ */
// Die Parameter zu den Assumptions hinzufügen: // Die Parameter zu den Assumptions hinzufügen:
if(this.parameterlist!=null)for(FormalParameter param : this.parameterlist){ if (this.parameterlist != null)
for (FormalParameter param : this.parameterlist) {
param.setType(param.getType().checkTYPE(localAss, this)); param.setType(param.getType().checkTYPE(localAss, this));
/* /*
if(param.getType() instanceof RefType) * if(param.getType() instanceof RefType) { Type replaceType =
{ * null; replaceType = ass.getTypeFor((RefType)param.getType());
Type replaceType = null; * if(replaceType == null) throw new
replaceType = ass.getTypeFor((RefType)param.getType()); * TypeinferenceException("Der Typ "
if(replaceType == null) * +param.getType().getName()+" ist nicht korrekt",param);
throw new TypeinferenceException("Der Typ "+param.getType().getName()+" ist nicht korrekt",param); * param.setType(replaceType); }
param.setType(replaceType);
}
*/ */
localAss.addAssumption(new ParameterAssumption(param)); localAss.addAssumption(new ParameterAssumption(param));
} }
ret.add(this.block.TYPEStmt(localAss)); ret.add(this.block.TYPEStmt(localAss));
//eine Verknüpfung mit der Type Assumption aus dem Assumption Set und dem ermittelten Typ der Methode: // eine Verknüpfung mit der Type Assumption aus dem Assumption Set
ret.add(new SingleConstraint(this.block.getType().TYPE(localAss, this), this.returntype.TYPE(localAss, this))); // und dem ermittelten Typ der Methode:
ret.add(new SingleConstraint(this.block.getType().TYPE(localAss, this),
this.returntype.TYPE(localAss, this)));
return ret; return ret;
} }
@ -539,14 +546,21 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
* @return die TypInformationen der Statements dieser Methode. * @return die TypInformationen der Statements dieser Methode.
*/ */
public String getTypeInformation() { public String getTypeInformation() {
if(this.parameterlist!=null)return "Methode "+this.get_Name()+ " Parameter: "+this.parameterlist.getTypeInformation()+", Block: "+this.block.getTypeInformation(); if (this.parameterlist != null)
return "Methode "+this.get_Name()+" : "+this.getType()+", Block: "+this.block.getTypeInformation(); return "Methode " + this.get_Name() + " Parameter: "
+ this.parameterlist.getTypeInformation() + ", Block: "
+ this.block.getTypeInformation();
return "Methode " + this.get_Name() + " : " + this.getType()
+ ", Block: " + this.block.getTypeInformation();
} }
@Override @Override
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.get_Method_Name()).attach("(").attach(this.getParameterList().printJavaCode(resultSet)).attach(")\n"); ret.attach(this.getType().printJavaCode(resultSet)).attach(" ")
.attach(this.get_Method_Name()).attach("(")
.attach(this.getParameterList().printJavaCode(resultSet))
.attach(")\n");
ret.attach(this.block.printJavaCode(resultSet)); ret.attach(this.block.printJavaCode(resultSet));
return ret; return ret;
@ -562,102 +576,105 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
ret.addAssumption(new MethodAssumption(this, parentClass)); ret.addAssumption(new MethodAssumption(this, parentClass));
return ret; return ret;
/* /*
TypeAssumptions assumptions = new TypeAssumptions(); * TypeAssumptions assumptions = new TypeAssumptions(); this.assumedType
this.assumedType = null; * = null; //if((this.get_Method_Name().equals(classmember.getName()) ||
//if((this.get_Method_Name().equals(classmember.getName()) || this.get_Method_Name().equals("<init>")) && ((this.getType().equals(new mycompiler.mytype.Void(0))) || this.getType() instanceof TypePlaceholder)){ * this.get_Method_Name().equals("<init>")) &&
if((this.get_Method_Name().equals(classmember.getName()) || this.get_Method_Name().equals("<init>"))) { * ((this.getType().equals(new mycompiler.mytype.Void(0))) ||
this.set_Method_Name("<init>"); * this.getType() instanceof TypePlaceholder)){
this.assumedType = new RefType(classmember.getName(),0); * if((this.get_Method_Name().equals(classmember.getName()) ||
this.setReturnType(this.assumedType); * this.get_Method_Name().equals("<init>"))) {
this.assumedType = new RefType("void",0); * this.set_Method_Name("<init>"); this.assumedType = new
//Return constructorReturnStatement = new Return(0,0); * RefType(classmember.getName(),0);
//constructorReturnStatement.retexpr = * this.setReturnType(this.assumedType); this.assumedType = new
//this.block.statements.add(constructorReturnStatement); * RefType("void",0); //Return constructorReturnStatement = new
} * Return(0,0); //constructorReturnStatement.retexpr =
//hoth: 06.04.2006 * //this.block.statements.add(constructorReturnStatement); } //hoth:
//durchlaufe Block und suche nach Objektvariablen fuer Offset-Markierung * 06.04.2006 //durchlaufe Block und suche nach Objektvariablen fuer
Iterator<CTypeAssumption> fieldVarIterator = assumptions.iterator(); * Offset-Markierung Iterator<CTypeAssumption> fieldVarIterator =
while (fieldVarIterator.hasNext()) * assumptions.iterator(); while (fieldVarIterator.hasNext()) { //Wenn
{ * ObjektVariable CTypeAssumption dieAssum = fieldVarIterator.next();
//Wenn ObjektVariable * if(dieAssum instanceof CInstVarTypeAssumption) {
CTypeAssumption dieAssum = fieldVarIterator.next(); * Class.isFirstLocalVarDecl=false; if(this.get_Block() != null)
if(dieAssum instanceof CInstVarTypeAssumption) * this.get_Block
{ * ().addOffsetsToAssumption(dieAssum,dieAssum.getIdentifier(),true); }
Class.isFirstLocalVarDecl=false; * }
if(this.get_Block() != null) *
this.get_Block().addOffsetsToAssumption(dieAssum,dieAssum.getIdentifier(),true); * //methodList.addElement(method);
} *
} * //¯Â¿Â½r V_fields_methods: CMethodTypeAssumption methodAssum
* = new CMethodTypeAssumption(classmember.getType(),
//methodList.addElement(method); * this.get_Method_Name(), this.getType(),
* this.getParameterCount(),this.getLineNumber(),this.getOffset(),new
//¯Â¿Â½r V_fields_methods: * Menge<Integer>(),this.getGenericMethodParameters()); // Typannahme
CMethodTypeAssumption methodAssum = new CMethodTypeAssumption(classmember.getType(), this.get_Method_Name(), this.getType(), this.getParameterCount(),this.getLineNumber(),this.getOffset(),new Menge<Integer>(),this.getGenericMethodParameters()); // Typannahme bauen... * bauen...
*
*
//Methode in V_Fields_methods ablegen * //Methode in V_Fields_methods ablegen //Dabei wird die
//Dabei wird die OverloadedMethodID ermittelt !! * OverloadedMethodID ermittelt !! //=> Method setzenuct
//=> Method setzenuct *
*
* assumptions.add(methodAssum);
assumptions.add(methodAssum); * this.setOverloadedID(methodAssum.getHashSetKey
this.setOverloadedID(methodAssum.getHashSetKey().getOverloadedMethodID()); * ().getOverloadedMethodID());
*
*
//¯Â¿Â½r die V_i: * //¯Â¿Â½r die V_i: CTypeAssumptionSet localAssum = new
CTypeAssumptionSet localAssum = new CTypeAssumptionSet(); * CTypeAssumptionSet();
*
//Bauen... * //Bauen... ParameterList parameterList = this.getParameterList();
ParameterList parameterList = this.getParameterList(); * if(parameterList!=null){ for(int i=0;
if(parameterList!=null){ * i<parameterList.sc_get_Formalparalist().size(); i++){ FormalParameter
for(int i=0; i<parameterList.sc_get_Formalparalist().size(); i++){ * para = parameterList.sc_get_Formalparalist().elementAt(i); //
FormalParameter para = parameterList.sc_get_Formalparalist().elementAt(i); * ¯Â¿Â½r V_fields_methods: CParaTypeAssumption paraAssum = new
// ¯Â¿Â½r V_fields_methods: * CParaTypeAssumption(classmember.getName(), this.get_Method_Name(),
CParaTypeAssumption paraAssum = new CParaTypeAssumption(classmember.getName(), this.get_Method_Name(), this.getParameterCount(), this.getOverloadedID(),para.get_Name(), para.getType(), para.getLineNumber(),para.getOffset(),new Menge<Integer>()); * this.getParameterCount(), this.getOverloadedID(),para.get_Name(),
//fuege Offsets fuer Parameter hinzu, hoth: 06.04.2006 * para.getType(), para.getLineNumber(),para.getOffset(),new
Class.isFirstLocalVarDecl=false; * Menge<Integer>()); //fuege Offsets fuer Parameter hinzu, hoth:
* 06.04.2006 Class.isFirstLocalVarDecl=false;
if(this.get_Block() != null) *
this.get_Block().addOffsetsToAssumption(paraAssum,paraAssum.getIdentifier(),true); * if(this.get_Block() != null)
* this.get_Block().addOffsetsToAssumption(paraAssum
methodAssum.addParaAssumption(paraAssum); * ,paraAssum.getIdentifier(),true);
*
// ¯Â¿Â½r die V_i: * methodAssum.addParaAssumption(paraAssum);
CLocalVarTypeAssumption varAssum = new CLocalVarTypeAssumption(classmember.getName(), this.get_Method_Name(), this.getParameterCount(), this.getOverloadedID(),"1", para.get_Name(),para.getType(), para.getLineNumber(),para.getOffset(),new Menge<Integer>()); *
localAssum.addElement(varAssum); * // ¯Â¿Â½r die V_i: CLocalVarTypeAssumption varAssum = new
//rememberLocals.addElement(varAssum); * CLocalVarTypeAssumption(classmember.getName(),
} * this.get_Method_Name(), this.getParameterCount(),
} * this.getOverloadedID(),"1", para.get_Name(),para.getType(),
//...und hinzuf�gen: * para.getLineNumber(),para.getOffset(),new Menge<Integer>());
* localAssum.addElement(varAssum);
assumptions.add(localAssum);//Assumptions ¼r lokale Variablen den Assumptions hinzufügen * //rememberLocals.addElement(varAssum); } } //...und
* hinzuf�gen:
//Hier wird der Typ der als Assumption eingetragen wird in die Variable assumedType dieser Klasse geschrieben: *
if(this.assumedType == null) // Falls der Typ nicht schon gesetzt ist. Das ist der Fall, falls die Methode ein Konstruktor ist * assumptions.add(localAssum);//Assumptions ¼r lokale Variablen den
this.assumedType = methodAssum.getAssumedType(); * Assumptions hinzufügen
*
return assumptions; * //Hier wird der Typ der als Assumption eingetragen wird in die
* Variable assumedType dieser Klasse geschrieben: if(this.assumedType
* == null) // Falls der Typ nicht schon gesetzt ist. Das ist der Fall,
* falls die Methode ein Konstruktor ist this.assumedType =
* methodAssum.getAssumedType();
*
* return assumptions;
*/ */
} }
@Override @Override
public void parserPostProcessing(SyntaxTreeNode parent) { public void parserPostProcessing(SyntaxTreeNode parent) {
if(this.getType()==null)this.setType(TypePlaceholder.fresh(this)); if (this.getType() == null)
//Bei dem Elterntyp der Methode darf es sich nur um eine Klasse handeln, daher Cast ohne Prüfung: this.setType(TypePlaceholder.fresh(this));
// Bei dem Elterntyp der Methode darf es sich nur um eine Klasse
// handeln, daher Cast ohne Prüfung:
// Class parentClass = (Class)parent; // Class parentClass = (Class)parent;
if(this.returntype == null)this.returntype = TypePlaceholder.fresh(this); if (this.returntype == null)
this.returntype = TypePlaceholder.fresh(this);
super.parserPostProcessing(parent); super.parserPostProcessing(parent);
/* /*
this.returntype.parserPostProcessing(this); * this.returntype.parserPostProcessing(this); if(this.parameterlist !=
if(this.parameterlist != null){ * null){ for(FormalParameter fp : this.parameterlist){
for(FormalParameter fp : this.parameterlist){ * fp.parserPostProcessing(this); } } for(GenericTypeVar gtv :
fp.parserPostProcessing(this); * this.getGenericParameter()){ gtv.parserPostProcessing(this); }
}
}
for(GenericTypeVar gtv : this.getGenericParameter()){
gtv.parserPostProcessing(this);
}
*/ */
} }
@ -676,7 +693,8 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
// Methode und Block teilen sich einen ReturnType: // Methode und Block teilen sich einen ReturnType:
// this.block.setType(t); // this.block.setType(t);
this.returntype = t; this.returntype = t;
this.returntype.parent = this; //TODO: Dieser Hack sollte nicht tig sein. (Parser ändern) this.returntype.parent = this; // TODO: Dieser Hack sollte nicht
// tig sein. (Parser ändern)
} }
/** /**
@ -687,7 +705,11 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
// Methode und Block teilen sich einen ReturnType: // Methode und Block teilen sich einen ReturnType:
return this.returntype; return this.returntype;
} }
public static Method createEmptyMethod(Block withBlock, String withSignature, Class parent) {
Method ret = Method.createEmptyMethod(withSignature, parent);
ret.set_Block(withBlock);
return ret;
}
public static Method createEmptyMethod(String withSignature, Class parent) { public static Method createEmptyMethod(String withSignature, Class parent) {
Method ret = new Method(0); Method ret = new Method(0);
DeclId DImethod = new DeclId(); DeclId DImethod = new DeclId();
@ -702,15 +724,37 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
@Override @Override
public boolean equals(Object obj) { public boolean equals(Object obj) {
if(!(obj instanceof Method))return false; if (!(obj instanceof Method))
return false;
Method equals = (Method) obj; Method equals = (Method) obj;
if((this.returntype!=null && equals.returntype==null))return false; if ((this.returntype != null && equals.returntype == null))
if((this.returntype==null && equals.returntype!=null))return false; return false;
if(this.returntype!=null && equals.returntype!=null)if(!this.returntype.equals(equals.returntype))return false; if ((this.returntype == null && equals.returntype != null))
if(!this.parameterlist.equals(equals.parameterlist))return false; return false;
if (this.returntype != null && equals.returntype != null)
if (!this.returntype.equals(equals.returntype))
return false;
if (!this.parameterlist.equals(equals.parameterlist))
return false;
return super.equals(obj); return super.equals(obj);
} }
@Override
public void genByteCode(ClassGen cg) {
/*ConstantPoolGen _cp = cg.getConstantPool();
* InstructionFactory _factory = new InstructionFactory(cg, _cp);
* InstructionList il = new InstructionList();
* Class parentClass = this.getParentClass();
*/
//oben steht MethodGen method als Variable (Z. 71)
// <EFBFBD>ber Statements iterieren um Block abzurufen
for (Statement statements : block.get_Statement()) {
statements.genByteCode(cg);
}
}
} }
// ino.end // ino.end

View File

@ -1,7 +1,8 @@
package de.dhbwstuttgart.syntaxtree; package de.dhbwstuttgart.syntaxtree;
import de.dhbwstuttgart.typeinference.Menge; import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.core.IItemWithOffset; import de.dhbwstuttgart.core.IItemWithOffset;
import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar; import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar;
import de.dhbwstuttgart.syntaxtree.type.Type; import de.dhbwstuttgart.syntaxtree.type.Type;
@ -126,4 +127,6 @@ public abstract class SyntaxTreeNode implements IItemWithOffset{
return this.getParent().getGTVDeclarationContext(); return this.getParent().getGTVDeclarationContext();
} }
} }

View File

@ -5,10 +5,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
@ -166,5 +167,15 @@ public class Assign extends Expr
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -5,10 +5,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.HashMap; import java.util.HashMap;
import java.util.Hashtable; import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
@ -212,5 +213,13 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -5,8 +5,16 @@ package de.dhbwstuttgart.syntaxtree.statement;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import de.dhbwstuttgart.typeinference.Menge;
import org.apache.bcel.Constants;
import org.apache.bcel.generic.ClassGen;
import org.apache.bcel.generic.ConstantPoolGen;
import org.apache.bcel.generic.InstructionFactory;
import org.apache.bcel.generic.InstructionHandle;
import org.apache.bcel.generic.InstructionList;
import org.apache.bcel.generic.MethodGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.logger.Section; import de.dhbwstuttgart.logger.Section;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
@ -14,6 +22,7 @@ import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
import de.dhbwstuttgart.myexception.SCStatementException; import de.dhbwstuttgart.myexception.SCStatementException;
import de.dhbwstuttgart.syntaxtree.Class; import de.dhbwstuttgart.syntaxtree.Class;
import de.dhbwstuttgart.syntaxtree.Field;
import de.dhbwstuttgart.syntaxtree.SyntaxTreeNode; import de.dhbwstuttgart.syntaxtree.SyntaxTreeNode;
import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar; import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar;
import de.dhbwstuttgart.syntaxtree.type.Type; import de.dhbwstuttgart.syntaxtree.type.Type;
@ -36,6 +45,9 @@ public class Block extends Statement
// ino.end // ino.end
// ino.class.Block.25037.body // ino.class.Block.25037.body
{ {
private InstructionFactory _factory;
private ConstantPoolGen _cp;
private ClassGen _cg;
// ino.method.Block.25041.definition // ino.method.Block.25041.definition
public Block() public Block()
@ -80,6 +92,7 @@ public class Block extends Statement
// ino.method.set_Statement.25068.definition // ino.method.set_Statement.25068.definition
public void set_Statement(Statement s) public void set_Statement(Statement s)
// ino.end // ino.end
@ -222,6 +235,7 @@ public class Block extends Statement
ret.attach(stmt.printJavaCode(resultSet)); ret.attach(stmt.printJavaCode(resultSet));
ret.attach((stmt instanceof ExprStmt ? ";" : "") + "\n"); ret.attach((stmt instanceof ExprStmt ? ";" : "") + "\n");
} }
return ret.attach("}"); return ret.attach("}");
} }
@ -239,5 +253,24 @@ public class Block extends Statement
public String getDescription(){ public String getDescription(){
return "Block"; return "Block";
} }
@Override
public void genByteCode(ClassGen cg) {
//ConstantPoolGen _cp = cg.getConstantPool();
InstructionFactory _factory = new InstructionFactory(cg, _cp);
InstructionList il = new InstructionList();
//Frage: Wenn Block von Statements erbt, und Block selbst keinen BCEL Code besitzt, ist das hier dann nicht eine Sackgasse?
//Instructionhandle dynamisch
InstructionHandle ih_0 = il.append(_factory.createLoad(org.apache.bcel.generic.Type.OBJECT, 0));
il.append(_factory.createInvoke(this.getParentClass().superclassid.toString(), "<init>", org.apache.bcel.generic.Type.VOID, org.apache.bcel.generic.Type.NO_ARGS, Constants.INVOKESPECIAL));
InstructionHandle ih_4 = il.append(_factory.createReturn(org.apache.bcel.generic.Type.VOID));
il.dispose();
}
} }
// ino.end // ino.end

View File

@ -3,8 +3,10 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.BoolLiteral.8626.import // ino.module.BoolLiteral.8626.import
import java.util.Hashtable; import java.util.Hashtable;
import de.dhbwstuttgart.typeinference.Menge;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -27,6 +29,14 @@ public class BoolLiteral extends Literal
// ino.end // ino.end
// ino.class.BoolLiteral.25089.body // ino.class.BoolLiteral.25089.body
{ {
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
// ino.attribute.Bool.25093.declaration // ino.attribute.Bool.25093.declaration
private boolean Bool; private boolean Bool;
// ino.end // ino.end

View File

@ -4,8 +4,10 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.module.CastExpr.8627.import // ino.module.CastExpr.8627.import
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import de.dhbwstuttgart.typeinference.Menge;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -118,5 +120,13 @@ public class CastExpr extends UnaryExpr
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,6 +3,9 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.CharLiteral.8628.import // ino.module.CharLiteral.8628.import
import java.util.Hashtable; import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
@ -106,5 +109,12 @@ public class CharLiteral extends Literal
Menge<Type> paralist, Menge<Type> paralist,
Menge<GenericTypeVar> genericMethodParameters) { Menge<GenericTypeVar> genericMethodParameters) {
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,11 +3,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.IntLiteral.8635.import // ino.module.IntLiteral.8635.import
import java.util.Hashtable; import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.syntaxtree.Class; import de.dhbwstuttgart.syntaxtree.Class;
@ -127,5 +127,11 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
Menge<SyntaxTreeNode> ret = new Menge<SyntaxTreeNode>(); Menge<SyntaxTreeNode> ret = new Menge<SyntaxTreeNode>();
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,10 +3,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.EmptyStmt.8629.import // ino.module.EmptyStmt.8629.import
import java.util.Hashtable; import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.syntaxtree.Class; import de.dhbwstuttgart.syntaxtree.Class;
@ -85,5 +86,12 @@ public class EmptyStmt extends Statement
return new Menge<SyntaxTreeNode>(); return new Menge<SyntaxTreeNode>();
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,10 +3,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.IntLiteral.8635.import // ino.module.IntLiteral.8635.import
import java.util.Hashtable; import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.syntaxtree.Class; import de.dhbwstuttgart.syntaxtree.Class;
@ -125,5 +126,11 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
Menge<SyntaxTreeNode> ret = new Menge<SyntaxTreeNode>(); Menge<SyntaxTreeNode> ret = new Menge<SyntaxTreeNode>();
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,10 +3,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
@ -115,4 +116,10 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
//throw new NotImplementedException(); //throw new NotImplementedException();
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }

View File

@ -5,10 +5,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
@ -159,5 +160,13 @@ public class IfStmt extends Statement
if(this.then_block!=null)ret.add(this.then_block); if(this.then_block!=null)ret.add(this.then_block);
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -5,10 +5,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.syntaxtree.Class; import de.dhbwstuttgart.syntaxtree.Class;
@ -214,5 +215,11 @@ public class InstVar extends Expr
ret.add(this.expr); ret.add(this.expr);
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -4,10 +4,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.module.InstanceOf.8633.import // ino.module.InstanceOf.8633.import
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCStatementException; import de.dhbwstuttgart.myexception.SCStatementException;
@ -114,6 +115,12 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,8 +3,10 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.IntLiteral.8635.import // ino.module.IntLiteral.8635.import
import java.util.Hashtable; import java.util.Hashtable;
import de.dhbwstuttgart.typeinference.Menge;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -127,5 +129,11 @@ public class IntLiteral extends Literal
Menge<SyntaxTreeNode> ret = new Menge<SyntaxTreeNode>(); Menge<SyntaxTreeNode> ret = new Menge<SyntaxTreeNode>();
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -1,8 +1,10 @@
package de.dhbwstuttgart.syntaxtree.statement; package de.dhbwstuttgart.syntaxtree.statement;
import java.util.Hashtable; import java.util.Hashtable;
import de.dhbwstuttgart.typeinference.Menge;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCStatementException; import de.dhbwstuttgart.myexception.SCStatementException;
@ -205,4 +207,10 @@ public class LambdaExpression extends Expr{
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }

View File

@ -4,8 +4,10 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.module.LocalOrFieldVar.8637.import // ino.module.LocalOrFieldVar.8637.import
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import de.dhbwstuttgart.typeinference.Menge;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -133,5 +135,11 @@ public class LocalOrFieldVar extends Expr
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -4,10 +4,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.module.LocalVarDecl.8638.import // ino.module.LocalVarDecl.8638.import
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.core.MyCompiler; import de.dhbwstuttgart.core.MyCompiler;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
@ -422,5 +423,11 @@ public class LocalVarDecl extends Statement implements TypeInsertable
ResultSet resultSet) { ResultSet resultSet) {
return new TypeInsertPoint(this, this, resultSet.getTypeEqualTo(tph),resultSet); return new TypeInsertPoint(this, this, resultSet.getTypeEqualTo(tph),resultSet);
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,11 +3,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.IntLiteral.8635.import // ino.module.IntLiteral.8635.import
import java.util.Hashtable; import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.syntaxtree.Class; import de.dhbwstuttgart.syntaxtree.Class;
@ -123,5 +123,11 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
Menge<SyntaxTreeNode> ret = new Menge<SyntaxTreeNode>(); Menge<SyntaxTreeNode> ret = new Menge<SyntaxTreeNode>();
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,8 +3,10 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.MethodCall.8639.import // ino.module.MethodCall.8639.import
import java.util.Hashtable; import java.util.Hashtable;
import de.dhbwstuttgart.typeinference.Menge;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.syntaxtree.Method; import de.dhbwstuttgart.syntaxtree.Method;
@ -48,7 +50,6 @@ public class MethodCall extends Expr
} }
// ino.end // ino.end
// ino.attribute.receiver.25639.declaration // ino.attribute.receiver.25639.declaration
/** /**
* Diese Variable speichert die Expression, welche die Klasse von welcher die Methode aufgerufen wird darstellt. * Diese Variable speichert die Expression, welche die Klasse von welcher die Methode aufgerufen wird darstellt.
@ -303,5 +304,11 @@ public class MethodCall extends Expr
super.parserPostProcessing(parent); super.parserPostProcessing(parent);
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -4,10 +4,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.module.NegativeExpr.8640.import // ino.module.NegativeExpr.8640.import
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
@ -107,5 +108,11 @@ public class NegativeExpr extends UnaryExpr
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,9 +3,10 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.NewArray.8641.import // ino.module.NewArray.8641.import
import java.util.Hashtable; import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -142,5 +143,11 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -5,9 +5,10 @@ package de.dhbwstuttgart.syntaxtree.statement;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -202,6 +203,12 @@ public class NewClass extends Expr
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -4,10 +4,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.module.NotExpr.8643.import // ino.module.NotExpr.8643.import
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCStatementException; import de.dhbwstuttgart.myexception.SCStatementException;
@ -131,5 +132,11 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,9 +3,10 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.Null.8644.import // ino.module.Null.8644.import
import java.util.Hashtable; import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -89,5 +90,11 @@ public class Null extends Literal
return new Menge<SyntaxTreeNode>(); return new Menge<SyntaxTreeNode>();
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,9 +3,10 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.PositivExpr.8645.import // ino.module.PositivExpr.8645.import
import java.util.Hashtable; import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -115,5 +116,11 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -4,10 +4,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.module.PostDecExpr.8646.import // ino.module.PostDecExpr.8646.import
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
@ -88,5 +89,11 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -4,10 +4,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.module.PostIncExpr.8647.import // ino.module.PostIncExpr.8647.import
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
@ -94,5 +95,11 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -4,10 +4,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.module.PreDecExpr.8648.import // ino.module.PreDecExpr.8648.import
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
@ -86,6 +87,11 @@ public class PreDecExpr extends UnaryExpr
ret.add(this.expr); ret.add(this.expr);
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -4,10 +4,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.module.PreIncExpr.8649.import // ino.module.PreIncExpr.8649.import
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
@ -89,5 +90,11 @@ public JavaCodeResult printJavaCode(ResultSet resultSet) {
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,8 +3,10 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.Return.8651.import // ino.module.Return.8651.import
import java.util.Hashtable; import java.util.Hashtable;
import de.dhbwstuttgart.typeinference.Menge;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -126,5 +128,11 @@ public class Return extends Statement
public Type getReturnType(){ public Type getReturnType(){
return this.getType(); return this.getType();
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -4,8 +4,13 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.module.Statement.8652.import // ino.module.Statement.8652.import
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import de.dhbwstuttgart.typeinference.Menge;
import org.apache.bcel.generic.ClassGen;
import org.apache.bcel.generic.ConstantPoolGen;
import org.apache.bcel.generic.InstructionFactory;
import org.apache.bcel.generic.InstructionList;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.core.IItemWithOffset; import de.dhbwstuttgart.core.IItemWithOffset;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -122,5 +127,12 @@ public abstract class Statement extends SyntaxTreeNode implements IItemWithOffse
public Type getReturnType(){ public Type getReturnType(){
return new de.dhbwstuttgart.syntaxtree.type.Void(this,-1); return new de.dhbwstuttgart.syntaxtree.type.Void(this,-1);
} }
public abstract void genByteCode(ClassGen _cg);
} }
// ino.end // ino.end

View File

@ -1,9 +1,13 @@
package de.dhbwstuttgart.syntaxtree.statement; package de.dhbwstuttgart.syntaxtree.statement;
import de.dhbwstuttgart.typeinference.Menge;
// ino.end
// ino.module.StringLiteral.8653.import
import java.util.Hashtable;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.syntaxtree.SyntaxTreeNode; import de.dhbwstuttgart.syntaxtree.SyntaxTreeNode;
import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar; import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar;
@ -98,5 +102,11 @@ public class StringLiteral extends Literal
return "\""+this.string+"\""; return "\""+this.string+"\"";
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -3,8 +3,10 @@ package de.dhbwstuttgart.syntaxtree.statement;
// ino.end // ino.end
// ino.module.This.8654.import // ino.module.This.8654.import
import java.util.Hashtable; import java.util.Hashtable;
import de.dhbwstuttgart.typeinference.Menge;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
@ -140,4 +142,10 @@ public class This extends Expr
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }

View File

@ -5,10 +5,11 @@ package de.dhbwstuttgart.syntaxtree.statement;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.CTypeReconstructionException;
import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.myexception.JVMCodeException;
import de.dhbwstuttgart.myexception.SCExcept; import de.dhbwstuttgart.myexception.SCExcept;
@ -132,5 +133,11 @@ public class WhileStmt extends Statement
ret.add(this.loop_block); ret.add(this.loop_block);
return ret; return ret;
} }
@Override
public void genByteCode(ClassGen _cg) {
// TODO Auto-generated method stub
}
} }
// ino.end // ino.end

View File

@ -1,38 +1,24 @@
package de.dhbwstuttgart.typeinference; package de.dhbwstuttgart.typeinference;
import de.dhbwstuttgart.typeinference.Menge; import org.apache.bcel.generic.ClassGen;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder; import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder;
public class ByteCodeResult{ public class ByteCodeResult{
private String byteCode = ""; private ClassGen byteCode;
//TODO: unresolvedTPHs entfernen. BROKEN! //TODO: unresolvedTPHs entfernen. BROKEN!
private Menge<TypePlaceholder> unresolvedTPHs = new Menge<TypePlaceholder>(); private Menge<TypePlaceholder> unresolvedTPHs = new Menge<TypePlaceholder>();
public ByteCodeResult(){ public ByteCodeResult(ClassGen byteCode){
this.byteCode = byteCode;
} }
public ByteCodeResult(String byteCode){ public ClassGen getByteCode(){
this.byteCode += byteCode;
}
public String getByteCode(){
return byteCode; return byteCode;
} }
public ByteCodeResult attach(ByteCodeResult byteCodeResult){
this.byteCode += byteCodeResult.getByteCode();
//Alle TPH anfügen:
for(TypePlaceholder tph : byteCodeResult.getUnresolvedTPH())this.addUnresolvedTPH(tph);
return this;
}
public ByteCodeResult attach(String javaCode){
this.byteCode += javaCode;
return this;
}
public void addUnresolvedTPH(TypePlaceholder typePlaceholder) { public void addUnresolvedTPH(TypePlaceholder typePlaceholder) {
unresolvedTPHs.add(typePlaceholder); unresolvedTPHs.add(typePlaceholder);
@ -49,7 +35,7 @@ public class ByteCodeResult{
@Override @Override
public String toString(){ public String toString(){
return getByteCode(); return getByteCode().toString();
} }
@Override @Override

View File

@ -0,0 +1,7 @@
class EmptyClass{
public EmptyClass(){}
public void leckMichAmArsch(){}
}

View File

@ -0,0 +1,45 @@
package bytecode;
import static org.junit.Assert.*;
import java.io.File;
import java.io.IOException;
import junit.framework.TestCase;
import org.junit.Test;
import plugindevelopment.TypeInsertTester;
import de.dhbwstuttgart.core.MyCompiler;
import de.dhbwstuttgart.core.MyCompilerAPI;
import de.dhbwstuttgart.logger.LoggerConfiguration;
import de.dhbwstuttgart.logger.Section;
import de.dhbwstuttgart.parser.JavaParser.yyException;
import de.dhbwstuttgart.typeinference.ByteCodeResult;
import de.dhbwstuttgart.typeinference.Menge;
import de.dhbwstuttgart.typeinference.TypeinferenceResultSet;
import de.dhbwstuttgart.typeinference.typedeployment.TypeInsertSet;
public class EmptyClass {
public final static String rootDirectory = System.getProperty("user.dir")+"/test/bytecode/";
public final static String testFile = "EmptyClass.jav";
public final static String outputFile = "EmptyClassTest.class";
@Test
public void test() {
LoggerConfiguration logConfig = new LoggerConfiguration().setOutput(Section.PARSER, System.out);
MyCompilerAPI compiler = MyCompiler.getAPI(logConfig);
try {
compiler.parse(new File(rootDirectory + testFile));
compiler.typeReconstruction();
ByteCodeResult bytecode = compiler.generateBytecode();
System.out.println(bytecode);
bytecode.getByteCode().getJavaClass().dump(new File(rootDirectory + outputFile));
} catch (IOException | yyException e) {
e.printStackTrace();
TestCase.fail();
}
}
}