Class AbstractTypeDeclaration
java.lang.Object
com.github.javaparser.symbolsolver.logic.AbstractTypeDeclaration
- All Implemented Interfaces:
AssociableToAST, ResolvedDeclaration, ResolvedReferenceTypeDeclaration, ResolvedTypeDeclaration, ResolvedTypeParametrizable
- Direct Known Subclasses:
AbstractClassDeclaration, JavaParserAnnotationDeclaration, JavaParserEnumDeclaration, JavaParserInterfaceDeclaration, JavaParserRecordDeclaration, JavaParserTypeParameter, JavaParserTypeVariableDeclaration, JavassistAnnotationDeclaration, JavassistEnumDeclaration, JavassistInterfaceDeclaration, JavassistRecordDeclaration, ReflectionAnnotationDeclaration, ReflectionEnumDeclaration, ReflectionInterfaceDeclaration, ReflectionRecordDeclaration
public abstract class AbstractTypeDeclaration
extends Object
implements ResolvedReferenceTypeDeclaration
Common ancestor for most types.
-
Field Summary
Fields inherited from interface ResolvedReferenceTypeDeclaration
breadthFirstFunc, depthFirstFunc, JAVA_IO_SERIALIZABLE, JAVA_LANG_COMPARABLE, JAVA_LANG_ENUM, JAVA_LANG_OBJECT, JAVA_LANG_RECORD -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionfinal Set<MethodUsage> Return a list of all the methods declared of this type declaration, either declared or inherited.final booleanThis means that the type has a functional method.static booleanisRecordType(Class<?> clazz) With the introduction of records in Java 14 (Preview), theClass.isRecordmethod was added to check whether a class is a record or not (similar toisEnumetc.).Methods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface AssociableToAST
toAst, toAstMethods inherited from interface ResolvedDeclaration
asEnumConstant, asField, asMethod, asParameter, asTypePattern, getName, hasName, isEnumConstant, isField, isMethod, isParameter, isTypePattern, isVariableMethods inherited from interface ResolvedReferenceTypeDeclaration
asReferenceType, canBeAssignedTo, findTypeParameter, getAllAncestors, getAllAncestors, getAllFields, getAllNonStaticFields, getAllStaticFields, getAncestors, getAncestors, getConstructors, getDeclaredAnnotation, getDeclaredAnnotations, getDeclaredFields, getDeclaredMethods, getField, getVisibleField, getVisibleFields, hasAnnotation, hasDirectlyAnnotation, hasField, hasVisibleField, isAssignableBy, isAssignableBy, isInheritedAnnotation, isJavaLangEnum, isJavaLangObject, isJavaLangRecord, isReferenceTypeMethods inherited from interface ResolvedTypeDeclaration
asAnnotation, asClass, asEnum, asInterface, asRecord, asType, asTypeParameter, containerType, getClassName, getId, getInternalType, getPackageName, getQualifiedName, hasInternalType, internalTypes, isAnnotation, isAnonymousClass, isClass, isEnum, isInterface, isRecord, isType, isTypeParameterMethods inherited from interface ResolvedTypeParametrizable
getTypeParameters, isGeneric
-
Constructor Details
-
AbstractTypeDeclaration
public AbstractTypeDeclaration()
-
-
Method Details
-
getAllMethods
Description copied from interface:ResolvedReferenceTypeDeclarationReturn a list of all the methods declared of this type declaration, either declared or inherited. Note that it should not include overridden methods.- Specified by:
getAllMethodsin interfaceResolvedReferenceTypeDeclaration
-
isFunctionalInterface
public final boolean isFunctionalInterface()Description copied from interface:ResolvedReferenceTypeDeclarationThis means that the type has a functional method. Conceptually, a functional interface has exactly one abstract method. Typically these classes has the FunctionInterface annotation but this is not mandatory.- Specified by:
isFunctionalInterfacein interfaceResolvedReferenceTypeDeclaration
-
isRecordType
With the introduction of records in Java 14 (Preview), theClass.isRecordmethod was added to check whether a class is a record or not (similar toisEnumetc.). This method cannot be used directly in JavaParser, however, since it will not compile on Java versions 8-13 (or 15 if preview features aren't enabled) which are supported by the project. This workaround calls theisRecordmethod via reflection which compiles while still giving the expected answer. There are 2 cases to consider when this method is called: 1) JavaParser is invoked using a Java runtime which supports records In this case, theisRecordmethod exists, so invoking it will give the answer as usual. 2) JavaParser is invoked using an older Java runtime without record support In this case, theisRecordmethod does not exist, so attempting to invoke it will throw aNoSuchMethodException. This is not a problem since the classloader cannot load classes compiled by Java versions greater than that used to invoke JavaParser. This means that if JavaParser is invoked with a Java 8 runtime, for example, then no classes compiled with Java versions greater than 8 are supported, so no class loaded by the classloader could possibly be a record class since it could not be compiled in the first place. There may be an edge case here for classes compiled with Java 14/15 preview, but most likely these won't load either. In the case of anNoSuchMethodException, simply return false as the type could not be a record for the reason explained above.
-