From a27b4f9d3b8d4d0c7258fbaedba0dce5a37940c5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Enrico=20Schr=C3=B6dter?= Date: Wed, 25 Nov 2015 10:23:06 +0100 Subject: [PATCH] =?UTF-8?q?Mehrere=20L=C3=B6sungen=20in=20einer=20Classfil?= =?UTF-8?q?e?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../bytecode/MethodGenerator.java | 21 ++++++++++++--- .../dhbwstuttgart/syntaxtree/Constructor.java | 2 +- src/de/dhbwstuttgart/syntaxtree/Method.java | 26 ++++++++++++------- .../typeinference/TypeinferenceResults.java | 23 +++++++++++++--- 4 files changed, 56 insertions(+), 16 deletions(-) diff --git a/src/de/dhbwstuttgart/bytecode/MethodGenerator.java b/src/de/dhbwstuttgart/bytecode/MethodGenerator.java index f783c0ef..ddfcb27c 100644 --- a/src/de/dhbwstuttgart/bytecode/MethodGenerator.java +++ b/src/de/dhbwstuttgart/bytecode/MethodGenerator.java @@ -7,10 +7,13 @@ import org.apache.commons.bcel6.generic.InstructionList; import org.apache.commons.bcel6.generic.MethodGen; import org.apache.commons.bcel6.generic.Type; +import de.dhbwstuttgart.logger.Logger; +import de.dhbwstuttgart.logger.Section; import de.dhbwstuttgart.syntaxtree.FormalParameter; import de.dhbwstuttgart.syntaxtree.ParameterList; import de.dhbwstuttgart.syntaxtree.statement.Block; import de.dhbwstuttgart.syntaxtree.statement.Return; +import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder; public class MethodGenerator extends MethodGen{ @@ -19,7 +22,7 @@ public class MethodGenerator extends MethodGen{ super(access_flags, return_type, arg_types, arg_names, method_name, class_name, il, cp); } - public Method createMethod(ClassGenerator cg, ParameterList parameter, de.dhbwstuttgart.syntaxtree.type.Type retType, Block block){ + public Method createMethod(ClassGenerator cg, ParameterList parameter, de.dhbwstuttgart.syntaxtree.type.Type retType, Block block, Integer typeReconstructionSetIndex){ MethodGen method = this; DHBWInstructionFactory factory = cg.getInstructionFactory(); @@ -39,10 +42,22 @@ public class MethodGenerator extends MethodGen{ //Die korrekte Signatur für die Methode anhängen. Hier sind dann auch die Parameter von RefTypes enthalten: String paramTypesSig = "("; for(FormalParameter p : parameter){ - paramTypesSig += p.getType().getBytecodeSignature(cg); + if(p.getType() instanceof TypePlaceholder){ + paramTypesSig += ((TypePlaceholder) p.getType()).getBytecodeSignature(cg, typeReconstructionSetIndex); + }else{ + paramTypesSig += p.getType().getBytecodeSignature(cg); + } + + Logger.getLogger("MethodGenerator").error(paramTypesSig, Section.CODEGEN); } paramTypesSig += ")"; - String retTypeSig = retType.getBytecodeSignature(cg); + String retTypeSig = ""; + if(retType instanceof TypePlaceholder){ + retTypeSig = ((TypePlaceholder) retType).getBytecodeSignature(cg, typeReconstructionSetIndex); + }else{ + retTypeSig = retType.getBytecodeSignature(cg); + } + method.addAttribute(factory.createSignatureAttribute(paramTypesSig+retTypeSig)); return method.getMethod(); diff --git a/src/de/dhbwstuttgart/syntaxtree/Constructor.java b/src/de/dhbwstuttgart/syntaxtree/Constructor.java index 251124cd..cce7a56e 100644 --- a/src/de/dhbwstuttgart/syntaxtree/Constructor.java +++ b/src/de/dhbwstuttgart/syntaxtree/Constructor.java @@ -78,7 +78,7 @@ public class Constructor extends Method { //method.setMaxStack(); //Die Stack Größe automatisch berechnen lassen (erst nach dem alle Instructions angehängt wurden) - cg.addMethod(method.createMethod(cg, getParameterList(), this.getType(), get_Block())); + cg.addMethod(method.createMethod(cg, getParameterList(), this.getType(), get_Block(), 0)); } /** diff --git a/src/de/dhbwstuttgart/syntaxtree/Method.java b/src/de/dhbwstuttgart/syntaxtree/Method.java index 0130daef..e803dcf5 100755 --- a/src/de/dhbwstuttgart/syntaxtree/Method.java +++ b/src/de/dhbwstuttgart/syntaxtree/Method.java @@ -746,7 +746,7 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable } public void genByteCode(ClassGenerator cg) { - List typeReconstructionSetIndexList = cg.getTypeinferenceResults().getTypeReconstructionSetIndexList(this); + List typeReconstructionSetIndexList = cg.getTypeinferenceResults().getTypeReconstructionSetIndexList(this, cg); for(Integer t: typeReconstructionSetIndexList){ DHBWConstantPoolGen _cp = cg.getConstantPool(); @@ -769,15 +769,23 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable argumentNames[i] = parameter.getIdentifier(); i++; } + + short constants = Constants.ACC_PUBLIC; //Per Definition ist jede Methode public + if(this.modifiers != null && this.modifiers.includesModifier(new Static())) constants += Constants.ACC_STATIC; + + Type returnType; + if(this.getType() instanceof TypePlaceholder){ + returnType = cg.resolveTPH((TypePlaceholder) this.getType(), t); + }else{ + returnType = this.getType(); + } + + //Methode generieren: + MethodGenerator method = new MethodGenerator(constants, returnType.getBytecodeType(cg), argumentTypes , argumentNames, this.get_Method_Name(), parentClass.name, il, _cp); + + //Methode generieren und anfügen: + cg.addMethod(method.createMethod(cg, getParameterList(), returnType, get_Block(), t)); } - - short constants = Constants.ACC_PUBLIC; //Per Definition ist jede Methode public - if(this.modifiers != null && this.modifiers.includesModifier(new Static())) constants += Constants.ACC_STATIC; - //Methode generieren: - MethodGenerator method = new MethodGenerator(constants, this.getType().getBytecodeType(cg), argumentTypes , argumentNames, this.get_Method_Name(), parentClass.name, il, _cp); - - //Methode generieren und anfügen: - cg.addMethod(method.createMethod(cg, getParameterList(), getType(), get_Block())); } } diff --git a/src/de/dhbwstuttgart/typeinference/TypeinferenceResults.java b/src/de/dhbwstuttgart/typeinference/TypeinferenceResults.java index 79915d9b..3424ad37 100644 --- a/src/de/dhbwstuttgart/typeinference/TypeinferenceResults.java +++ b/src/de/dhbwstuttgart/typeinference/TypeinferenceResults.java @@ -3,8 +3,13 @@ package de.dhbwstuttgart.typeinference; import java.util.LinkedList; import java.util.List; +import de.dhbwstuttgart.bytecode.ClassGenerator; +import de.dhbwstuttgart.logger.Logger; +import de.dhbwstuttgart.logger.Section; import de.dhbwstuttgart.syntaxtree.FormalParameter; import de.dhbwstuttgart.syntaxtree.Method; +import de.dhbwstuttgart.syntaxtree.type.ExtendsWildcardType; +import de.dhbwstuttgart.syntaxtree.type.SuperWildcardType; import de.dhbwstuttgart.syntaxtree.type.Type; import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder; import de.dhbwstuttgart.typeinference.Menge.Equal; @@ -33,7 +38,7 @@ public class TypeinferenceResults { return typeReconstructions; } - public List getTypeReconstructionSetIndexList(Method method) { + public List getTypeReconstructionSetIndexList(Method method, ClassGenerator cg) { Menge parameters = method.parameterlist.formalparameter; Menge typePlaceholders = new Menge<>(); List result = new LinkedList<>(); @@ -52,7 +57,7 @@ public class TypeinferenceResults { reconstructionTypes[t] = getTypeOfPlaceholder(typePlaceholders.get(t), i); } - if(!types.contains(reconstructionTypes, new TypeArrayEqual())){ + if(!types.contains(reconstructionTypes, new TypeArrayEqual(cg))){ types.add(reconstructionTypes); result.add(i); } @@ -63,6 +68,16 @@ public class TypeinferenceResults { } class TypeArrayEqual implements Equal{ + private ClassGenerator cg; + + + + public TypeArrayEqual(ClassGenerator cg) { + super(); + this.cg = cg; + } + + @Override public boolean equal(Type[] a, Type[] b) { @@ -71,7 +86,9 @@ class TypeArrayEqual implements Equal{ } for(int i = 0; i < a.length; i++){ - if(!a[i].equals(b[i])){ + if(!a[i].getBytecodeType(cg).equals(b[i].getBytecodeType(cg))){ + Logger.getLogger("TypeArrayEqual").error(a[i].toString(), Section.CODEGEN); + Logger.getLogger("TypeArrayEqual").error(b[i].toString(), Section.CODEGEN); return false; } }