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

org.checkerframework.checker.optional.qual.EnsuresPresent Maven / Gradle / Ivy

There is a newer version: 4.1.4
Show newest version
package org.checkerframework.checker.optional.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.InheritedAnnotation;
import org.checkerframework.framework.qual.PostconditionAnnotation;

/**
 * Indicates that the expression evaluates to a non-empty Optional, if the method terminates
 * successfully.
 *
 * 

This postcondition annotation is useful for methods that construct a non-empty Optional: * *


 *   {@literal @}EnsuresPresent("optStr")
 *   void initialize() {
 *     optStr = Optional.of("abc");
 *   }
 * 
* * It can also be used for a method that fails if a given Optional value is empty, indicating that * the argument is null if the method returns normally: * *

 *   /** Throws an exception if the argument is empty. */
 *   {@literal @}EnsuresPresent("#1")
 *   void useTheOptional(Optional<T> arg) { ... }
 * 
* * @see Present * @see org.checkerframework.checker.optional.OptionalChecker * @checker_framework.manual #optional-checker Optional Checker */ @Documented @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.METHOD, ElementType.CONSTRUCTOR}) @PostconditionAnnotation(qualifier = Present.class) @InheritedAnnotation public @interface EnsuresPresent { /** * The expression (of Optional type) that is present, if the method returns normally. * * @return the expression (of Optional type) that is present, if the method returns normally */ String[] value(); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy