Module rustc_passes::stability
source · Expand description
A pass that annotates every item and method with its stability level, propagating default levels lexically from parent to children ast nodes.
Structs
- A private tree-walker for producing an
Index
. - Checker 🔒
Enums
- Whether to inherit const stability flags for nested items. In most cases, we do not want to inherit const stability: just because an enclosing
fn
is const-stable does not mean allextern
imports declared in it should be const-stable! However, trait methods inherit const stability attributes from their parent and do not have their own. - Whether to inherit deprecation flags for nested items. In most cases, we do want to inherit deprecation, because nested items rarely have individual deprecation attributes, and so should be treated as deprecated if their parent is. However, default generic parameters have separate deprecation attributes from their parents, so we do not wish to inherit deprecation in this case. For example, inheriting deprecation for
T
inFoo<T>
would cause a duplicate warning arising from bothFoo
andT
being deprecated.
Functions
- Cross-references the feature names of unstable APIs with enabled features and possibly prints errors.
- Given the list of enabled features that were not language features (i.e., that were expected to be library features), and the list of features used from libraries, identify activated features that don’t exist and error about them.
- Check whether a path is a
use
item that has been marked as unstable. - provide 🔒