diff --git a/src/de/dhbwstuttgart/bytecode/ClassGenerator.java b/src/de/dhbwstuttgart/bytecode/ClassGenerator.java index 59e65397..dee9be8e 100644 --- a/src/de/dhbwstuttgart/bytecode/ClassGenerator.java +++ b/src/de/dhbwstuttgart/bytecode/ClassGenerator.java @@ -69,6 +69,10 @@ public class ClassGenerator extends ClassGen{ return this.getNearestUsedType(toTPH, null); } + public Type resolveTPH(TypePlaceholder typePlaceholder) { + return resolveTPH(typePlaceholder, 0, null); + } + public Type resolveTPH(TypePlaceholder typePlaceholder, Integer typeinferenceResultSetIndex) { return resolveTPH(typePlaceholder, typeinferenceResultSetIndex, null); } diff --git a/src/de/dhbwstuttgart/syntaxtree/Class.java b/src/de/dhbwstuttgart/syntaxtree/Class.java index 8fe32c6b..d3a5ab10 100755 --- a/src/de/dhbwstuttgart/syntaxtree/Class.java +++ b/src/de/dhbwstuttgart/syntaxtree/Class.java @@ -240,7 +240,7 @@ public class Class extends GTVDeclarationContext implements AClassOrInterface, I * @param modifiers * @param supertypeGenPara - Eine Liste von Namen, welche die Generischen Parameter der Klasse darstellen. */ - public Class(String name, Type superClass, Modifiers modifiers, Menge supertypeGenPara) { + public Class(String name, Type superClass, Modifiers modifiers, Menge supertypeGenPara) { this(name,superClass,modifiers,0); if(supertypeGenPara == null)return; Menge gtvs = new Menge<>(); diff --git a/src/de/dhbwstuttgart/syntaxtree/Method.java b/src/de/dhbwstuttgart/syntaxtree/Method.java index b55ea238..f4743a08 100755 --- a/src/de/dhbwstuttgart/syntaxtree/Method.java +++ b/src/de/dhbwstuttgart/syntaxtree/Method.java @@ -745,7 +745,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable } public void genByteCode(ClassGenerator cg) { - for(int t = 0; t < cg.getTypeinferenceResults().getTypeReconstructions().size(); t++){ + for(int t = 0; t < cg.getTypeinferenceResults().getTypeReconstructions().size(); t++){ DHBWConstantPoolGen _cp = cg.getConstantPool(); DHBWInstructionFactory _factory = new DHBWInstructionFactory(cg, _cp); InstructionList il = new InstructionList(); @@ -754,8 +754,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable //Die Argumentliste generieren: org.apache.commons.bcel6.generic.Type[] argumentTypes = org.apache.commons.bcel6.generic.Type.NO_ARGS; String[] argumentNames = new String[]{}; - if(this.parameterlist != null && - this.parameterlist.size() > 0){ + if(this.parameterlist != null && this.parameterlist.size() > 0){ argumentTypes = new org.apache.commons.bcel6.generic.Type[this.parameterlist.size()]; argumentNames = new String[this.parameterlist.size()]; int i = 0; diff --git a/src/de/dhbwstuttgart/syntaxtree/type/RefType.java b/src/de/dhbwstuttgart/syntaxtree/type/RefType.java index fae67654..f09e0ad6 100755 --- a/src/de/dhbwstuttgart/syntaxtree/type/RefType.java +++ b/src/de/dhbwstuttgart/syntaxtree/type/RefType.java @@ -834,11 +834,10 @@ public class RefType extends ObjectType implements IMatchable @Override public String getBytecodeSignature(ClassGenerator cg) { - //TODO: bytecode woher bekommt ich die parent klasse String combinedType = getCombinedType(cg); if(!combinedType.equals(getName().toString())){ getSuperWildcardTypes(); - Class generatedClass = ASTFactory.createClass(getCombinedType(cg), getGenericClassType(), null, get_ParaList(), new SourceFile()); + Class generatedClass = ASTFactory.createClass(getCombinedType(cg), getGenericClassType(), null, null, new SourceFile()); cg.addExtraClass(generatedClass.genByteCode(new TypeinferenceResults()).getByteCode()); } diff --git a/test/bytecode/ASTBytecodeTest.java b/test/bytecode/ASTBytecodeTest.java index cd6d268e..32fd8088 100644 --- a/test/bytecode/ASTBytecodeTest.java +++ b/test/bytecode/ASTBytecodeTest.java @@ -56,7 +56,10 @@ public abstract class ASTBytecodeTest { String rootDirectory = getRootDirectory(); + System.out.println(rootDirectory); + JavaClass javaClass = result.getByteCode().getJavaClass(); + System.out.println(javaClass.toString()); javaClass.dump(new File(rootDirectory+javaClass.getClassName()+".class")); for(ClassGenerator cg: result.getByteCode().getExtraClasses().values()){ diff --git a/test/bytecode/types/AutoOverloading.jav b/test/bytecode/types/AutoOverloading.jav index d4b74752..860f5483 100644 --- a/test/bytecode/types/AutoOverloading.jav +++ b/test/bytecode/types/AutoOverloading.jav @@ -2,16 +2,16 @@ import java.util.Vector; class AutoOverloading{ - methode(v, x){ - v.add(x); + methode2(String p){ + } - methode(v, x){ - v.add(x); - } + methode2(Integer p){ - methode(){ - methode(new Vector(),"hallo"); - methode(new Vector(), 1); + } + + + methode(p){ + methode2(p); } } \ No newline at end of file diff --git a/test/bytecode/types/ExtendsTypeTest.java b/test/bytecode/types/ExtendsTypeTest.java index 32f24c9c..eb753389 100644 --- a/test/bytecode/types/ExtendsTypeTest.java +++ b/test/bytecode/types/ExtendsTypeTest.java @@ -8,6 +8,7 @@ import java.net.URL; import java.net.URLClassLoader; import java.util.Vector; +import org.junit.Ignore; import org.junit.Test; import bytecode.SourceFileBytecodeTest; @@ -20,6 +21,7 @@ public class ExtendsTypeTest extends SourceFileBytecodeTest{ } @Test + @Ignore public void testConstruct() throws Exception{ ClassLoader classLoader = getClassLoader(); diff --git a/test/bytecode/types/LocalVariableStringVector.jav b/test/bytecode/types/LocalVariableStringVector.jav deleted file mode 100644 index 887c82d6..00000000 --- a/test/bytecode/types/LocalVariableStringVector.jav +++ /dev/null @@ -1,7 +0,0 @@ -import java.util.Vector; - -class LocalVariableStringVector{ - void method() { - Vector vector; - } -} \ No newline at end of file diff --git a/test/bytecode/types/LocalVariableStringVectorTest.java b/test/bytecode/types/LocalVariableStringVectorTest.java deleted file mode 100644 index 9c16a4b4..00000000 --- a/test/bytecode/types/LocalVariableStringVectorTest.java +++ /dev/null @@ -1,39 +0,0 @@ -package bytecode.types; - -import static org.junit.Assert.*; - -import java.io.File; -import java.lang.reflect.Method; -import java.net.URL; -import java.net.URLClassLoader; -import java.util.Vector; - -import org.junit.Test; - -import bytecode.SourceFileBytecodeTest; - -public class LocalVariableStringVectorTest extends SourceFileBytecodeTest{ - @Override - protected void init() { - testName = "LocalVariableStringVector"; - rootDirectory = System.getProperty("user.dir")+"/test/bytecode/types/"; - } - - - - @Test - public void testCompiler() { - try{ - ClassLoader classLoader = getClassLoader(); - - Class cls = classLoader.loadClass(testName); - - Object obj = cls.newInstance(); - - assertTrue(true); - }catch(Exception e){ - throw new RuntimeException(e); - } - } - -} diff --git a/test/bytecode/types/LocalVariableVector.jav b/test/bytecode/types/LocalVariableVector.jav deleted file mode 100644 index 13cd673c..00000000 --- a/test/bytecode/types/LocalVariableVector.jav +++ /dev/null @@ -1,7 +0,0 @@ -import java.util.Vector; - -class LocalVariableVector{ - void method() { - Vector vector; - } -} \ No newline at end of file diff --git a/test/bytecode/types/LocalVariableVectorTest.java b/test/bytecode/types/LocalVariableVectorTest.java deleted file mode 100644 index b6278a65..00000000 --- a/test/bytecode/types/LocalVariableVectorTest.java +++ /dev/null @@ -1,38 +0,0 @@ -package bytecode.types; - -import static org.junit.Assert.*; - -import java.io.File; -import java.lang.reflect.Method; -import java.net.URL; -import java.net.URLClassLoader; -import java.util.Vector; - -import org.junit.Test; - -import bytecode.SourceFileBytecodeTest; - -public class LocalVariableVectorTest extends SourceFileBytecodeTest{ - @Override - protected void init() { - testName = "LocalVariableVector"; - rootDirectory = System.getProperty("user.dir")+"/test/bytecode/types/"; - } - - - - @Test - public void testCompiler() { - try{ - ClassLoader classLoader = getClassLoader(); - - Class cls = classLoader.loadClass(testName); - - Object obj = cls.newInstance(); - - assertTrue(true); - }catch(Exception e){ - throw new RuntimeException(e); - } - } -} diff --git a/test/bytecode/types/NewStatement.jav b/test/bytecode/types/NewStatement.jav new file mode 100644 index 00000000..ccded70b --- /dev/null +++ b/test/bytecode/types/NewStatement.jav @@ -0,0 +1,11 @@ +import java.util.Vector; + +class NewStatement{ + + Vector vi; + + void methode(){ + vi = new Vector(); + } + +} diff --git a/test/bytecode/types/OverloadingAdditionTest.java b/test/bytecode/types/NewStatementTest.java similarity index 85% rename from test/bytecode/types/OverloadingAdditionTest.java rename to test/bytecode/types/NewStatementTest.java index bb5211f5..c63548b6 100644 --- a/test/bytecode/types/OverloadingAdditionTest.java +++ b/test/bytecode/types/NewStatementTest.java @@ -13,10 +13,10 @@ import org.junit.Test; import bytecode.SourceFileBytecodeTest; -public class OverloadingAdditionTest extends SourceFileBytecodeTest{ +public class NewStatementTest extends SourceFileBytecodeTest{ @Override protected void init() { - testName = "OverloadingAddition"; + testName = "NewStatement"; rootDirectory = System.getProperty("user.dir")+"/test/bytecode/types/"; } diff --git a/test/bytecode/types/OverloadingAddition.jav b/test/bytecode/types/OverloadingAddition.jav deleted file mode 100644 index 0b0607ac..00000000 --- a/test/bytecode/types/OverloadingAddition.jav +++ /dev/null @@ -1,5 +0,0 @@ -class OverloadingAddition{ - methode(a){ - return a+a; - } -} \ No newline at end of file diff --git a/test/bytecode/types/OverloadingAdditionTest2.java b/test/bytecode/types/OverloadingAdditionTest2.java deleted file mode 100644 index 2669b7fa..00000000 --- a/test/bytecode/types/OverloadingAdditionTest2.java +++ /dev/null @@ -1,211 +0,0 @@ -package bytecode.types; - -import static org.junit.Assert.*; - -import java.io.File; -import java.lang.reflect.Constructor; -import java.lang.reflect.Method; -import java.net.URL; -import java.net.URLClassLoader; -import java.util.Vector; - -import org.junit.BeforeClass; -import org.junit.Test; -import org.omg.CORBA.TypeCodeHolder; - -import bytecode.ASTBytecodeTest; -import bytecode.SourceFileBytecodeTest; -import de.dhbwstuttgart.bytecode.TypePlaceholderType; -import de.dhbwstuttgart.syntaxtree.FormalParameter; -import de.dhbwstuttgart.syntaxtree.ParameterList; -import de.dhbwstuttgart.syntaxtree.SourceFile; -import de.dhbwstuttgart.syntaxtree.factory.ASTFactory; -import de.dhbwstuttgart.syntaxtree.misc.DeclId; -import de.dhbwstuttgart.syntaxtree.statement.Block; -import de.dhbwstuttgart.syntaxtree.statement.Expr; -import de.dhbwstuttgart.syntaxtree.statement.IntLiteral; -import de.dhbwstuttgart.syntaxtree.statement.Return; -import de.dhbwstuttgart.syntaxtree.statement.Statement; -import de.dhbwstuttgart.syntaxtree.type.RefType; -import de.dhbwstuttgart.syntaxtree.type.Type; -import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder; -import de.dhbwstuttgart.typeinference.Menge; -import de.dhbwstuttgart.typeinference.Pair; -import de.dhbwstuttgart.typeinference.ResultSet; -import de.dhbwstuttgart.typeinference.TypeinferenceResultSet; -import de.dhbwstuttgart.typeinference.TypeinferenceResults; - -public class OverloadingAdditionTest2 extends ASTBytecodeTest{ - public SourceFile getSourceFile(){ - /* - class OverloadingAddition{ - methode(a){ - return a+a; - } - } - */ - SourceFile sourceFile = new SourceFile(); - de.dhbwstuttgart.syntaxtree.Class classToTest = ASTFactory.createClass(getTestName(), null, null, null, sourceFile); - - ParameterList parameterList = new ParameterList(); - - System.out.println("Type"); - - Type type = new RefType("java.lang.Integer", parameterList, 0); - //Type type = TypePlaceholder.getInstance("OverloadingAdditionTestTypePlaceholder_A"); - - System.out.println("type: "+type.toString()); - - DeclId declId = new DeclId("a"); - declId.set_Paratyp(new Menge()); - - FormalParameter formalParameter = new FormalParameter(declId); - formalParameter.setType(type); - - parameterList.set_AddParameter(formalParameter); - - IntLiteral additionExpression = new IntLiteral(); - additionExpression.set_Int(2); - - Return returnStatment = new Return(0, 0); - returnStatment.set_ReturnExpr(additionExpression); - returnStatment.setReturnType(type); - - Menge statements = new Menge<>(); - statements.add(returnStatment); - - Block block = new Block(); - block.set_Statement_Menge(statements); - block.setType(type); - - de.dhbwstuttgart.syntaxtree.Method method = ASTFactory.createMethod("method", parameterList, block, classToTest); - method.setType(type); - - classToTest.addField(method); - sourceFile.addElement(classToTest); - - return sourceFile; - } - - - - @Override - public String getRootDirectory() { - return super.getRootDirectory()+"types/"; - } - - - - @Override - public String getTestName() { - return "OverloadingAddition"; - } - - - - @Test - public void testConstruct() throws Exception{ - ClassLoader classLoader = getClassLoader(); - - Class cls = classLoader.loadClass(getTestName()); - - Object obj = cls.newInstance(); - assertTrue(true); - } - - @Test - public void testMethodWithInteger(){ - try{ - ClassLoader classLoader = getClassLoader(); - - Class cls = classLoader.loadClass(getTestName()); - - Object obj = cls.newInstance(); - - Integer param = new Integer(1); - - Class[] params = new Class[1]; - params[0] = param.getClass(); - - Method method = cls.getDeclaredMethod("method", params); - Object result = method.invoke(obj, param); - - assertEquals(2, (Integer) result); - }catch(Exception e){ - throw new RuntimeException(e); - } - } - - @Test - public void testMethodWithDouble(){ - try{ - ClassLoader classLoader = getClassLoader(); - - Class cls = classLoader.loadClass(getTestName()); - - Object obj = cls.newInstance(); - - Double param = new Double(1.5); - - Class[] params = new Class[1]; - params[0] = param.getClass(); - - Method method = cls.getDeclaredMethod("method", params); - Object result = method.invoke(obj, param); - - assertEquals(3.0, (Double) result); - }catch(Exception e){ - throw new RuntimeException(e); - } - } - - @Test - public void testMethodWithString(){ - try{ - ClassLoader classLoader = getClassLoader(); - - Class cls = classLoader.loadClass(getTestName()); - - Object obj = cls.newInstance(); - - String param = new String("abc"); - - Class[] params = new Class[1]; - params[0] = param.getClass(); - - Method method = cls.getDeclaredMethod("method", params); - Object result = method.invoke(obj, param); - - assertEquals("abcabc", (String) result); - }catch(Exception e){ - throw new RuntimeException(e); - } - } - - /* - public TypeinferenceResults getResults() { - String[] types = { - "java.lang.Integer", - "java.lang.Double", - "java.lang.String" - }; - - Menge results = new Menge<>(); - - for(String typeString: types){ - ParameterList parameterList = new ParameterList(); - - - Type type = new RefType(typeString, parameterList, 0); - - Menge pairs = new Menge<>(); - pairs.add(new Pair(TypePlaceholder.fresh("OverloadingAdditionTestTypePlaceholder_A", getSourceFile().KlassenVektor.get(0)), type)); - - - results.add(new TypeinferenceResultSet(getSourceFile().KlassenVektor.get(0), pairs, new ResultSet(pairs))); - } - - return new TypeinferenceResults(results); - } - */ -} diff --git a/test/bytecode/types/SuperType.java b/test/bytecode/types/SuperType.java index 26b5b790..5b2e2e12 100644 --- a/test/bytecode/types/SuperType.java +++ b/test/bytecode/types/SuperType.java @@ -11,8 +11,11 @@ import java.util.Vector; import org.junit.Test; +import org.junit.Ignore; + import bytecode.SourceFileBytecodeTest; + public class SuperType extends SourceFileBytecodeTest{ @Override protected void init() { @@ -21,6 +24,7 @@ public class SuperType extends SourceFileBytecodeTest{ } @Test + @Ignore public void testConstruct() throws Exception{ ClassLoader classLoader = getClassLoader();