Package io.github.classgraph
Class ArrayClassInfo
- java.lang.Object
-
- io.github.classgraph.ClassInfo
-
- io.github.classgraph.ArrayClassInfo
-
public class ArrayClassInfo extends ClassInfo
Holds metadata about an array class. This class extendsClassInfo
with additional methods relevant to array classes, in particulargetArrayTypeSignature()
,getTypeSignatureStr()
,getElementTypeSignature()
,getElementClassInfo()
,loadElementClass()
, andgetNumDimensions()
.An
ArrayClassInfo
object will not have any methods, fields or annotations.ClassInfo.isArrayClass()
will return true for this subclass ofClassInfo
.
-
-
Field Summary
Fields Modifier and Type Field Description protected java.lang.Class<?>
classRef
The class ref, once the class is loaded.protected ScanResult
scanResult
The scan result.-
Fields inherited from class io.github.classgraph.ClassInfo
classfileResource, isExternalClass, isScannedClass, name, typeSignatureStr
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
equals(java.lang.Object obj)
Use class name for equals().protected void
findReferencedClassInfo(java.util.Map<java.lang.String,ClassInfo> classNameToClassInfo, java.util.Set<ClassInfo> refdClassInfo)
GetClassInfo
objects for any classes referenced in the type descriptor or type signature.ArrayTypeSignature
getArrayTypeSignature()
Get the type signature of the class.ClassInfo
getElementClassInfo()
Get theClassInfo
instance for the array element type.TypeSignature
getElementTypeSignature()
Get the type signature of the array elements.int
getNumDimensions()
Get the number of dimensions of the array.ClassTypeSignature
getTypeSignature()
Returns null, because array classes do not have a ClassTypeSignature.java.lang.String
getTypeSignatureStr()
Get the raw type signature string of the array class, e.g.int
hashCode()
Use hash code of class name.java.lang.Class<?>
loadClass()
Obtain aClass<?>
reference for the array class named by thisArrayClassInfo
object.java.lang.Class<?>
loadClass(boolean ignoreExceptions)
Obtain aClass<?>
reference for the array class named by thisArrayClassInfo
object.java.lang.Class<?>
loadElementClass()
Get aClass<?>
reference for the array element type.java.lang.Class<?>
loadElementClass(boolean ignoreExceptions)
Get aClass<?>
reference for the array element type.-
Methods inherited from class io.github.classgraph.ClassInfo
compareTo, extendsSuperclass, getAnnotationDefaultParameterValues, getAnnotationInfo, getAnnotationInfo, getAnnotationInfoRepeatable, getAnnotations, getClassDependencies, getClassesImplementing, getClassesWithAnnotation, getClassesWithFieldAnnotation, getClassesWithMethodAnnotation, getClassesWithMethodParameterAnnotation, getClassInfo, getClassName, getClasspathElementFile, getClasspathElementURI, getClasspathElementURL, getConstructorInfo, getDeclaredConstructorInfo, getDeclaredFieldInfo, getDeclaredFieldInfo, getDeclaredMethodAndConstructorInfo, getDeclaredMethodInfo, getDeclaredMethodInfo, getFieldAnnotations, getFieldInfo, getFieldInfo, getFullyQualifiedDefiningMethodName, getInnerClasses, getInterfaces, getMethodAndConstructorInfo, getMethodAnnotations, getMethodInfo, getMethodInfo, getMethodParameterAnnotations, getModifiers, getModifiersStr, getModuleInfo, getModuleRef, getName, getOuterClasses, getPackageInfo, getPackageName, getResource, getSimpleName, getSubclasses, getSuperclass, getSuperclasses, hasAnnotation, hasDeclaredField, hasDeclaredFieldAnnotation, hasDeclaredMethod, hasDeclaredMethodAnnotation, hasDeclaredMethodParameterAnnotation, hasField, hasFieldAnnotation, hasMethod, hasMethodAnnotation, hasMethodParameterAnnotation, implementsInterface, isAbstract, isAnnotation, isAnonymousInnerClass, isArrayClass, isEnum, isExternalClass, isFinal, isImplementedInterface, isInnerClass, isInterface, isInterfaceOrAnnotation, isOuterClass, isPublic, isStandardClass, isStatic, isSynthetic, loadClass, loadClass, toString, toString
-
-
-
-
Field Detail
-
scanResult
protected transient ScanResult scanResult
The scan result.
-
classRef
protected transient java.lang.Class<?> classRef
The class ref, once the class is loaded.
-
-
Method Detail
-
getTypeSignatureStr
public java.lang.String getTypeSignatureStr()
Get the raw type signature string of the array class, e.g. "[[I" for "int[][]".- Returns:
- The raw type signature string of the array class.
-
getTypeSignature
public ClassTypeSignature getTypeSignature()
Returns null, because array classes do not have a ClassTypeSignature. CallgetArrayTypeSignature()
instead.- Overrides:
getTypeSignature
in classClassInfo
- Returns:
- null (always).
-
getArrayTypeSignature
public ArrayTypeSignature getArrayTypeSignature()
Get the type signature of the class.- Returns:
- The class type signature, if available, otherwise returns null.
-
getElementTypeSignature
public TypeSignature getElementTypeSignature()
Get the type signature of the array elements.- Returns:
- The type signature of the array elements.
-
getNumDimensions
public int getNumDimensions()
Get the number of dimensions of the array.- Returns:
- The number of dimensions of the array.
-
getElementClassInfo
public ClassInfo getElementClassInfo()
Get theClassInfo
instance for the array element type.- Returns:
- the
ClassInfo
instance for the array element type. Returns null if the element type was not found during the scan. In particular, will return null for arrays that have a primitive element type.
-
loadElementClass
public java.lang.Class<?> loadElementClass(boolean ignoreExceptions)
Get aClass<?>
reference for the array element type. Causes the ClassLoader to load the element class, if it is not already loaded.- Parameters:
ignoreExceptions
- Whether or not to ignore exceptions.- Returns:
- a
Class<?>
reference for the array element type. Also works for arrays of primitive element type.
-
loadElementClass
public java.lang.Class<?> loadElementClass()
Get aClass<?>
reference for the array element type. Causes the ClassLoader to load the element class, if it is not already loaded.- Returns:
- a
Class<?>
reference for the array element type. Also works for arrays of primitive element type.
-
loadClass
public java.lang.Class<?> loadClass(boolean ignoreExceptions)
Obtain aClass<?>
reference for the array class named by thisArrayClassInfo
object. Causes the ClassLoader to load the element class, if it is not already loaded.- Overrides:
loadClass
in classClassInfo
- Parameters:
ignoreExceptions
- Whether or not to ignore exceptions- Returns:
- The class reference, or null, if ignoreExceptions is true and there was an exception or error loading the class.
- Throws:
java.lang.IllegalArgumentException
- if ignoreExceptions is false and there were problems loading the class.
-
loadClass
public java.lang.Class<?> loadClass()
Obtain aClass<?>
reference for the array class named by thisArrayClassInfo
object. Causes the ClassLoader to load the element class, if it is not already loaded.
-
findReferencedClassInfo
protected void findReferencedClassInfo(java.util.Map<java.lang.String,ClassInfo> classNameToClassInfo, java.util.Set<ClassInfo> refdClassInfo)
GetClassInfo
objects for any classes referenced in the type descriptor or type signature.- Overrides:
findReferencedClassInfo
in classClassInfo
- Parameters:
classNameToClassInfo
- the map from class name toClassInfo
.refdClassInfo
- the referenced class info
-
equals
public boolean equals(java.lang.Object obj)
Description copied from class:ClassInfo
Use class name for equals().
-
-