org.jetbrains.annotations.ApiStatus Maven / Gradle / Ivy
/*
* Copyright 2000-2020 JetBrains s.r.o.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.jetbrains.annotations;
import java.lang.annotation.*;
/**
* Set of annotations which can be used to specify status of API Element.
*
* @since 18.0.0
*/
public final class ApiStatus {
/**
* Indicates that a public API of the annotated element (class, method or field) is not in stable state yet. It may be renamed, changed or
* even removed in a future version. This annotation refers to API status only, it doesn't mean that the implementation has
* an 'experimental' quality.
*
* It's safe to use an element marked with this annotation if the usage is located in the same sources codebase as the declaration. However,
* if the declaration belongs to an external library such usages may lead to problems when the library will be updated to another version.
*
* If a package is marked with this annotation, all its containing classes are considered experimental.
* Subpackages of this package are not affected and should be marked independently.
*
* If a type is marked with this annotation, all its members are considered experimental, but its inheritors are not.
*
* If a method is marked with this annotation, overriding methods are not considered experimental.
*/
@Documented
@Retention(RetentionPolicy.CLASS)
@Target({
ElementType.TYPE, ElementType.ANNOTATION_TYPE, ElementType.METHOD, ElementType.CONSTRUCTOR, ElementType.FIELD, ElementType.PACKAGE
})
public @interface Experimental {}
/**
* Indicates that the annotated element (class, method, field, etc) must not be considered as a public API. It's made visible to allow
* usages in other packages of the declaring library, but it must not be used outside of that library. Such elements
* may be renamed, changed or removed in future versions.
*
* If a package is marked with this annotation, all its containing classes are considered internal.
* Subpackages of this package are not affected and should be marked independently.
*
* If a type is marked with this annotation, all its members are considered internal, but its inheritors are not.
*
* If a method is marked with this annotation, overriding methods are not considered internal.
*/
@Documented
@Retention(RetentionPolicy.CLASS)
@Target({
ElementType.TYPE, ElementType.ANNOTATION_TYPE, ElementType.METHOD, ElementType.CONSTRUCTOR, ElementType.FIELD, ElementType.PACKAGE
})
public @interface Internal {}
/**
* Indicates that a public API of the annotated element (class, method or field) is subject to removal in a future version.
* It's a stronger variant of {@link Deprecated} annotation.
*
* Since many tools aren't aware of this annotation it should be used as an addition to {@code @Deprecated} annotation
* or {@code @deprecated} Javadoc tag only.
*/
@Documented
@Retention(RetentionPolicy.CLASS)
@Target({
ElementType.TYPE, ElementType.ANNOTATION_TYPE, ElementType.METHOD, ElementType.CONSTRUCTOR, ElementType.FIELD, ElementType.PACKAGE
})
public @interface ScheduledForRemoval {
/**
* Specifies in which version the API will be removed.
*/
String inVersion() default "";
}
/**
* Indicates that the annotated element firstly appeared in the specified version of the library, so the code using that element
* won't be compatible with older versions of the library. This information may be used by IDEs and static analysis tools.
* This annotation can be used instead of '@since' Javadoc tag if it's needed to keep that information in *.class files or if you need
* to generate them automatically.
*/
@Documented
@Retention(RetentionPolicy.CLASS)
@Target({
ElementType.TYPE, ElementType.ANNOTATION_TYPE, ElementType.METHOD, ElementType.CONSTRUCTOR, ElementType.FIELD, ElementType.PACKAGE
})
public @interface AvailableSince {
/**
* Specifies a version where the annotation API firstly appeared.
*/
String value();
}
/**
* Indicates that the annotated API class, interface or method must not be extended, implemented or overridden.
*
* API class, interface or method may not be marked {@code final} because it is extended by classes of the declaring library
* but it is not supposed to be extended outside the library. Instances of classes and interfaces marked with this annotation
* may be cast to an internal implementing class in the library code, leading to {@code ClassCastException}
* if a different implementation is provided by a client.
*
* New abstract methods may be added to such classes and interfaces in new versions of the library breaking compatibility
* with a client's implementations.
*/
@Documented
@Retention(RetentionPolicy.CLASS)
@Target({
ElementType.TYPE, ElementType.METHOD
})
public @interface NonExtendable { }
/**
* Indicates that the annotated method is part of SPI (Service Provider Interface), which is intended to be
* only implemented or overridden but not called by clients of the declaring library.
* If a class or interface is marked with this annotation it means that all its methods can be only overridden.
*
* Although there is a standard mechanism of {@code protected} methods, it is not applicable to interface's methods.
* Also, API method may be made {@code public} to allow calls only from different parts of the declaring library but not outside it.
*
* Signatures of such methods may be changed in new versions of the library in the following steps. Firstly, a method with new signature
* is added to the library delegating to the old method by default. Secondly, all clients implement the new method and remove
* implementations of the old one. This leads to compatibility breakage with code that calls the methods directly.
*/
@Documented
@Retention(RetentionPolicy.CLASS)
@Target({
ElementType.TYPE, ElementType.METHOD
})
public @interface OverrideOnly { }
}