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

org.apache.pekko.annotation.ApiMayChange Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * license agreements; and to You under the Apache License, version 2.0:
 *
 *   https://www.apache.org/licenses/LICENSE-2.0
 *
 * This file is part of the Apache Pekko project, which was derived from Akka.
 */

/*
 * Copyright (C) 2017-2022 Lightbend Inc. 
 */

package org.apache.pekko.annotation;

import java.lang.annotation.*;

/**
 * Marks APIs that are meant to evolve towards becoming stable APIs, but are not stable APIs yet.
 *
 * 

Evolving interfaces MAY change from one patch release to another (i.e. 2.4.10 to 2.4.11) * without up-front notice. A best-effort approach is taken to not cause more breakage than really * necessary, and usual deprecation techniques are utilised while evolving these APIs, however there * is NO strong guarantee regarding the source or binary compatibility of APIs marked using this * annotation. * *

It MAY also change when promoting the API to stable, for example such changes may include * removal of deprecated methods that were introduced during the evolution and final refactoring * that were deferred because they would have introduced to much breaking changes during the * evolution phase. * *

Promoting the API to stable MAY happen in a patch release. * *

It is encouraged to document in ScalaDoc how exactly this API is expected to evolve. */ @Documented @Retention(RetentionPolicy.CLASS) // to be accessible by MiMa @Target({ ElementType.METHOD, ElementType.CONSTRUCTOR, ElementType.FIELD, ElementType.TYPE, ElementType.PACKAGE }) public @interface ApiMayChange { /** Reference to issue discussing the future evolvement of this API */ String issue() default ""; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy