API Life Cycle and Deprecation Policy (original) (raw)

API Life Cycle#

name

Each API of ExecuTorch falls into one of the following life cycle states:

Experimental

Stable

Deprecated

Deleted

Deprecation Policy#

Follow these steps to deprecate and remove an API:

  1. Discuss the change and collect initial feedback.
  2. Clearly mark the API deprecated in code and documentation (See “How to Mark API State” below).
  3. Listen to user feedback after the first release that deprecates the API. Users who weren’t involved in the original discussion may have good arguments for not deprecating or removing the API.
  4. Once the deprecation period has passed, the API may be removed (See “Deprecation Period” below). Be sure to also remove references from the documentation.

We also use deprecation as a way to make breaking changes to an existing interface: for example, if adding a non-optional parameter to a method. To do this without breaking existing users:

  1. In a single commit:
    • Create a new API that meets the new requirements.
    • Deprecate the old API and recommend that users move to the new API.
  2. Migrate use cases from the old API to the new API.
  3. Delete the old API after the deprecation period.

How to Mark API State#

When possible, the ExecuTorch code uses language-standard ways to annotate API lifecycle state in the code. This makes it easier for IDEs and other tools to communicate state to developers.

Language Code Documentation
Python Use theexecutorch.exir._warnings.deprecateddecorator. Use theexecutorch.exir._warnings.experimentaldecorator. Use .. warning:: in the docstrings of deprecated and experimental APIs. Seeexample usage.
C++ Use the ET_DEPRECATED annotation macro. See example usage. Use the ET_EXPERIMENTAL annotation macro. Start Doxygen comments with DEPRECATED: Seeexample usage. Start Doxygen comments with EXPERIMENTAL:.
Java Use java.lang.Deprecated. Use androidx.annotation.RequiresOptIn. /** * @deprecated Use {@link #newMethod()} instead. */ /** * Warning: This API is experimental. */
Objective-C __attribute__((deprecated("Use newMethod instead"))); __attribute__((deprecated("This API is experimental and may change without notice."))); /** * @deprecated Use `newMethod` instead. */ /** * @experimental This API is experimental. */
Swift @available(*, deprecated, message: "Use newMethod instead") @available(*, message: "This API is experimental") /// - Warning: Deprecated. Use `newMethod()` instead. /// - Warning: This API is experimental.

The annotations would trigger static and/or runtime warning that contains at least these information:

  1. Clearly point to the non-deprecated alternative to migrate to, or be clear if there is no alternative;
  2. Specify the earliest version in which the API may actually be removed (See “Deprecation Period” below).

Deprecation Period#

Here we recommend waiting for at least 2 minor releases before the removal. For example, if a function is marked as deprecated in release 1.3.x, then it can be deleted in 1.5.x or later.