blob: 1965d76339c04187c91bb9b2691cff3e732942b1 [file] [log] [blame]
package org.checkerframework.checker.index.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;
/**
* An integer that is either -1 or is a valid index for each of the given sequences.
*
* <p>The <a
* href="https://docs.oracle.com/en/java/javase/11/docs/api/java.base/java/lang/String.html#indexOf(java.lang.String)">
* {@code String.indexOf(String)}</a> method is declared as
*
* <pre><code>
* class String {
* {@literal @}IndexOrLow("this") int indexOf(String str) { ... }
* }
* </code></pre>
*
* <p>Writing {@code @IndexOrLow("arr")} is equivalent to writing {@link
* GTENegativeOne @GTENegativeOne} {@link LTLengthOf @LTLengthOf("arr")}, and that is how it is
* treated internally by the checker. Thus, if you write an {@code @IndexOrLow("arr")} annotation,
* you might see warnings about {@code @GTENegativeOne} or {@code @LTLengthOf}.
*
* @see GTENegativeOne
* @see LTLengthOf
* @checker_framework.manual #index-checker Index Checker
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE_USE, ElementType.TYPE_PARAMETER})
public @interface IndexOrLow {
/** Sequences that the annotated expression is a valid index for (or it's -1). */
String[] value();
}