Implementierung neuer ASTGen fortgesetzt

This commit is contained in:
luca9913 2023-01-21 05:35:15 +01:00
parent 3bdc3b764d
commit 1cf23bec90
2 changed files with 59 additions and 20 deletions

View File

@ -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;
} }

View File

@ -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);
} }