forked from JavaTX/JavaCompilerCore
GenericType für Bytecodegenerierung eingeführt
This commit is contained in:
parent
1b99f74f39
commit
ddbcc5ee6e
@ -64,8 +64,8 @@ public class BytecodeTypeFactory {
|
|||||||
* @see https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-ReferenceTypeSignature
|
* @see https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-ReferenceTypeSignature
|
||||||
*/
|
*/
|
||||||
private static String generateTypeSignature(RefType t){
|
private static String generateTypeSignature(RefType t){
|
||||||
if(t.isGenericType())return generateReferenceTypeSignature(t);
|
if(t.isGenericType())return generateGenericTypeSignature(t);
|
||||||
return generateGenericTypeSignature(t);
|
return generateReferenceTypeSignature(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String generateReferenceTypeSignature(RefType t){
|
private static String generateReferenceTypeSignature(RefType t){
|
||||||
@ -81,7 +81,7 @@ public class BytecodeTypeFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static String generateGenericTypeSignature(RefType t){
|
private static String generateGenericTypeSignature(RefType t){
|
||||||
String ret = "T" + t.get_Name();
|
String ret = "T" + t.getName();
|
||||||
return ret + ";";
|
return ret + ";";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,7 +3,6 @@ import java.util.ArrayList;
|
|||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import de.dhbwstuttgart.typeinference.Menge;
|
|
||||||
import de.dhbwstuttgart.bytecode.ClassGenerator;
|
import de.dhbwstuttgart.bytecode.ClassGenerator;
|
||||||
import de.dhbwstuttgart.typecheck.JavaClassName;
|
import de.dhbwstuttgart.typecheck.JavaClassName;
|
||||||
import de.dhbwstuttgart.syntaxtree.Class;
|
import de.dhbwstuttgart.syntaxtree.Class;
|
||||||
@ -27,13 +26,7 @@ public class RefType extends SyntaxTreeNode
|
|||||||
private boolean IsArray = false;
|
private boolean IsArray = false;
|
||||||
protected JavaClassName name;
|
protected JavaClassName name;
|
||||||
protected List<RefType> parameter = null;
|
protected List<RefType> parameter = null;
|
||||||
/**
|
private boolean isGeneric = false;
|
||||||
* Ist primitiveFlag auf true, muss beim Codegen dieser Reftype durch
|
|
||||||
* den primitiven Datentyp ersetzt werden
|
|
||||||
*
|
|
||||||
* Bsp: java.lang.Integer mit Flag wird dann zu [int]
|
|
||||||
*/
|
|
||||||
private boolean primitiveFlag=false;
|
|
||||||
|
|
||||||
public RefType(JavaClassName fullyQualifiedName, int offset)
|
public RefType(JavaClassName fullyQualifiedName, int offset)
|
||||||
{
|
{
|
||||||
@ -49,11 +42,18 @@ public class RefType extends SyntaxTreeNode
|
|||||||
return hash;
|
return hash;
|
||||||
}
|
}
|
||||||
|
|
||||||
public RefType(JavaClassName fullyQualifiedName, List<RefType> parameter, int offset)
|
public RefType(JavaClassName fullyQualifiedName, List<RefType> parameter, int offset)
|
||||||
{
|
{
|
||||||
this(fullyQualifiedName, offset);
|
this(fullyQualifiedName, offset);
|
||||||
if(parameter != null && parameter.size()>0)this.parameter = parameter;
|
if(parameter != null && parameter.size()>0)this.parameter = parameter;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public RefType(JavaClassName fullyQualifiedName, List<RefType> parameter, boolean isGneric,int offset)
|
||||||
|
{
|
||||||
|
this(fullyQualifiedName, offset);
|
||||||
|
if(parameter != null && parameter.size()>0)this.parameter = parameter;
|
||||||
|
this.isGeneric = isGneric;
|
||||||
|
}
|
||||||
|
|
||||||
public JavaClassName getName()
|
public JavaClassName getName()
|
||||||
{
|
{
|
||||||
@ -127,10 +127,9 @@ public class RefType extends SyntaxTreeNode
|
|||||||
|
|
||||||
public String toString()
|
public String toString()
|
||||||
{
|
{
|
||||||
String primitiveFlagMarker=primitiveFlag?"*":"";
|
|
||||||
if(parameter==null)
|
if(parameter==null)
|
||||||
{
|
{
|
||||||
return name+primitiveFlagMarker;
|
return this.getName().toString();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -146,7 +145,7 @@ public class RefType extends SyntaxTreeNode
|
|||||||
}
|
}
|
||||||
String ret = name.toString();
|
String ret = name.toString();
|
||||||
if(parameter.size()>0)ret += "<"+para + " >";
|
if(parameter.size()>0)ret += "<"+para + " >";
|
||||||
return ret + primitiveFlagMarker;//name + "<"+para + " >" +primitiveFlagMarker;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -250,5 +249,9 @@ public class RefType extends SyntaxTreeNode
|
|||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isGenericType() {
|
||||||
|
return isGeneric;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user