package org.checkerframework.checker.index.qual; 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.JavaExpression; import org.checkerframework.framework.qual.SubtypeOf; /** * The annotated expression evaluates to an integer whose length is between {@code -a.length - 1} * and {@code a.length - 1}, inclusive, for all sequences {@code a} listed in the annotation. * * <p>This is the return type of {@link java.util.Arrays#binarySearch(Object[],Object) {@code * Arrays.binarySearch}} in the JDK. * * @checker_framework.manual #index-checker Index Checker */ @SubtypeOf(SearchIndexUnknown.class) @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.TYPE_USE, ElementType.TYPE_PARAMETER}) public @interface SearchIndexFor { /** * Sequences for which the annotated expression has the type of the result of a call to {@link * java.util.Arrays#binarySearch(Object[],Object) {@code Arrays.binarySearch}}. */ @JavaExpression public String[] value(); }