Class MethodParameterInfo
- All Implemented Interfaces:
AnnotationTarget,Declaration
Thread-Safety
This class is immutable and can be shared between threads without safe publication.- Author:
- Jason T. Greene
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.jboss.jandex.AnnotationTarget
AnnotationTarget.Kind -
Method Summary
Modifier and TypeMethodDescriptionannotation(DotName name) Returns the annotation instance with given name declared on this method parameter or any type within its signature.Returns the annotation instances declared on this method parameter or any type within its signature.annotations(DotName name) Returns the annotation instances with given name declared on this method parameter or any type within its signature.annotationsWithRepeatable(DotName name, IndexView index) Returns the annotation instances with given name declared on this method parameter or any type within its signature.final ClassInfoasClass()Casts and returns this target as aClassInfoif it is of kindCLASSfinal FieldInfoasField()Casts and returns this target as aFieldInfoif it is of kindFIELDfinal MethodInfoasMethod()Casts and returns this target as aMethodInfoif it is of kindMETHODfinal MethodParameterInfoCasts and returns this target as aMethodParameterInfoif it is of kindMETHOD_PARAMETERfinal RecordComponentInfoCasts and returns this target as aRecordComponentInfoif it is of kindRECORD_COMPONENTfinal TypeTargetasType()Casts and returns this target as aTypeTargetif it is of kindTYPEstatic MethodParameterInfocreate(MethodInfo method, short parameter) Constructs a new mock method parameter infodeclaredAnnotation(DotName name) Returns the annotation instance with given name declared on this method parameter.Returns the annotation instances declared on this method parameter.declaredAnnotationsWithRepeatable(DotName name, IndexView index) Returns the annotation instances with given name declared on this method parameter.booleanbooleanhasAnnotation(DotName name) Returns whether an annotation instance with given name is declared on this method parameter or any type within its signature.booleanhasDeclaredAnnotation(DotName name) Returns whether an annotation instance with given name is declared on this method parameter.inthashCode()kind()Returns the kind of object this target represents.final MethodInfomethod()Returns the method this parameter belongs to.final Stringname()Returns the name of this parameter, ornullif not known.final shortposition()Returns the 0 based position of this parameter.toString()Returns a string representation describing this method parameter.final Typetype()Returns the type of this parameter.Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface org.jboss.jandex.AnnotationTarget
annotation, annotation, annotations, annotations, annotationsWithRepeatable, annotationsWithRepeatable, declaredAnnotation, declaredAnnotation, declaredAnnotationsWithRepeatable, declaredAnnotationsWithRepeatable, hasAnnotation, hasAnnotation, hasDeclaredAnnotation, hasDeclaredAnnotationMethods inherited from interface org.jboss.jandex.Declaration
asDeclaration, isDeclaration
-
Method Details
-
create
Constructs a new mock method parameter info- Parameters:
method- the method containing this parameter.parameter- the zero based index of this parameter- Returns:
- the new mock parameter info
-
method
Returns the method this parameter belongs to.- Returns:
- the declaring Java method
-
position
public final short position()Returns the 0 based position of this parameter.- Returns:
- the position of this parameter
-
name
Returns the name of this parameter, ornullif not known.- Returns:
- the name of this parameter, or
nullif not known
-
type
Returns the type of this parameter.- Returns:
- the type of this parameter
- Since:
- 3.0
-
hasAnnotation
Returns whether an annotation instance with given name is declared on this method parameter or any type within its signature.- Specified by:
hasAnnotationin interfaceAnnotationTarget- Parameters:
name- name of the annotation type to look for, must not benull- Returns:
trueif the annotation is present,falseotherwise- Since:
- 3.0
- See Also:
-
annotation
Returns the annotation instance with given name declared on this method parameter or any type within its signature. Thetarget()method of the returned annotation instance may be used to determine the exact location of the annotation instance.In case an annotation with given name occurs more than once, the result of this method is not deterministic. For such situations,
annotations(DotName)is preferable.- Specified by:
annotationin interfaceAnnotationTarget- Parameters:
name- name of the annotation type to look for, must not benull- Returns:
- the annotation instance, or
nullif not found - Since:
- 3.0
- See Also:
-
annotations
Returns the annotation instances with given name declared on this method parameter or any type within its signature. Thetarget()method of the returned annotation instances may be used to determine the exact location of the respective annotation instance.- Specified by:
annotationsin interfaceAnnotationTarget- Parameters:
name- name of the annotation type, must not benull- Returns:
- immutable list of annotation instances, never
null - Since:
- 3.0
- See Also:
-
annotationsWithRepeatable
Returns the annotation instances with given name declared on this method parameter or any type within its signature. Thetarget()method of the returned annotation instances may be used to determine the exact location of the respective annotation instance.If the specified annotation is repeatable, the result also contains all values from the container annotation instance. In this case, the
AnnotationInstance.target()returns the target of the container annotation instance.- Specified by:
annotationsWithRepeatablein interfaceAnnotationTarget- Parameters:
name- name of the annotation type, must not benullindex- index used to obtain the annotation type, must not benull- Returns:
- immutable list of annotation instances, never
null - Throws:
IllegalArgumentException- if the index isnull, if the index does not contain the annotation type or ifnamedoes not identify an annotation type- Since:
- 3.0
- See Also:
-
annotations
Returns the annotation instances declared on this method parameter or any type within its signature. Thetarget()method of the returned annotation instances may be used to determine the exact location of the respective annotation instance.- Specified by:
annotationsin interfaceAnnotationTarget- Returns:
- immutable list of annotation instances, never
null - Since:
- 3.0
-
hasDeclaredAnnotation
Returns whether an annotation instance with given name is declared on this method parameter.Unlike
hasAnnotation(DotName), this method ignores annotations declared on types within the methor parameter signature.- Specified by:
hasDeclaredAnnotationin interfaceAnnotationTarget- Parameters:
name- name of the annotation type to look for, must not benull- Returns:
trueif the annotation is present,falseotherwise- Since:
- 3.0
- See Also:
-
declaredAnnotation
Returns the annotation instance with given name declared on this method parameter.Unlike
annotation(DotName), this method doesn't return annotations declared on types within the methor parameter signature.- Specified by:
declaredAnnotationin interfaceAnnotationTarget- Parameters:
name- name of the annotation type to look for, must not benull- Returns:
- the annotation instance, or
nullif not found - Since:
- 3.0
- See Also:
-
declaredAnnotationsWithRepeatable
Returns the annotation instances with given name declared on this method parameter.If the specified annotation is repeatable, the result also contains all values from the container annotation instance. In this case, the
AnnotationInstance.target()returns the target of the container annotation instance.Unlike
annotationsWithRepeatable(DotName, IndexView), this method doesn't return annotations declared on types within the methor parameter signature.- Specified by:
declaredAnnotationsWithRepeatablein interfaceAnnotationTarget- Parameters:
name- name of the annotation type, must not benullindex- index used to obtain the annotation type, must not benull- Returns:
- immutable list of annotation instances, never
null - Throws:
IllegalArgumentException- if the index isnull, if the index does not contain the annotation type or ifnamedoes not identify an annotation type- Since:
- 3.0
- See Also:
-
declaredAnnotations
Returns the annotation instances declared on this method parameter.Unlike
annotations(), this method doesn't return annotations declared on types within the methor parameter signature.- Specified by:
declaredAnnotationsin interfaceAnnotationTarget- Returns:
- immutable list of annotation instances, never
null - Since:
- 3.0
- See Also:
-
toString
Returns a string representation describing this method parameter. It is similar although not necessarily identical to a Java source code declaration of this method parameter. -
asClass
Description copied from interface:AnnotationTargetCasts and returns this target as aClassInfoif it is of kindCLASS- Specified by:
asClassin interfaceAnnotationTarget- Returns:
- this instance cast to a class
-
asField
Description copied from interface:AnnotationTargetCasts and returns this target as aFieldInfoif it is of kindFIELD- Specified by:
asFieldin interfaceAnnotationTarget- Returns:
- this instance cast to a field
-
asMethod
Description copied from interface:AnnotationTargetCasts and returns this target as aMethodInfoif it is of kindMETHOD- Specified by:
asMethodin interfaceAnnotationTarget- Returns:
- this instance cast to a method
-
asMethodParameter
Description copied from interface:AnnotationTargetCasts and returns this target as aMethodParameterInfoif it is of kindMETHOD_PARAMETER- Specified by:
asMethodParameterin interfaceAnnotationTarget- Returns:
- this instance cast to a method parameter
-
asType
Description copied from interface:AnnotationTargetCasts and returns this target as aTypeTargetif it is of kindTYPE- Specified by:
asTypein interfaceAnnotationTarget- Returns:
- this instance cast to a type target
-
asRecordComponent
Description copied from interface:AnnotationTargetCasts and returns this target as aRecordComponentInfoif it is of kindRECORD_COMPONENT- Specified by:
asRecordComponentin interfaceAnnotationTarget- Returns:
- this instance cast to a record component
-
kind
Description copied from interface:AnnotationTargetReturns the kind of object this target represents.- Specified by:
kindin interfaceAnnotationTarget- Returns:
- the target kind.
-
hashCode
public int hashCode() -
equals
-