All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.checkerframework.framework.qual.DefaultFor Maven / Gradle / Ivy

package org.checkerframework.framework.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;

/**
 * A meta-annotation applied to the declaration of a type qualifier. It specifies that the given
 * annotation should be the default for:
 *
 * 
    *
  • all uses at a particular location, *
  • all uses of a particular type, and *
  • all uses of a particular kind of type. *
* *

The default applies to every match for any of this annotation's conditions. * * @see TypeUseLocation * @see DefaultQualifier * @see DefaultQualifierInHierarchy */ @Documented @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.ANNOTATION_TYPE) public @interface DefaultFor { /** * Returns the locations to which the annotation should be applied. * * @return the locations to which the annotation should be applied */ TypeUseLocation[] value() default {}; /** * Returns {@link TypeKind}s of types for which an annotation should be implicitly added. * * @return {@link TypeKind}s of types for which an annotation should be implicitly added */ TypeKind[] typeKinds() default {}; /** * Returns {@link Class}es for which an annotation should be applied. For example, if * {@code @MyAnno} is meta-annotated with {@code @DefaultFor(classes=String.class)}, then every * occurrence of {@code String} is actually {@code @MyAnno String}. * *

Only the given types, not their subtypes, receive the default. For instance, if the {@code * types} element contains only {@code Iterable}, then the default does not apply to a variable * or expression of type {@code Collection} which is a subtype of {@code Iterable}. * * @return {@link Class}es for which an annotation should be applied */ Class[] types() default {}; /** * Returns regular expressions matching names of variables, to whose types the annotation should * be applied as a default. If a regular expression matches the name of a method, the annotation * is applied as a default to the return type. * *

The regular expression must match the entire variable or method name. For example, to * match any name that contains "foo", use ".*foo.*". * *

The default does not apply if the name matches any of the regexes in {@link * #namesExceptions}. * *

This affects formal parameter types only if one of the following is true: * *

    *
  • The method's source code is available; that is, the method is type-checked along with * client calls. *
  • When the method was compiled in a previous run of javac, either the processor was run * or the {@code -g} command-line option was provided. *
* * @return regular expressions matching variables to whose type an annotation should be applied */ String[] names() default {}; /** * Returns exceptions to regular expression rules. * * @return exceptions to regular expression rules * @see #names */ String[] namesExceptions() default {}; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy