forked from JavaTX/JavaCompilerCore
Implementierung neuer ASTGen fortgesetzt
This commit is contained in:
parent
3bdc3b764d
commit
1cf23bec90
@ -19,6 +19,8 @@ import de.dhbwstuttgart.exceptions.TypeinferenceException;
|
|||||||
import de.dhbwstuttgart.parser.antlr.Java17Parser;
|
import de.dhbwstuttgart.parser.antlr.Java17Parser;
|
||||||
import de.dhbwstuttgart.parser.antlr.Java17Parser.ClassOrInterfaceModifierContext;
|
import de.dhbwstuttgart.parser.antlr.Java17Parser.ClassOrInterfaceModifierContext;
|
||||||
import de.dhbwstuttgart.parser.antlr.Java17Parser.ClassorinterfacedeclContext;
|
import de.dhbwstuttgart.parser.antlr.Java17Parser.ClassorinterfacedeclContext;
|
||||||
|
import de.dhbwstuttgart.parser.antlr.Java17Parser.MemberdeclContext;
|
||||||
|
import de.dhbwstuttgart.parser.antlr.Java17Parser.MemberfieldContext;
|
||||||
import de.dhbwstuttgart.parser.antlr.Java17Parser.ModifierContext;
|
import de.dhbwstuttgart.parser.antlr.Java17Parser.ModifierContext;
|
||||||
import de.dhbwstuttgart.parser.antlr.Java17Parser.NoclassorinterfaceContext;
|
import de.dhbwstuttgart.parser.antlr.Java17Parser.NoclassorinterfaceContext;
|
||||||
import de.dhbwstuttgart.parser.antlr.Java17Parser.SrcfileContext;
|
import de.dhbwstuttgart.parser.antlr.Java17Parser.SrcfileContext;
|
||||||
@ -153,7 +155,7 @@ public class ASTGen {
|
|||||||
} else {
|
} else {
|
||||||
superClass = new RefType(ASTFactory.createObjectClass().getClassName(), ctx.getStart());
|
superClass = new RefType(ASTFactory.createObjectClass().getClassName(), ctx.getStart());
|
||||||
}
|
}
|
||||||
// List<Field> fielddecl = convertFields(ctx.classBody(), generics);
|
List<Field> fielddecl = convertFields(ctx.classBody(), generics);
|
||||||
}
|
}
|
||||||
|
|
||||||
private RefType convert(Java17Parser.TypeTypeContext typeType) {
|
private RefType convert(Java17Parser.TypeTypeContext typeType) {
|
||||||
@ -179,15 +181,48 @@ public class ASTGen {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int convertModifier(Java17Parser.ClassOrInterfaceModifierContext ctx) {
|
private List<Field> convertFields(Java17Parser.ClassBodyContext classBodyContext, GenericsRegistry generics) {
|
||||||
int ret = 0;
|
List<Field> ret = new ArrayList<>();
|
||||||
if (ctx.annotation() != null) {
|
for (Java17Parser.ClassBodyDeclarationContext classBody : classBodyContext.classBodyDeclaration()) {
|
||||||
return ret;
|
if (classBody instanceof MemberdeclContext) {
|
||||||
} else {
|
MemberdeclContext memberdecl = new MemberdeclContext(classBody);
|
||||||
for (String m : this.allmodifiers.keySet()) {
|
int modifiers = 0;
|
||||||
if (ctx.getText().contains(m))
|
for (ModifierContext mod : memberdecl.modifier()) {
|
||||||
ret += allmodifiers.get(m);
|
modifiers += convert(mod);
|
||||||
}
|
}
|
||||||
|
if (memberdecl.memberDeclaration() instanceof MemberfieldContext) {
|
||||||
|
ret.addAll(
|
||||||
|
convert(new MemberfieldContext(memberdecl.memberDeclaration()).fieldDeclaration(), modifiers, generics));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<? extends Field> convert(Java17Parser.FieldDeclarationContext fieldDeclContext, int modifiers,
|
||||||
|
GenericsRegistry generics) {
|
||||||
|
List<Field> ret = new ArrayList<>();
|
||||||
|
RefTypeOrTPHOrWildcardOrGeneric fieldType;
|
||||||
|
if (fieldDeclContext.typeType() != null) {
|
||||||
|
// TODO: fieldType = TypeGenerator.convert()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private int convert(Java17Parser.ClassOrInterfaceModifierContext ctx) {
|
||||||
|
if (ctx.annotation() != null)
|
||||||
|
return 0;
|
||||||
|
return convertModifier(ctx.getText());
|
||||||
|
}
|
||||||
|
|
||||||
|
private int convert(Java17Parser.ModifierContext ctx) {
|
||||||
|
return convertModifier(ctx.getText());
|
||||||
|
}
|
||||||
|
|
||||||
|
public int convertModifier(String modifier) {
|
||||||
|
int ret = 0;
|
||||||
|
for (String m : this.allmodifiers.keySet()) {
|
||||||
|
if (modifier.contains(m))
|
||||||
|
ret += allmodifiers.get(m);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -26,7 +26,7 @@ import java.util.regex.Pattern;
|
|||||||
public class TypeGenerator {
|
public class TypeGenerator {
|
||||||
|
|
||||||
public static RefTypeOrTPHOrWildcardOrGeneric convert(
|
public static RefTypeOrTPHOrWildcardOrGeneric convert(
|
||||||
Java17Parser.UnannClassOrInterfaceTypeContext unannClassOrInterfaceTypeContext, JavaClassRegistry reg,
|
Java17Parser.ClassOrInterfaceTypeContext unannClassOrInterfaceTypeContext, JavaClassRegistry reg,
|
||||||
GenericsRegistry generics) {
|
GenericsRegistry generics) {
|
||||||
Java17Parser.TypeArgumentsContext arguments = null;
|
Java17Parser.TypeArgumentsContext arguments = null;
|
||||||
/*
|
/*
|
||||||
@ -92,24 +92,28 @@ public class TypeGenerator {
|
|||||||
return convertTypeName(name, arguments, unannClassOrInterfaceTypeContext.getStart(), reg, generics);
|
return convertTypeName(name, arguments, unannClassOrInterfaceTypeContext.getStart(), reg, generics);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static RefTypeOrTPHOrWildcardOrGeneric convert(Java17Parser.UnannTypeContext unannTypeContext,
|
public static RefTypeOrTPHOrWildcardOrGeneric convert(Java17Parser.TypeTypeContext typeContext,
|
||||||
JavaClassRegistry reg, GenericsRegistry genericsRegistry) {
|
JavaClassRegistry reg, GenericsRegistry genericsRegistry) {
|
||||||
if (unannTypeContext.unannPrimitiveType() != null) {
|
if (typeContext.primitiveType() != null) {
|
||||||
if (unannTypeContext.unannPrimitiveType().getText().equals("boolean")) {
|
if (typeContext.primitiveType().getText().equals("boolean")) {
|
||||||
return new RefType(ASTFactory.createClass(Boolean.class).getClassName(), unannTypeContext.getStart());
|
return new RefType(ASTFactory.createClass(Boolean.class).getClassName(), typeContext.getStart());
|
||||||
} else {
|
} else {
|
||||||
Java17Parser.NumericTypeContext numericType = unannTypeContext.unannPrimitiveType().numericType();
|
/*
|
||||||
|
* Nicht benötigt, wenn danach eine Exception erstellt wird
|
||||||
|
* Java17Parser.NumericTypeContext numericType =
|
||||||
|
* typeContext.unannPrimitiveType().numericType();
|
||||||
|
*/
|
||||||
throw new NotImplementedException();
|
throw new NotImplementedException();
|
||||||
}
|
}
|
||||||
} else if (unannTypeContext.unannReferenceType().unannArrayType() != null) {
|
} else if (!typeContext.LBRACK().isEmpty()) { // ArrayType über eckige Klammer prüfen
|
||||||
// System.out.println(unannTypeContext.getText());
|
// System.out.println(unannTypeContext.getText());
|
||||||
throw new NotImplementedException();
|
throw new NotImplementedException();
|
||||||
} else if (unannTypeContext.unannReferenceType().unannTypeVariable() != null) {
|
} else if (typeContext.classOrInterfaceType() != null) {
|
||||||
JavaClassName name = reg
|
JavaClassName name = reg
|
||||||
.getName(unannTypeContext.unannReferenceType().unannTypeVariable().Identifier().toString());
|
.getName(typeContext.classOrInterfaceType().typeIdentifier().getText());
|
||||||
return new RefType(name, unannTypeContext.getStart());
|
return new RefType(name, typeContext.getStart());
|
||||||
}
|
}
|
||||||
return TypeGenerator.convert(unannTypeContext.unannReferenceType().unannClassOrInterfaceType(), reg,
|
return TypeGenerator.convert(typeContext.classOrInterfaceType(), reg,
|
||||||
genericsRegistry);
|
genericsRegistry);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user