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

org.checkerframework.checker.lock.qual.EnsuresLockHeldIf Maven / Gradle / Ivy

There is a newer version: 1.0.0
Show newest version
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
     */
    // It would be clearer for users if this field were named "lock".
    // However, method ContractUtils.getConditionalPostconditions in the CF implementation assumes
    // that conditional postconditions have a field named "expression".
    String[] expression();

    /** The return value of the method that needs to hold for the postcondition to hold. */
    boolean result();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy