blob: 61945114567dd666c5c8658f6bd795d3ddeeb1b2 [file] [log] [blame]
package org.checkerframework.common.aliasing.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.SubtypeOf;
/**
* An expression with this type has no aliases. In other words, no other expression, evaluated at
* the same program point, would evaluate to the exact same object value.
*
* <p>A constructor's return type should be annotated with {@code @Unique} if the constructor does
* not leak references to the constructed object. For example, the {@code String()} constructor
* return type is annotated as {@code @Unique}.
*
* @see MaybeAliased
* @checker_framework.manual #aliasing-checker Aliasing Checker
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE_USE, ElementType.TYPE_PARAMETER})
@SubtypeOf({MaybeAliased.class})
public @interface Unique {}