org.opentcs.util.annotations.ScheduledApiChange Maven / Gradle / Ivy
/**
* Copyright (c) The openTCS Authors.
*
* This program is free software and subject to the MIT license. (For details,
* see the licensing information (LICENSE.txt) you should have received with
* this copy of the software.)
*/
package org.opentcs.util.annotations;
import static java.lang.annotation.ElementType.CONSTRUCTOR;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.ElementType.TYPE;
import java.lang.annotation.Documented;
import java.lang.annotation.Repeatable;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
* Marks an API detail (class, method, field) that is scheduled for an incompatible change.
*
* This annotation should not be used outside the source code of the openTCS project itself. It
* should not be considered part of the public API.
*
*
* This annotation is intended to be used as a supplement for @Deprecated for two purposes:
*
*
* - For users of the openTCS API to gain knowledge about upcoming changes.
* - For openTCS developers to easily find pending changes during pre-release cleanups.
*
*/
@Target({CONSTRUCTOR, FIELD, METHOD, TYPE})
@Retention(RetentionPolicy.SOURCE)
@Documented
@Repeatable(ScheduledApiChanges.class)
public @interface ScheduledApiChange {
/**
* Returns the date or version at which the API is scheduled to be changed.
*
* @return The date or version at which the API is scheduled to be changed.
*/
String when();
/**
* Returns optional details about the scheduled change.
*
* @return Optional details about the scheduled change.
*/
String details() default "";
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy