blob: 6a89836561b6bb747527efc1333aaf28e0f96026 [file] [log] [blame]
package org.checkerframework.checker.nullness.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.PolymorphicQualifier;
/**
* A polymorphic qualifier for the Map Key (@KeyFor) type system.
*
* <p>Any method written using {@code @PolyKeyFor} conceptually has an arbitrary number of versions:
* one in which every instance of {@code @PolyKeyFor} has been replaced by {@code @}{@link
* UnknownKeyFor}, one in which every instance of {@code @}{@link PolyKeyFor} has been replaced by
* {@code @}{@link KeyForBottom}, and ones in which every instance of {@code @PolyKeyFor} has been
* replaced by {@code @}{@code KeyFor}, for every possible combination of map arguments.
*
* @checker_framework.manual #nullness-checker Nullness Checker
* @checker_framework.manual #qualifier-polymorphism Qualifier polymorphism
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE_USE, ElementType.TYPE_PARAMETER})
@PolymorphicQualifier(UnknownKeyFor.class)
public @interface PolyKeyFor {}