blob: cac3fc896f1067228e61c00e685fc1e0a7998496 [file] [log] [blame]
package org.checkerframework.checker.initialization.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.checker.nullness.qual.NonNull;
import org.checkerframework.framework.qual.DefaultFor;
import org.checkerframework.framework.qual.DefaultQualifierInHierarchy;
import org.checkerframework.framework.qual.SubtypeOf;
import org.checkerframework.framework.qual.TypeUseLocation;
/**
* This type qualifier belongs to the freedom-before-commitment initialization tracking type-system.
* This type-system is not used on its own, but in conjunction with some other type-system that
* wants to ensure safe initialization. For instance, {@link
* org.checkerframework.checker.nullness.NullnessChecker} uses freedom-before-commitment to track
* initialization of {@link NonNull} fields.
*
* <p>This type qualifier indicates that the object has been fully initialized; reading fields from
* such objects is fully safe and yields objects of the correct type.
*
* @checker_framework.manual #initialization-checker Initialization Checker
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE_USE, ElementType.TYPE_PARAMETER})
@SubtypeOf(UnknownInitialization.class)
@DefaultQualifierInHierarchy
@DefaultFor({
TypeUseLocation.IMPLICIT_UPPER_BOUND,
TypeUseLocation.IMPLICIT_LOWER_BOUND,
TypeUseLocation.EXCEPTION_PARAMETER
})
public @interface Initialized {}