Instability
Rust API stability attributes for the rest of us.
Overview
This crate provides attribute macros for specifying API stability of public API items of a crate. It is a fork of the Stability original created by Stephen M. Coakley (@sagebind).
Usage
Add the instability
crate to your Cargo.toml
file:
cargo add instability
Then, use the #[instability::stable]
and #[instability::unstable]
attributes to specify the
stability of your API items:
/// This function does something really risky!
/// This function is safe to use!
A feature flag prefixed with "unstable-" will be created that can be used to enable unstable items.
The macro will append an extra documentation comment that describes the stability of the item. The
visibility of the item will be changed to pub(crate)
when the feature is not enabled (or when the
attribute is on an impl block, the entire block will be removed).
Check out the Docs for detailed usage. See instability-example for a complete example.
MSRV
The minimum supported Rust version (MSRV) is 1.64.0.
License
This project's source code and documentation are licensed under the MIT License.