@Documented
@Retention(value=RUNTIME)
@Target(value=ANNOTATION_TYPE)
public @interface TargetLocations
@Target({ElementType.TYPE_USE})
, the given type qualifier may
be written only at locations listed in the @TargetLocations(...)
meta-annotation.
@Target({ElementType.TYPE_USE})
together with no @TargetLocations(...)
means that
the qualifier can be written on any type use.
This enables a type system designer to permit a qualifier to be written only in certain
locations. For example, some type systems' top and bottom qualifier (such as KeyForBottom
) should only be written on an explicit
wildcard upper or lower bound. This meta-annotation is a declarative, coarse-grained approach to
enable that. A org.checkerframework.common.basetype.TypeValidator
must be implemented if
finer-grained control is necessary.
Modifier and Type | Required Element and Description |
---|---|
TypeUseLocation[] |
value
Type uses at which the qualifier is permitted to be written in source code.
|
public abstract TypeUseLocation[] value