- UnitTest für MultiExtends Problem

- Verhindern von doppelten Methoden von Class -> ClassGen
This commit is contained in:
Enrico Schrödter 2016-03-28 10:33:04 +02:00
parent c80dc162d9
commit b4d7ab02eb
6 changed files with 66 additions and 15 deletions

View File

@ -1,8 +1,12 @@
package de.dhbwstuttgart.bytecode; package de.dhbwstuttgart.bytecode;
import java.util.Arrays;
import java.util.HashMap; import java.util.HashMap;
import java.util.Iterator; import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Vector;
import org.apache.commons.bcel6.classfile.BootstrapMethod; import org.apache.commons.bcel6.classfile.BootstrapMethod;
import org.apache.commons.bcel6.classfile.BootstrapMethods; import org.apache.commons.bcel6.classfile.BootstrapMethods;
@ -10,6 +14,7 @@ import org.apache.commons.bcel6.classfile.ConstantPool;
import org.apache.commons.bcel6.classfile.InnerClass; import org.apache.commons.bcel6.classfile.InnerClass;
import org.apache.commons.bcel6.classfile.InnerClasses; import org.apache.commons.bcel6.classfile.InnerClasses;
import org.apache.commons.bcel6.classfile.JavaClass; import org.apache.commons.bcel6.classfile.JavaClass;
import org.apache.commons.bcel6.classfile.Method;
import org.apache.commons.bcel6.classfile.Signature; import org.apache.commons.bcel6.classfile.Signature;
import org.apache.commons.bcel6.generic.ClassGen; import org.apache.commons.bcel6.generic.ClassGen;
import org.apache.commons.bcel6.generic.ConstantPoolGen; import org.apache.commons.bcel6.generic.ConstantPoolGen;
@ -34,6 +39,7 @@ public class ClassGenerator extends ClassGen{
private Menge<TypePlaceholder> usedTPHs = new Menge<>(); private Menge<TypePlaceholder> usedTPHs = new Menge<>();
private Map<String, ClassGenerator> extraClasses = new HashMap<>(); private Map<String, ClassGenerator> extraClasses = new HashMap<>();
private List<String> methodsNamesAndTypes = new LinkedList<>();
public ClassGenerator(String name, Type superClass, String string, short accessflags, String[] strings, TypeinferenceResults typeinferenceResults) { public ClassGenerator(String name, Type superClass, String string, short accessflags, String[] strings, TypeinferenceResults typeinferenceResults) {
super(name,superClass.get_Name(),string,accessflags,strings, new DHBWConstantPoolGen()); super(name,superClass.get_Name(),string,accessflags,strings, new DHBWConstantPoolGen());
@ -163,6 +169,20 @@ public class ClassGenerator extends ClassGen{
return tiResult; return tiResult;
} }
@Override
public void addMethod(Method m) {
String methodNameAndTypes = m.getName()+Arrays.toString(m.getArgumentTypes());
if(methodsNamesAndTypes.contains(methodNameAndTypes)){
return;
}
methodsNamesAndTypes.add(methodNameAndTypes);
super.addMethod(m);
}
} }

View File

@ -74,7 +74,6 @@ public class Class extends GTVDeclarationContext implements AClassOrInterface, I
protected UsedId pkgName; protected UsedId pkgName;
protected Modifiers modifiers; protected Modifiers modifiers;
protected String name; protected String name;
private List<String> methodSignaturesAndNames = new LinkedList<>();
/** /**
* *
@ -1043,14 +1042,6 @@ public class Class extends GTVDeclarationContext implements AClassOrInterface, I
return false; return false;
} }
protected boolean methodExists(String nameAndSignature) {
return methodSignaturesAndNames.contains(nameAndSignature);
}
protected void addMethod(String nameAndSignature) {
methodSignaturesAndNames.add(nameAndSignature);
}
/* /*
private Collection<? extends ByteCodeResult> getGenericClasses() { private Collection<? extends ByteCodeResult> getGenericClasses() {
Collection<ByteCodeResult> results = new Menge<>(); Collection<ByteCodeResult> results = new Menge<>();

View File

@ -634,10 +634,6 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
Logger.getLogger("nameAndSignature").error(nameAndSignature, Section.CODEGEN); Logger.getLogger("nameAndSignature").error(nameAndSignature, Section.CODEGEN);
if(classObj.methodExists(nameAndSignature)){
Logger.getLogger("methodExists").debug(this.toString(), Section.CODEGEN);
continue;
}
short constants = Constants.ACC_PUBLIC; //Per Definition ist jede Methode public short constants = Constants.ACC_PUBLIC; //Per Definition ist jede Methode public
if(this.modifiers != null && this.modifiers.includesModifier(new Static())) constants += Constants.ACC_STATIC; if(this.modifiers != null && this.modifiers.includesModifier(new Static())) constants += Constants.ACC_STATIC;
@ -649,7 +645,6 @@ public class Method extends Field implements IItemWithOffset, TypeInsertable
//Methode generieren und anfügen: //Methode generieren und anfügen:
cg.addMethod(method.createMethod(cg, getParameterList(), returnType, get_Block(), t)); cg.addMethod(method.createMethod(cg, getParameterList(), returnType, get_Block(), t));
classObj.addMethod(nameAndSignature);
Logger.getLogger("createMethod").debug(this.toString(), Section.CODEGEN); Logger.getLogger("createMethod").debug(this.toString(), Section.CODEGEN);
} }

View File

@ -24,7 +24,6 @@ public class AutoOverloadingMultiResultsTest extends SourceFileBytecodeTest{
} }
@Test @Test
@Ignore
public void testConstruct() throws Exception{ public void testConstruct() throws Exception{
ClassLoader classLoader = getClassLoader(); ClassLoader classLoader = getClassLoader();

View File

@ -0,0 +1,11 @@
import java.util.Vector;
class MultiExtends{
Integer method(Vector<Integer> a){
return method2(a);
}
Integer method2(Vector<Number> b){
return 1;
}
}

View File

@ -0,0 +1,35 @@
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.Test;
import org.junit.Ignore;
import bytecode.SourceFileBytecodeTest;
public class MultiExtendsTest extends SourceFileBytecodeTest{
@Override
protected void init() {
testName = "MultiExtends";
rootDirectory = System.getProperty("user.dir")+"/test/bytecode/types/";
}
@Test
public void testConstruct() throws Exception{
ClassLoader classLoader = getClassLoader();
Class cls = classLoader.loadClass(testName);
Object obj = cls.newInstance();
assertTrue(true);
}
}