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

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

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

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

/**
 * A postcondition annotation to indicate that a method ensures certain expressions to have a
 * certain type qualifier once the method has successfully terminated. The expressions for which the
 * qualifier must hold after the method's execution are indicated by {@code expression} and are
 * specified using a string. The qualifier is specified by {@code qualifier}.
 *
 * 

Here is an example use: * *


 *  {@literal @}EnsuresQualifier(expression = "p.f1", qualifier = Odd.class)
 *   void oddF1_1() {
 *       p.f1 = null;
 *   }
 * 
* * Some type systems have specialized versions of this annotation, such as {@code * org.checkerframework.checker.nullness.qual.EnsuresNonNull} and {@code * org.checkerframework.checker.lock.qual.EnsuresLockHeld}. * * @see EnsuresQualifierIf * @checker_framework.manual #java-expressions-as-arguments Syntax of Java expressions */ @Documented @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.METHOD, ElementType.CONSTRUCTOR}) @InheritedAnnotation @Repeatable(EnsuresQualifiers.class) public @interface EnsuresQualifier { /** * The Java expressions for which the qualifier holds after successful method termination. * * @checker_framework.manual #java-expressions-as-arguments Syntax of Java expressions */ String[] expression(); /** The qualifier that is guaranteed to hold on successful termination of the method. */ Class qualifier(); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy