forked from JavaTX/JavaCompilerCore
Beginnen der BytecodeTypeFactory
This commit is contained in:
parent
c4aff43f71
commit
accbe5bbfc
93
src/de/dhbwstuttgart/bytecode/BytecodeTypeFactory.java
Normal file
93
src/de/dhbwstuttgart/bytecode/BytecodeTypeFactory.java
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
package de.dhbwstuttgart.bytecode;
|
||||||
|
|
||||||
|
import de.dhbwstuttgart.syntaxtree.type.BoundedGenericTypeVar;
|
||||||
|
import de.dhbwstuttgart.syntaxtree.type.GenericTypeVar;
|
||||||
|
import de.dhbwstuttgart.syntaxtree.type.ObjectType;
|
||||||
|
import de.dhbwstuttgart.syntaxtree.type.RefType;
|
||||||
|
import de.dhbwstuttgart.syntaxtree.type.Type;
|
||||||
|
import de.dhbwstuttgart.typeinference.exceptions.NotImplementedException;
|
||||||
|
|
||||||
|
public class BytecodeTypeFactory {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-FieldType
|
||||||
|
*/
|
||||||
|
public static String generateFieldDescriptor(Type t){
|
||||||
|
String ret = "";
|
||||||
|
if(t instanceof RefType){
|
||||||
|
ret += "L" + t.getName().toString().replace('.', '/') + ";";
|
||||||
|
}else{
|
||||||
|
throw new NotImplementedException();
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-ClassSignature
|
||||||
|
*/
|
||||||
|
public static String generateClassSignature(de.dhbwstuttgart.syntaxtree.Class c){
|
||||||
|
String ret = "";
|
||||||
|
if(c.getGenericParameter() != null && c.getGenericParameter().size() > 0){
|
||||||
|
ret += "<";
|
||||||
|
for(GenericTypeVar gtv : c.getGenericParameter()){
|
||||||
|
ret += generateTypeParameter(gtv);
|
||||||
|
}
|
||||||
|
ret += ">";
|
||||||
|
}
|
||||||
|
//Add the SuperClassSignature:
|
||||||
|
c.getSuperClass();
|
||||||
|
ret += generateClassTypeSignature();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String generateSuperClassSignature(Type superClass){
|
||||||
|
String ret = "";
|
||||||
|
//TODO:
|
||||||
|
throw new NotImplementedException();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String generateTypeParameter(GenericTypeVar gtv){
|
||||||
|
String ret = gtv.get_Name() + ":";
|
||||||
|
for(ObjectType t : gtv.getBounds()){
|
||||||
|
ret += generateReferenceTypeSignature(t);
|
||||||
|
ret += ":";
|
||||||
|
}
|
||||||
|
ret = ret.substring(0, ret.length()-1);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-ClassTypeSignature
|
||||||
|
*/
|
||||||
|
private static String generateClassTypeSignature(){
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-ReferenceTypeSignature
|
||||||
|
*/
|
||||||
|
private static String generateReferenceTypeSignature(Type t){
|
||||||
|
if(t instanceof RefType)return generateReferenceTypeSignature((RefType)t);
|
||||||
|
if(t instanceof GenericTypeVar)return generateReferenceTypeSignature((GenericTypeVar)t);
|
||||||
|
throw new NotImplementedException();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String generateReferenceTypeSignature(RefType t){
|
||||||
|
String ret = "L" + t.get_Name();
|
||||||
|
if(t.getParaList() != null && t.getParaList().size() > 0){
|
||||||
|
ret += "<";
|
||||||
|
for(Type p : t.getParaList()){
|
||||||
|
ret += generateReferenceTypeSignature(p);
|
||||||
|
}
|
||||||
|
ret+=">";
|
||||||
|
}
|
||||||
|
return ret + ";";
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String generateReferenceTypeSignature(GenericTypeVar t){
|
||||||
|
String ret = "T" + t.get_Name();
|
||||||
|
return ret + ";";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -158,7 +158,8 @@ public class ClassGenerator extends ClassGen{
|
|||||||
|
|
||||||
//Signatur setzen:
|
//Signatur setzen:
|
||||||
String typeParameters = this.generateParameterSignature();
|
String typeParameters = this.generateParameterSignature();
|
||||||
String superClassSignature = this.superClass.get_Name();
|
String superClassSignature = BytecodeTypeFactory.generateSuperClassSignature(this.superClass);//"L" + this.superClass.getBytecodeType(cg, rs)
|
||||||
|
superClassSignature = superClassSignature.substring(0, superClassSignature.length()-1); //Das ";" am Ende entfernen
|
||||||
if(this.superClass instanceof RefType &&
|
if(this.superClass instanceof RefType &&
|
||||||
((RefType)superClass).get_ParaList() != null &&
|
((RefType)superClass).get_ParaList() != null &&
|
||||||
((RefType)superClass).get_ParaList().size() > 0){
|
((RefType)superClass).get_ParaList().size() > 0){
|
||||||
@ -167,7 +168,7 @@ public class ClassGenerator extends ClassGen{
|
|||||||
for(Type param : superRefType.get_ParaList()){
|
for(Type param : superRefType.get_ParaList()){
|
||||||
superClassSignature += param.getBytecodeSignature(this, null);
|
superClassSignature += param.getBytecodeSignature(this, null);
|
||||||
}
|
}
|
||||||
superClassSignature += ">";
|
superClassSignature += ">;";
|
||||||
}
|
}
|
||||||
String classSignature = typeParameters + superClassSignature; //TOOD: Hier noch die Signaturen der SuperInterfaces anfügen
|
String classSignature = typeParameters + superClassSignature; //TOOD: Hier noch die Signaturen der SuperInterfaces anfügen
|
||||||
if(classSignature.length()>0){
|
if(classSignature.length()>0){
|
||||||
|
@ -83,7 +83,10 @@ public class ASTFactory {
|
|||||||
|
|
||||||
public static Class createObjectClass() {
|
public static Class createObjectClass() {
|
||||||
Class generatedClass = new Class("java.lang.Object", 0);
|
Class generatedClass = new Class("java.lang.Object", 0);
|
||||||
|
|
||||||
return generatedClass;
|
return generatedClass;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static RefType createObjectType(){
|
||||||
|
return createObjectClass().getType();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,9 +2,12 @@
|
|||||||
package de.dhbwstuttgart.syntaxtree.type;
|
package de.dhbwstuttgart.syntaxtree.type;
|
||||||
// ino.end
|
// ino.end
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
// ino.module.GenericTypeVar.8671.import
|
// ino.module.GenericTypeVar.8671.import
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import de.dhbwstuttgart.typeinference.Menge;
|
import de.dhbwstuttgart.typeinference.Menge;
|
||||||
|
|
||||||
import de.dhbwstuttgart.typeinference.ConstraintsSet;
|
import de.dhbwstuttgart.typeinference.ConstraintsSet;
|
||||||
@ -22,17 +25,14 @@ import de.dhbwstuttgart.parser.JavaClassName;
|
|||||||
import de.dhbwstuttgart.syntaxtree.Class;
|
import de.dhbwstuttgart.syntaxtree.Class;
|
||||||
import de.dhbwstuttgart.syntaxtree.GTVDeclarationContext;
|
import de.dhbwstuttgart.syntaxtree.GTVDeclarationContext;
|
||||||
import de.dhbwstuttgart.syntaxtree.SyntaxTreeNode;
|
import de.dhbwstuttgart.syntaxtree.SyntaxTreeNode;
|
||||||
// ino.class.GenericTypeVar.26505.description type=javadoc
|
import de.dhbwstuttgart.syntaxtree.factory.ASTFactory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Diese Klasse überarbeiten. Pair genericTypeVar ist nicht implementiert.
|
* TODO: Diese Klasse überarbeiten. Pair genericTypeVar ist nicht implementiert.
|
||||||
* @author J�rg B�uerle
|
* @author J�rg B�uerle
|
||||||
* @version $Date: 2013/09/22 20:12:53 $
|
* @version $Date: 2013/09/22 20:12:53 $
|
||||||
*/
|
*/
|
||||||
// ino.end
|
|
||||||
// ino.class.GenericTypeVar.26505.declaration
|
|
||||||
public class GenericTypeVar extends ObjectType
|
public class GenericTypeVar extends ObjectType
|
||||||
// ino.end
|
|
||||||
// ino.class.GenericTypeVar.26505.body
|
|
||||||
{
|
{
|
||||||
//Type genericTypeVar;
|
//Type genericTypeVar;
|
||||||
//Menge<Type> extendVars = new Menge<Type>();
|
//Menge<Type> extendVars = new Menge<Type>();
|
||||||
@ -236,7 +236,14 @@ public class GenericTypeVar extends ObjectType
|
|||||||
// TODO Bytecode
|
// TODO Bytecode
|
||||||
return org.apache.bcel.generic.Type.getType(getSignatureType(null));// new org.apache.bcel.generic.ObjectType("Object");
|
return org.apache.bcel.generic.Type.getType(getSignatureType(null));// new org.apache.bcel.generic.ObjectType("Object");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<ObjectType> getBounds()
|
||||||
|
{
|
||||||
|
//Gibt eine Liste mit "java.lang.Object" zurück, da jede Generic von Object erbt
|
||||||
|
ArrayList<ObjectType> ret = new ArrayList<>();
|
||||||
|
ret.add(ASTFactory.createObjectType());
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
// ino.end
|
// ino.end
|
||||||
|
@ -130,12 +130,13 @@ public class RefType extends ObjectType implements IMatchable
|
|||||||
//this.parameter = null;
|
//this.parameter = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public RefType(JavaClassName jName, SyntaxTreeNode parent, int offset) {
|
|
||||||
this(jName.toString(), parent, offset);
|
public RefType(JavaClassName name, List<Type> parameter, int offset) {
|
||||||
|
super(name.toString(), null, offset);
|
||||||
|
this.parameter = parameter;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
/**
|
|
||||||
* Wandelt die Parameter des RefTypes in TPHs um, sofern es sich um Generische Variablen handelt.
|
* Wandelt die Parameter des RefTypes in TPHs um, sofern es sich um Generische Variablen handelt.
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@ -590,20 +591,26 @@ public class RefType extends ObjectType implements IMatchable
|
|||||||
//Bsp.: Ljava/util/Vector<Ljava/lang/String;>;
|
//Bsp.: Ljava/util/Vector<Ljava/lang/String;>;
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
String ret;
|
String ret;
|
||||||
|
List<Type> newParams = new ArrayList<>();
|
||||||
if(parameter != null && parameter.size() > 0){
|
if(parameter != null && parameter.size() > 0){
|
||||||
sb.append(getName().toString().replace(".", "%"));
|
sb.append(getName().toString().replace(".", "%"));
|
||||||
sb.append("%%");
|
sb.append("%%");
|
||||||
for(Type type: parameter){
|
for(Type type: parameter){
|
||||||
|
Type newParameter;
|
||||||
if(type instanceof RefType){
|
if(type instanceof RefType){
|
||||||
sb.append(((RefType) type).getCombinedType(cg, rs).replace(".", "%"));
|
sb.append(((RefType) type).getCombinedType(cg, rs).replace(".", "%"));
|
||||||
|
newParameter = type;
|
||||||
}else if(type instanceof TypePlaceholder){
|
}else if(type instanceof TypePlaceholder){
|
||||||
|
newParameter = rs.getTypeOfPlaceholder((TypePlaceholder)type);
|
||||||
sb.append(((TypePlaceholder) type).getBytecodeType(cg, rs).toString().replace(".", "%"));
|
sb.append(((TypePlaceholder) type).getBytecodeType(cg, rs).toString().replace(".", "%"));
|
||||||
}else if(type instanceof WildcardType){
|
}else if(type instanceof WildcardType){
|
||||||
|
//TODO: unresolved!
|
||||||
return this.getName().toString();
|
return this.getName().toString();
|
||||||
}else{
|
}else{
|
||||||
|
newParameter = type;
|
||||||
sb.append(type.getBytecodeType(cg, rs).toString().replace(".", "%"));
|
sb.append(type.getBytecodeType(cg, rs).toString().replace(".", "%"));
|
||||||
}
|
}
|
||||||
|
newParams.add(newParameter);
|
||||||
sb.append("%");
|
sb.append("%");
|
||||||
}
|
}
|
||||||
ret = sb.toString();
|
ret = sb.toString();
|
||||||
@ -612,7 +619,8 @@ public class RefType extends ObjectType implements IMatchable
|
|||||||
}
|
}
|
||||||
if(!ret.equals(getName().toString())){
|
if(!ret.equals(getName().toString())){
|
||||||
//getSuperWildcardTypes();
|
//getSuperWildcardTypes();
|
||||||
Class generatedClass = ASTFactory.createInterface(ret, this, null, null, new SourceFile());
|
RefType superClass = new RefType(this.getName(),newParams,this.getOffset());
|
||||||
|
Class generatedClass = ASTFactory.createInterface(ret, superClass, null, null, new SourceFile());
|
||||||
|
|
||||||
cg.addExtraClass(generatedClass.genByteCode(new TypeinferenceResults()).getByteCode());
|
cg.addExtraClass(generatedClass.genByteCode(new TypeinferenceResults()).getByteCode());
|
||||||
}
|
}
|
||||||
|
8
test/bytecode/lambda/Simple.jav
Normal file
8
test/bytecode/lambda/Simple.jav
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
class Simple{
|
||||||
|
|
||||||
|
op = (i)->i;
|
||||||
|
|
||||||
|
public void main(){
|
||||||
|
op.apply(1);
|
||||||
|
}
|
||||||
|
}
|
19
test/bytecode/lambda/SimpleTest.java
Normal file
19
test/bytecode/lambda/SimpleTest.java
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
package bytecode.lambda;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import bytecode.SourceFileBytecodeTest;
|
||||||
|
|
||||||
|
public class SimpleTest extends SourceFileBytecodeTest{
|
||||||
|
@Override
|
||||||
|
protected void init() {
|
||||||
|
testName = "Simple";
|
||||||
|
rootDirectory = System.getProperty("user.dir")+"/test/bytecode/lambda/";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testConstruct() throws Exception{
|
||||||
|
this.testMethod("main");
|
||||||
|
assertTrue(true);
|
||||||
|
}
|
||||||
|
}
|
5
test/bytecode/lambda/Test.java
Normal file
5
test/bytecode/lambda/Test.java
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
class Test{
|
||||||
|
public static void main(String[] args){
|
||||||
|
new Simple().main();
|
||||||
|
}
|
||||||
|
}
|
1
test/bytecode/lambda/TestInterface.java
Normal file
1
test/bytecode/lambda/TestInterface.java
Normal file
@ -0,0 +1 @@
|
|||||||
|
interface TestInterface extends Fun1<String,Integer>{}
|
Loading…
Reference in New Issue
Block a user