Package net.bytebuddy.description.type
Interface TypeDescription
-
- All Superinterfaces:
AnnotationSource,ByteCodeElement,DeclaredByType,java.lang.Iterable<TypeDefinition>,ModifierReviewable,ModifierReviewable.ForTypeDefinition,ModifierReviewable.OfAbstraction,ModifierReviewable.OfByteCodeElement,ModifierReviewable.OfEnumeration,NamedElement,NamedElement.WithDescriptor,NamedElement.WithRuntimeName,TypeDefinition,TypeVariableSource
- All Known Subinterfaces:
InstrumentedType,InstrumentedType.WithFlexibleName
- All Known Implementing Classes:
InstrumentedType.Default,InstrumentedType.Frozen,TypeDescription.AbstractBase,TypeDescription.AbstractBase.OfSimpleType,TypeDescription.AbstractBase.OfSimpleType.WithDelegation,TypeDescription.ArrayProjection,TypeDescription.ForLoadedType,TypeDescription.ForLoadedType.ClassDescriptionTypeList.InternalNameLazyType,TypeDescription.ForPackageDescription,TypeDescription.Latent,TypeDescription.SuperTypeLoading,TypePool.Default.LazyTypeDescription,TypePool.Default.WithLazyResolution.LazyTypeDescription,TypePool.LazyFacade.LazyTypeDescription
public interface TypeDescription extends TypeDefinition, ByteCodeElement, TypeVariableSource
Implementations of this interface represent a Java type, i.e. a class or interface. Instances of this interface always represent non-generic types of sortTypeDefinition.Sort.NON_GENERIC.
-
-
Nested Class Summary
Nested Classes Modifier and Type Interface Description static classTypeDescription.AbstractBaseAn abstract base implementation of a type description.static classTypeDescription.ArrayProjectionA projection for an array type based on an existingTypeDescription.static classTypeDescription.ForLoadedTypeA type description implementation that represents a loaded type.static classTypeDescription.ForPackageDescriptionA type representation of a package description.static interfaceTypeDescription.GenericRepresents a generic type of the Java programming language.static classTypeDescription.LatentA latent type description for a type without methods or fields.static classTypeDescription.SuperTypeLoadingA delegating type description that always attempts to load the super types of a delegate type.-
Nested classes/interfaces inherited from interface net.bytebuddy.description.annotation.AnnotationSource
AnnotationSource.Empty, AnnotationSource.Explicit
-
Nested classes/interfaces inherited from interface net.bytebuddy.description.ByteCodeElement
ByteCodeElement.Token<T extends ByteCodeElement.Token<T>>, ByteCodeElement.TypeDependant<T extends ByteCodeElement.TypeDependant<?,S>,S extends ByteCodeElement.Token<S>>
-
Nested classes/interfaces inherited from interface net.bytebuddy.description.ModifierReviewable
ModifierReviewable.ForFieldDescription, ModifierReviewable.ForMethodDescription, ModifierReviewable.ForParameterDescription, ModifierReviewable.ForTypeDefinition, ModifierReviewable.OfAbstraction, ModifierReviewable.OfByteCodeElement, ModifierReviewable.OfEnumeration
-
Nested classes/interfaces inherited from interface net.bytebuddy.description.NamedElement
NamedElement.WithDescriptor, NamedElement.WithGenericName, NamedElement.WithOptionalName, NamedElement.WithRuntimeName
-
Nested classes/interfaces inherited from interface net.bytebuddy.description.type.TypeDefinition
TypeDefinition.Sort, TypeDefinition.SuperClassIterator
-
Nested classes/interfaces inherited from interface net.bytebuddy.description.TypeVariableSource
TypeVariableSource.Visitor<T>
-
-
Field Summary
Fields Modifier and Type Field Description static TypeList.GenericARRAY_INTERFACESA list of interfaces that are implicitly implemented by any array type.static TypeDescriptionCLASSA representation of theClasstype.static TypeDescriptionOBJECTA representation of theObjecttype.static TypeDescriptionSTRINGA representation of theStringtype.static TypeDescriptionTHROWABLEA representation of theThrowabletype.static TypeDescriptionUNDEFINEDRepresents any undefined property representing a type description that is instead represented asnullin order to resemble the Java reflection API which returnsnulland is intuitive to many Java developers.static TypeDescriptionVOIDA representation of thevoidnon-type.-
Fields inherited from interface net.bytebuddy.description.ModifierReviewable
EMPTY_MASK
-
Fields inherited from interface net.bytebuddy.description.NamedElement
EMPTY_NAME, NO_NAME
-
Fields inherited from interface net.bytebuddy.description.NamedElement.WithDescriptor
NON_GENERIC_SIGNATURE
-
Fields inherited from interface net.bytebuddy.description.type.TypeDefinition
RAW_TYPES_PROPERTY
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description TypeDescriptionasBoxed()Returns a description of this type that represents this type as a boxed type for primitive types, unless itsvoid.TypeDescriptionasUnboxed()Returns a description of this type that represents this type as an unboxed type for boxing types, unless itsVoid.intgetActualModifiers(boolean superFlag)Returns the type's actual modifiers as present in the class file.java.lang.StringgetCanonicalName()Returns the canonical name of this type if it exists.TypeDescriptiongetComponentType()Returns the component type of this type.FieldList<FieldDescription.InDefinedShape>getDeclaredFields()Returns the fields that this type declares.MethodList<MethodDescription.InDefinedShape>getDeclaredMethods()Returns the methods that this type declares.TypeListgetDeclaredTypes()Returns a list of types that are declared by this type.TypeDescriptiongetDeclaringType()Returns the declaring type of this instance.java.lang.ObjectgetDefaultValue()Returns the default value for this type, i.e.MethodDescription.InDefinedShapegetEnclosingMethod()Returns a description of the method that encloses this type.TypeDescriptiongetEnclosingType()Returns a description of this type's enclosing type if any.AnnotationListgetInheritedAnnotations()Returns the annotations that this type declares or inherits from super types.intgetInnerClassCount()Returns the amount of outer classes this type defines.TypeDescriptiongetNestHost()Returns the nest host of this type.TypeListgetNestMembers()Returns a list of members that are part of a nesting group.PackageDescriptiongetPackage()Returns the package of the type described by this instance ornullif the described type does not imply a package.TypeListgetPermittedSubclasses()Returns the list of permitted subclasses if this class is a sealed class or an empty list if this class is not sealed.RecordComponentList<RecordComponentDescription.InDefinedShape>getRecordComponents()Returns the list of record components that are declared by this type.java.lang.StringgetSimpleName()Returns the simple internalName of this type.booleanisAnnotationReturnType()Checks if instances of this type can be returned from an annotation method.booleanisAnnotationValue()Checks if instances of this type can be used for describing an annotation value.booleanisAnnotationValue(java.lang.Object value)Checks if instances of this type can be used for describing the given annotation value.booleanisAnonymousType()Checks if this type description represents an anonymous type.booleanisAssignableFrom(java.lang.Class<?> type)Checks if this type is assignable from the type described by this instance, for example forclass Fooandclass Bar extends Foo, this method would returntrueforFoo.class.isAssignableFrom(Bar.class).booleanisAssignableFrom(TypeDescription typeDescription)Checks if this type is assignable from the type described by this instance, for example forclass Fooandclass Bar extends Foo, this method would returntrueforFoo.class.isAssignableFrom(Bar.class).booleanisAssignableTo(java.lang.Class<?> type)Checks if this type is assignable from the type described by this instance, for example forclass Fooandclass Bar extends Foo, this method would returntrueforBar.class.isAssignableTo(Foo.class).booleanisAssignableTo(TypeDescription typeDescription)Checks if this type is assignable from the type described by this instance, for example forclass Fooandclass Bar extends Foo, this method would returntrueforBar.class.isAssignableFrom(Foo.class).booleanisCompileTimeConstant()Indicates if this type represents a compile-time constant, i.e.booleanisInHierarchyWith(java.lang.Class<?> type)Returnstrueif this type and the supplied type are in a type hierarchy with each other, i.e.booleanisInHierarchyWith(TypeDescription typeDescription)Returnstrueif this type and the supplied type are in a type hierarchy with each other, i.e.booleanisInnerClass()Indicates if this class is an inner class.booleanisInstance(java.lang.Object value)Checks ifvalueis an instance of the type represented by this instance.booleanisLocalType()Checks if this type description represents a local type.booleanisMemberType()Checks if this type description represents a member type.booleanisNestedClass()Indicates if this class is a nested class.booleanisNestHost()Checks if this class is the host of a nest group.booleanisNestMateOf(java.lang.Class<?> type)Checks if this type and the supplied type are members of the same nest group.booleanisNestMateOf(TypeDescription typeDescription)Checks if this type and the supplied type are members of the same nest group.booleanisPackageType()Checks if this type represents a class that is a place holder for a package description.booleanisPrimitiveWrapper()Checks if this type represents a wrapper type for a primitive type.booleanisSamePackage(TypeDescription typeDescription)Checks if two types are defined in the same package.booleanisSealed()Returnstrueif this class is a sealed class that only permitts a specified range of subclasses.-
Methods inherited from interface net.bytebuddy.description.annotation.AnnotationSource
getDeclaredAnnotations
-
Methods inherited from interface net.bytebuddy.description.ByteCodeElement
isAccessibleTo, isVisibleTo
-
Methods inherited from interface net.bytebuddy.description.ModifierReviewable
getModifiers, getSyntheticState, isFinal, isSynthetic
-
Methods inherited from interface net.bytebuddy.description.ModifierReviewable.ForTypeDefinition
getTypeManifestation, isAnnotation, isInterface
-
Methods inherited from interface net.bytebuddy.description.ModifierReviewable.OfAbstraction
isAbstract
-
Methods inherited from interface net.bytebuddy.description.ModifierReviewable.OfByteCodeElement
getOwnership, getVisibility, isDeprecated, isPackagePrivate, isPrivate, isProtected, isPublic, isStatic
-
Methods inherited from interface net.bytebuddy.description.ModifierReviewable.OfEnumeration
getEnumerationState, isEnum
-
Methods inherited from interface net.bytebuddy.description.NamedElement
getActualName
-
Methods inherited from interface net.bytebuddy.description.NamedElement.WithDescriptor
getDescriptor, getGenericSignature
-
Methods inherited from interface net.bytebuddy.description.NamedElement.WithRuntimeName
getInternalName, getName
-
Methods inherited from interface net.bytebuddy.description.type.TypeDefinition
asErasure, asGenericType, getInterfaces, getSort, getStackSize, getSuperClass, getTypeName, isArray, isPrimitive, isRecord, represents
-
Methods inherited from interface net.bytebuddy.description.TypeVariableSource
accept, findVariable, getEnclosingSource, getTypeVariables, isGenerified, isInferrable
-
-
-
-
Field Detail
-
OBJECT
static final TypeDescription OBJECT
A representation of theObjecttype.
-
STRING
static final TypeDescription STRING
A representation of theStringtype.
-
CLASS
static final TypeDescription CLASS
A representation of theClasstype.
-
THROWABLE
static final TypeDescription THROWABLE
A representation of theThrowabletype.
-
VOID
static final TypeDescription VOID
A representation of thevoidnon-type.
-
ARRAY_INTERFACES
static final TypeList.Generic ARRAY_INTERFACES
A list of interfaces that are implicitly implemented by any array type.
-
UNDEFINED
static final TypeDescription UNDEFINED
Represents any undefined property representing a type description that is instead represented asnullin order to resemble the Java reflection API which returnsnulland is intuitive to many Java developers.
-
-
Method Detail
-
getDeclaredFields
FieldList<FieldDescription.InDefinedShape> getDeclaredFields()
Returns the fields that this type declares. A super type is only defined for non-generic types (TypeDefinition.Sort.NON_GENERIC), parameterized types (TypeDefinition.Sort.PARAMETERIZED) or generic array types (TypeDefinition.Sort.GENERIC_ARRAY) types. Generic array types never define fields and the returned list is always empty for such types.- Specified by:
getDeclaredFieldsin interfaceTypeDefinition- Returns:
- The fields that this type declares. A super type is only defined for non-generic types (
TypeDefinition.Sort.NON_GENERIC), parameterized types (TypeDefinition.Sort.PARAMETERIZED) or generic array types (TypeDefinition.Sort.GENERIC_ARRAY) types. Generic array types never define methods and the returned list is always empty for such types.
-
getDeclaredMethods
MethodList<MethodDescription.InDefinedShape> getDeclaredMethods()
Returns the methods that this type declares.- Specified by:
getDeclaredMethodsin interfaceTypeDefinition- Returns:
- The methods that this type declares.
-
getRecordComponents
RecordComponentList<RecordComponentDescription.InDefinedShape> getRecordComponents()
Returns the list of record components that are declared by this type. If this type is not a record, the returned list is empty.- Specified by:
getRecordComponentsin interfaceTypeDefinition- Returns:
- A list of record components that this type declares.
-
isInstance
boolean isInstance(java.lang.Object value)
Checks ifvalueis an instance of the type represented by this instance.- Parameters:
value- The object of interest.- Returns:
trueif the object is an instance of the type described by this instance.
-
isAssignableFrom
boolean isAssignableFrom(java.lang.Class<?> type)
Checks if this type is assignable from the type described by this instance, for example forclass Fooandclass Bar extends Foo, this method would returntrueforFoo.class.isAssignableFrom(Bar.class).- Parameters:
type- The type of interest.- Returns:
trueif this type is assignable fromtype.
-
isAssignableFrom
boolean isAssignableFrom(TypeDescription typeDescription)
Checks if this type is assignable from the type described by this instance, for example forclass Fooandclass Bar extends Foo, this method would returntrueforFoo.class.isAssignableFrom(Bar.class).
Implementations of this methods are allowed to delegate toisAssignableFrom(Class)- Parameters:
typeDescription- The type of interest.- Returns:
trueif this type is assignable fromtype.
-
isAssignableTo
boolean isAssignableTo(java.lang.Class<?> type)
Checks if this type is assignable from the type described by this instance, for example forclass Fooandclass Bar extends Foo, this method would returntrueforBar.class.isAssignableTo(Foo.class).- Parameters:
type- The type of interest.- Returns:
trueif this type is assignable totype.
-
isAssignableTo
boolean isAssignableTo(TypeDescription typeDescription)
Checks if this type is assignable from the type described by this instance, for example forclass Fooandclass Bar extends Foo, this method would returntrueforBar.class.isAssignableFrom(Foo.class).
Implementations of this methods are allowed to delegate toisAssignableTo(Class)- Parameters:
typeDescription- The type of interest.- Returns:
trueif this type is assignable totype.
-
isInHierarchyWith
boolean isInHierarchyWith(java.lang.Class<?> type)
Returnstrueif this type and the supplied type are in a type hierarchy with each other, i.e. if this type is assignable to the supplied type or the other way around.- Parameters:
type- The type of interest.- Returns:
trueif this type and the supplied type are in a type hierarchy with each other.
-
isInHierarchyWith
boolean isInHierarchyWith(TypeDescription typeDescription)
Returnstrueif this type and the supplied type are in a type hierarchy with each other, i.e. if this type is assignable to the supplied type or the other way around.- Parameters:
typeDescription- The type of interest.- Returns:
trueif this type and the supplied type are in a type hierarchy with each other.
-
getComponentType
TypeDescription getComponentType()
Returns the component type of this type.
Only non-generic types (
TypeDefinition.Sort.NON_GENERIC) and generic array typesTypeDefinition.Sort.GENERIC_ARRAY) define a component type. For other types, anIllegalStateExceptionis thrown.- Specified by:
getComponentTypein interfaceTypeDefinition- Returns:
- The component type of this type or
nullif this type does not represent an array type.
-
getDeclaringType
TypeDescription getDeclaringType()
Returns the declaring type of this instance.- Specified by:
getDeclaringTypein interfaceDeclaredByType- Returns:
- The declaring type or
nullif no such type exists.
-
getDeclaredTypes
TypeList getDeclaredTypes()
Returns a list of types that are declared by this type. This list does not normally include anonymous types but might include additional types if they are explicitly added to an instrumented type.- Returns:
- A list of types that are declared within this type.
-
getEnclosingMethod
MethodDescription.InDefinedShape getEnclosingMethod()
Returns a description of the method that encloses this type. If this method is not enclosed by any type or is enclosed by the type initializer,nullis returned by this method.- Returns:
- A description of the enclosing method of this type or
nullif there is no such method.
-
getEnclosingType
TypeDescription getEnclosingType()
Returns a description of this type's enclosing type if any.- Returns:
- A description of the enclosing type of this type or
nullif there is no such type.
-
getActualModifiers
int getActualModifiers(boolean superFlag)
Returns the type's actual modifiers as present in the class file. For example, a type cannot beprivate. but it modifiers might reflect this property nevertheless if a class was defined as a private inner class. The returned modifiers take also into account if the type is marked asDeprecated. Anonymous classes that are enclosed in a static method or the type initializer are additionally marked asfinalas it is also done by the Java compiler.- Parameters:
superFlag-trueif the modifier's super flag should be set.- Returns:
- The type's actual modifiers.
-
getSimpleName
java.lang.String getSimpleName()
Returns the simple internalName of this type.- Returns:
- The simple internalName of this type.
-
getCanonicalName
java.lang.String getCanonicalName()
Returns the canonical name of this type if it exists.- Returns:
- The canonical name of this type. Might be
null.
-
isAnonymousType
boolean isAnonymousType()
Checks if this type description represents an anonymous type.- Returns:
trueif this type description represents an anonymous type.
-
isLocalType
boolean isLocalType()
Checks if this type description represents a local type.- Returns:
trueif this type description represents a local type.
-
isMemberType
boolean isMemberType()
Checks if this type description represents a member type.- Returns:
trueif this type description represents a member type.
-
getPackage
PackageDescription getPackage()
Returns the package of the type described by this instance ornullif the described type does not imply a package.- Returns:
- The package of the type described by this instance or
nullif the described type does not imply a package.
-
getInheritedAnnotations
AnnotationList getInheritedAnnotations()
Returns the annotations that this type declares or inherits from super types.- Returns:
- A list of all inherited annotations.
-
isSamePackage
boolean isSamePackage(TypeDescription typeDescription)
Checks if two types are defined in the same package.- Parameters:
typeDescription- The type of interest.- Returns:
trueif this type and the given type are in the same package.
-
isPrimitiveWrapper
boolean isPrimitiveWrapper()
Checks if this type represents a wrapper type for a primitive type. TheVoidtype is not considered to be a wrapper type.- Returns:
trueif this type represents a wrapper type.
-
isAnnotationReturnType
boolean isAnnotationReturnType()
Checks if instances of this type can be returned from an annotation method.- Returns:
trueif instances of this type can be returned from an annotation method.
-
isAnnotationValue
boolean isAnnotationValue()
Checks if instances of this type can be used for describing an annotation value.- Returns:
trueif instances of this type can be used for describing an annotation value.
-
isAnnotationValue
boolean isAnnotationValue(java.lang.Object value)
Checks if instances of this type can be used for describing the given annotation value.- Parameters:
value- The value that is supposed to describe the annotation value for this instance.- Returns:
trueif instances of this type can be used for describing the given annotation value..
-
isPackageType
boolean isPackageType()
Checks if this type represents a class that is a place holder for a package description.- Returns:
trueif this type represents a package description.
-
getInnerClassCount
int getInnerClassCount()
Returns the amount of outer classes this type defines. If this type is not an inner type of another class,0is returned.- Returns:
- The number of outer classes relatively to this type.
-
isInnerClass
boolean isInnerClass()
Indicates if this class is an inner class.- Returns:
trueif this class is an inner class.
-
isNestedClass
boolean isNestedClass()
Indicates if this class is a nested class.- Returns:
trueif this class is a nested class.
-
asBoxed
TypeDescription asBoxed()
Returns a description of this type that represents this type as a boxed type for primitive types, unless itsvoid.- Returns:
- A description of this type in its boxed form.
-
asUnboxed
TypeDescription asUnboxed()
Returns a description of this type that represents this type as an unboxed type for boxing types, unless itsVoid.- Returns:
- A description of this type in its unboxed form.
-
getDefaultValue
java.lang.Object getDefaultValue()
Returns the default value for this type, i.e. the zero value for a primitive type andnullfor a reference type. Forvoid,nullis returned.- Returns:
- This types default value.
-
getNestHost
TypeDescription getNestHost()
Returns the nest host of this type. For types prior to Java 11, this type is returned which is the default nest host.- Returns:
- The nest host of this type.
-
getNestMembers
TypeList getNestMembers()
Returns a list of members that are part of a nesting group. Prior to Java 11, a list that only contains this type is returned which is the default nest group.- Returns:
- A list of members of this nest group.
-
isNestHost
boolean isNestHost()
Checks if this class is the host of a nest group.- Returns:
trueif this class is a nest group's host.
-
isNestMateOf
boolean isNestMateOf(java.lang.Class<?> type)
Checks if this type and the supplied type are members of the same nest group.- Parameters:
type- The type for which to check if it is a member of the same nest group.- Returns:
trueif this type and the supplied type are members of the same nest group.
-
isNestMateOf
boolean isNestMateOf(TypeDescription typeDescription)
Checks if this type and the supplied type are members of the same nest group.- Parameters:
typeDescription- The type for which to check if it is a member of the same nest group.- Returns:
trueif this type and the supplied type are members of the same nest group.
-
isCompileTimeConstant
boolean isCompileTimeConstant()
Indicates if this type represents a compile-time constant, i.e.int,long,float,double,String,Classorjava.lang.invoke.MethodHandleorjava.lang.invoke.MethodType.- Returns:
trueif this type represents a compile-time constant.
-
getPermittedSubclasses
TypeList getPermittedSubclasses()
Returns the list of permitted subclasses if this class is a sealed class or an empty list if this class is not sealed.- Returns:
- The list of permitted subclasses if this class is a sealed class or an empty list if this class is not sealed.
-
isSealed
boolean isSealed()
Returnstrueif this class is a sealed class that only permitts a specified range of subclasses.- Returns:
trueif this class is a sealed class that only permitts a specified range of subclasses.
-
-