org.checkerframework.framework.qual.Unused Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of guava Show documentation
Show all versions of guava Show documentation
Guava is a suite of core and expanded libraries that include
utility classes, google's collections, io classes, and much
much more.
package org.checkerframework.framework.qual;
import java.lang.annotation.Annotation;
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;
/**
* Declares that the field may not be accessed if the receiver is of the specified qualifier type
* (or any supertype).
*
* This property is verified by the checker that type-checks the {@code when} element value
* qualifier.
*
*
Example Consider a class, {@code Table}, with a locking field, {@code lock}. The lock
* is used when a {@code Table} instance is shared across threads. When running in a local thread,
* the {@code lock} field ought not to be used.
*
*
You can declare this behavior in the following way:
*
*
{@code
* class Table {
* private @Unused(when=LocalToThread.class) final Lock lock;
* ...
* }
* }
*
* The checker for {@code @LocalToThread} would issue an error for the following code:
*
* @LocalToThread Table table = ...;
* ... table.lock ...;
*
*
* @checker_framework.manual #unused-fields Unused fields
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD})
public @interface Unused {
/**
* The field that is annotated with @Unused may not be accessed via a receiver that is annotated
* with the "when" annotation.
*/
Class extends Annotation> when();
}