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

org.kiwiproject.base.KiwiDeprecated Maven / Gradle / Ivy

Go to download

Kiwi is a utility library. We really like Google's Guava, and also use Apache Commons. But if they don't have something we need, and we think it is useful, this is where we put it.

There is a newer version: 4.5.2
Show newest version
package org.kiwiproject.base;

import static java.lang.annotation.ElementType.CONSTRUCTOR;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.LOCAL_VARIABLE;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.ElementType.MODULE;
import static java.lang.annotation.ElementType.PACKAGE;
import static java.lang.annotation.ElementType.PARAMETER;
import static java.lang.annotation.ElementType.TYPE;

import java.lang.annotation.Documented;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * A Kiwi-flavored version of {@link Deprecated} that includes the {@code since} attribute added in JDK 9 plus
 * additional attributes we think are useful.
 * 

* At the very least, users should populate the {@code since} and {@code removeAt} attributes. * * @implNote JDK 9 added a {@code forRemoval} attribute, but since this is intended for things we plan to remove, and * because we have the {@code removeAt} attribute, we omitted {@code forRemoval} as redundant. */ @Documented @Retention(RetentionPolicy.RUNTIME) @Target(value = {CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, MODULE, PARAMETER, TYPE}) public @interface KiwiDeprecated { /** * The version the annotated element became deprecated. * * @return the version when the annotated was deprecated */ String since() default ""; /** * The upcoming version at which the annotated element will be removed. * * @return the upcoming version when the annotated element will be removed */ String removeAt() default ""; /** * A description of what feature(s) replaces the one being deprecated, if any. *

* For example, a text description of a replacement REST endpoint such as: {@code GET /foo/bar/{id}} or the * name of one or more replacement methods. * * @return a description of the replacement, if any */ String[] replacedBy() default ""; /** * The issue number or another reference or descriptor which caused or is related to the deprecation, if any. *

* For example, one or more JIRA issue numbers. * * @return a reference to an issue, ticket, or another descriptor */ String[] reference() default ""; enum Severity { WARN, SEVERE } /** * Indication of potential for problems if the deprecated feature continues to be used by callers, clients, etc. * * @return the severity of continued usage */ Severity usageSeverity() default Severity.WARN; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy