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

framework.src.org.checkerframework.framework.qual.Unused Maven / Gradle / Ivy

Go to download

The Checker Framework enhances Java’s type system to make it more powerful and useful. This lets software developers detect and prevent errors in their Java programs. The Checker Framework includes compiler plug-ins ("checkers") that find bugs or verify their absence. It also permits you to write your own compiler plug-ins.

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

import static java.lang.annotation.ElementType.*;

import java.lang.annotation.*;

/**
 * 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: * *


 * 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 ...;
 * 
* */ @Documented @Retention(RetentionPolicy.RUNTIME) @Target({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 when(); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy