org.checkerframework.common.aliasing.qual.NonLeaked Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of checker-qual-android Show documentation
Show all versions of checker-qual-android Show documentation
checker-qual-android contains annotations (type qualifiers) that a programmer
writes to specify Java code for type-checking by the Checker Framework.
The checker-qual-android artifact is identical to the checker-qual
artifact, except that in checker-qual-android annotations have classfile
retention. The default Android Gradle plugin retains types annotated with
runtime annotations in the main dex, but strips out class-retention
annotations.
package org.checkerframework.common.aliasing.qual;
import org.checkerframework.framework.qual.SubtypeOf;
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;
/**
* This annotation is used on a formal parameter to indicate that the parameter is not leaked
* (stored in a location that could be accessed later) nor returned by the method body.
*
* For example, the parameter of {@link String#String(String s)} is {@code @NonLeaked}, because
* the method only uses the parameter to make a copy of it.
*
*
This annotation is currently trusted, not checked.
*
* @see LeakedToResult
* @checker_framework.manual #aliasing-checker Aliasing Checker
*/
// This is a type qualifier because of a Checker Framework limitation (Issue 383), but its hierarchy
// is ignored. Once the stub parser gets updated to read non-type-qualifiers annotations on stub
// files, this annotation won't be a type qualifier anymore.
@Documented
@Retention(RetentionPolicy.CLASS)
@Target({ElementType.TYPE_USE})
@SubtypeOf({})
public @interface NonLeaked {}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy