All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.checkerframework.framework.qual.UpperBoundFor Maven / Gradle / Ivy

Go to download

checker-qual-android contains annotations (type qualifiers) that a programmer writes to specify Java code for type-checking by the Checker Framework. The checker-qual-android artifact is identical to the checker-qual artifact, except that in checker-qual-android annotations have classfile retention. The default Android Gradle plugin retains types annotated with runtime annotations in the main dex, but strips out class-retention annotations.

There is a newer version: 3.42.0-eisop5
Show newest version
package org.checkerframework.framework.qual;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * A meta-annotation applied to the declaration of a type qualifier. It specifies that the
 * annotation should be the upper bound for
 *
 * 
    *
  • all uses of a particular type, and *
  • all uses of a particular kind of type. *
* * An example is the declaration * *

 * {@literal @}DefaultFor(classes=String.class)
 * {@literal @}interface MyAnno {}
 * 
* *

The upper bound applies to every occurrence of the given classes and also to every occurrence * of the given type kinds. * * @checker_framework.manual #upper-bound-for-use Upper bound of qualifiers on uses of a given type */ @Documented @Retention(RetentionPolicy.CLASS) @Target(ElementType.ANNOTATION_TYPE) public @interface UpperBoundFor { /** * Returns {@link TypeKind}s of types that get an upper bound. The meta-annotated annotation is * the upper bound. * * @return {@link TypeKind}s of types that get an upper bound */ TypeKind[] typeKinds() default {}; /** * Returns {@link Class}es that should get an upper bound. The meta-annotated annotation is the * upper bound. * * @return {@link Class}es that get an upper bound */ Class[] types() default {}; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy