checker.src.org.checkerframework.checker.lock.qual.EnsuresLockHeldIf Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of checker Show documentation
Show all versions of checker Show documentation
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.
package org.checkerframework.checker.lock.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;
import org.checkerframework.framework.qual.ConditionalPostconditionAnnotation;
import org.checkerframework.framework.qual.InheritedAnnotation;
/**
* Indicates that the given expressions are held
* if the method terminates successfully and returns the given result (either true or false).
*
*
* @see EnsuresLockHeld
* @checker_framework.manual #lock-checker Lock Checker
* @checker_framework.manual #ensureslockheld-examples Example use of @EnsuresLockHeldIf
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ ElementType.METHOD, ElementType.CONSTRUCTOR })
@ConditionalPostconditionAnnotation(qualifier = LockHeld.class)
@InheritedAnnotation
public @interface EnsuresLockHeldIf {
/**
* Java expressions whose values are held after the method returns the
* given result.
* @see Syntax of Java expressions
*/
String[] expression();
/**
* The return value of the method that needs to hold for the postcondition
* to hold.
*/
boolean result();
}