2013-08-31 17:13:57 +10:00
|
|
|
// aux-build:lint_stability.rs
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
// aux-build:inherited_stability.rs
|
2014-11-04 14:59:42 -08:00
|
|
|
// aux-build:stability_cfg1.rs
|
2019-03-12 00:49:17 +00:00
|
|
|
// aux-build:stability-cfg2.rs
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
#![allow(deprecated)]
|
2014-03-21 18:05:05 -07:00
|
|
|
#![allow(dead_code)]
|
2015-01-21 18:21:14 -08:00
|
|
|
#![feature(staged_api)]
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2015-11-16 19:54:28 +03:00
|
|
|
#![stable(feature = "rust1", since = "1.0.0")]
|
|
|
|
|
2015-01-02 22:21:28 -08:00
|
|
|
#[macro_use]
|
2015-02-04 03:20:12 +05:30
|
|
|
extern crate lint_stability;
|
2015-01-02 22:21:28 -08:00
|
|
|
|
2013-08-31 17:13:57 +10:00
|
|
|
mod cross_crate {
|
2014-11-04 14:59:42 -08:00
|
|
|
extern crate stability_cfg1;
|
2015-03-05 18:33:58 -08:00
|
|
|
extern crate stability_cfg2; //~ ERROR use of unstable library feature
|
2014-11-04 14:59:42 -08:00
|
|
|
|
2015-01-02 22:21:28 -08:00
|
|
|
use lint_stability::*;
|
2013-08-31 17:13:57 +10:00
|
|
|
|
|
|
|
fn test() {
|
2015-02-19 22:28:20 +02:00
|
|
|
type Foo = MethodTester;
|
2013-08-31 17:13:57 +10:00
|
|
|
let foo = MethodTester;
|
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
deprecated();
|
|
|
|
foo.method_deprecated();
|
|
|
|
Foo::method_deprecated(&foo);
|
|
|
|
<Foo>::method_deprecated(&foo);
|
|
|
|
foo.trait_deprecated();
|
|
|
|
Trait::trait_deprecated(&foo);
|
|
|
|
<Foo>::trait_deprecated(&foo);
|
|
|
|
<Foo as Trait>::trait_deprecated(&foo);
|
|
|
|
|
|
|
|
deprecated_text();
|
|
|
|
foo.method_deprecated_text();
|
|
|
|
Foo::method_deprecated_text(&foo);
|
|
|
|
<Foo>::method_deprecated_text(&foo);
|
|
|
|
foo.trait_deprecated_text();
|
|
|
|
Trait::trait_deprecated_text(&foo);
|
|
|
|
<Foo>::trait_deprecated_text(&foo);
|
|
|
|
<Foo as Trait>::trait_deprecated_text(&foo);
|
|
|
|
|
2018-06-21 14:37:35 +01:00
|
|
|
deprecated_future(); // Fine; no error.
|
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
deprecated_unstable();
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
2016-11-10 19:08:21 +02:00
|
|
|
Trait::trait_deprecated_unstable(&foo);
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
2016-11-10 19:08:21 +02:00
|
|
|
<Foo as Trait>::trait_deprecated_unstable(&foo);
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
2015-01-22 12:33:46 -08:00
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
deprecated_unstable_text();
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
2016-11-10 19:08:21 +02:00
|
|
|
Trait::trait_deprecated_unstable_text(&foo);
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
2016-11-10 19:08:21 +02:00
|
|
|
<Foo as Trait>::trait_deprecated_unstable_text(&foo);
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
2015-01-22 12:33:46 -08:00
|
|
|
|
2015-03-05 18:33:58 -08:00
|
|
|
unstable(); //~ ERROR use of unstable library feature
|
|
|
|
Trait::trait_unstable(&foo); //~ ERROR use of unstable library feature
|
|
|
|
<Foo as Trait>::trait_unstable(&foo); //~ ERROR use of unstable library feature
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2015-02-19 22:28:20 +02:00
|
|
|
unstable_text();
|
2018-07-23 12:22:23 +01:00
|
|
|
//~^ ERROR use of unstable library feature 'unstable_test_feature': text
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_unstable_text(&foo);
|
2018-07-23 12:22:23 +01:00
|
|
|
//~^ ERROR use of unstable library feature 'unstable_test_feature': text
|
2015-02-19 22:28:20 +02:00
|
|
|
<Foo as Trait>::trait_unstable_text(&foo);
|
2018-07-23 12:22:23 +01:00
|
|
|
//~^ ERROR use of unstable library feature 'unstable_test_feature': text
|
2013-08-31 17:13:57 +10:00
|
|
|
|
|
|
|
stable();
|
|
|
|
foo.method_stable();
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_stable(&foo);
|
|
|
|
<Foo>::method_stable(&foo);
|
2013-08-31 17:13:57 +10:00
|
|
|
foo.trait_stable();
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_stable(&foo);
|
|
|
|
<Foo>::trait_stable(&foo);
|
|
|
|
<Foo as Trait>::trait_stable(&foo);
|
2013-08-31 17:13:57 +10:00
|
|
|
|
|
|
|
stable_text();
|
|
|
|
foo.method_stable_text();
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_stable_text(&foo);
|
|
|
|
<Foo>::method_stable_text(&foo);
|
2013-08-31 17:13:57 +10:00
|
|
|
foo.trait_stable_text();
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_stable_text(&foo);
|
|
|
|
<Foo>::trait_stable_text(&foo);
|
|
|
|
<Foo as Trait>::trait_stable_text(&foo);
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2016-06-11 18:47:47 +03:00
|
|
|
struct S1<T: TraitWithAssociatedTypes>(T::TypeUnstable);
|
|
|
|
//~^ ERROR use of unstable library feature
|
|
|
|
struct S2<T: TraitWithAssociatedTypes>(T::TypeDeprecated);
|
2019-05-28 14:46:13 -04:00
|
|
|
type A = dyn TraitWithAssociatedTypes<
|
2017-11-18 18:38:56 +03:00
|
|
|
TypeUnstable = u8, //~ ERROR use of unstable library feature
|
|
|
|
TypeDeprecated = u16,
|
|
|
|
>;
|
2016-06-11 18:47:47 +03:00
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
let _ = DeprecatedStruct {
|
|
|
|
i: 0
|
2015-11-16 19:54:28 +03:00
|
|
|
};
|
2015-06-06 17:14:46 -07:00
|
|
|
let _ = DeprecatedUnstableStruct {
|
2016-11-10 19:08:21 +02:00
|
|
|
//~^ ERROR use of unstable library feature
|
|
|
|
i: 0
|
2015-06-06 17:14:46 -07:00
|
|
|
};
|
2015-03-05 18:33:58 -08:00
|
|
|
let _ = UnstableStruct { i: 0 }; //~ ERROR use of unstable library feature
|
2013-08-31 17:13:57 +10:00
|
|
|
let _ = StableStruct { i: 0 };
|
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
let _ = DeprecatedUnitStruct;
|
|
|
|
let _ = DeprecatedUnstableUnitStruct;
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
|
|
|
let _ = UnstableUnitStruct; //~ ERROR use of unstable library feature
|
2013-08-31 17:13:57 +10:00
|
|
|
let _ = StableUnitStruct;
|
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
let _ = Enum::DeprecatedVariant;
|
|
|
|
let _ = Enum::DeprecatedUnstableVariant;
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
|
|
|
let _ = Enum::UnstableVariant; //~ ERROR use of unstable library feature
|
2014-11-06 00:05:53 -08:00
|
|
|
let _ = Enum::StableVariant;
|
2014-01-30 23:36:05 +11:00
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
let _ = DeprecatedTupleStruct (1);
|
|
|
|
let _ = DeprecatedUnstableTupleStruct (1);
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
|
|
|
let _ = UnstableTupleStruct (1); //~ ERROR use of unstable library feature
|
2014-01-30 23:36:05 +11:00
|
|
|
let _ = StableTupleStruct (1);
|
2014-07-16 13:50:33 -07:00
|
|
|
|
2014-09-18 00:15:36 +02:00
|
|
|
// At the moment, the lint checker only checks stability in
|
|
|
|
// in the arguments of macros.
|
|
|
|
// Eventually, we will want to lint the contents of the
|
2014-07-16 13:50:33 -07:00
|
|
|
// macro in the module *defining* it. Also, stability levels
|
|
|
|
// on macros themselves are not yet linted.
|
2016-11-10 19:08:21 +02:00
|
|
|
macro_test_arg!(deprecated_text());
|
|
|
|
macro_test_arg!(deprecated_unstable_text());
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
2016-11-10 19:08:21 +02:00
|
|
|
macro_test_arg!(macro_test_arg!(deprecated_text()));
|
2013-08-31 17:13:57 +10:00
|
|
|
}
|
2013-12-15 21:52:48 -05:00
|
|
|
|
2015-02-19 22:28:20 +02:00
|
|
|
fn test_method_param<Foo: Trait>(foo: Foo) {
|
2016-11-10 19:08:21 +02:00
|
|
|
foo.trait_deprecated();
|
|
|
|
Trait::trait_deprecated(&foo);
|
|
|
|
<Foo>::trait_deprecated(&foo);
|
|
|
|
<Foo as Trait>::trait_deprecated(&foo);
|
|
|
|
foo.trait_deprecated_text();
|
|
|
|
Trait::trait_deprecated_text(&foo);
|
|
|
|
<Foo>::trait_deprecated_text(&foo);
|
|
|
|
<Foo as Trait>::trait_deprecated_text(&foo);
|
|
|
|
Trait::trait_deprecated_unstable(&foo);
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
2016-11-10 19:08:21 +02:00
|
|
|
<Foo as Trait>::trait_deprecated_unstable(&foo);
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
2016-11-10 19:08:21 +02:00
|
|
|
Trait::trait_deprecated_unstable_text(&foo);
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
2016-11-10 19:08:21 +02:00
|
|
|
<Foo as Trait>::trait_deprecated_unstable_text(&foo);
|
2015-03-05 18:33:58 -08:00
|
|
|
//~^ ERROR use of unstable library feature
|
|
|
|
Trait::trait_unstable(&foo); //~ ERROR use of unstable library feature
|
|
|
|
<Foo as Trait>::trait_unstable(&foo); //~ ERROR use of unstable library feature
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_unstable_text(&foo);
|
2018-07-23 12:22:23 +01:00
|
|
|
//~^ ERROR use of unstable library feature 'unstable_test_feature': text
|
2015-02-19 22:28:20 +02:00
|
|
|
<Foo as Trait>::trait_unstable_text(&foo);
|
2018-07-23 12:22:23 +01:00
|
|
|
//~^ ERROR use of unstable library feature 'unstable_test_feature': text
|
2013-12-15 21:52:48 -05:00
|
|
|
foo.trait_stable();
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_stable(&foo);
|
|
|
|
<Foo>::trait_stable(&foo);
|
|
|
|
<Foo as Trait>::trait_stable(&foo);
|
2013-12-15 21:52:48 -05:00
|
|
|
}
|
|
|
|
|
2019-05-28 14:46:13 -04:00
|
|
|
fn test_method_object(foo: &dyn Trait) {
|
2016-11-10 19:08:21 +02:00
|
|
|
foo.trait_deprecated();
|
|
|
|
foo.trait_deprecated_text();
|
2013-12-15 21:52:48 -05:00
|
|
|
foo.trait_stable();
|
|
|
|
}
|
2014-11-05 15:49:37 -08:00
|
|
|
|
|
|
|
struct S;
|
|
|
|
|
2015-03-05 18:33:58 -08:00
|
|
|
impl UnstableTrait for S { } //~ ERROR use of unstable library feature
|
2016-11-10 19:08:21 +02:00
|
|
|
impl DeprecatedTrait for S {}
|
2015-03-05 18:33:58 -08:00
|
|
|
trait LocalTrait : UnstableTrait { } //~ ERROR use of unstable library feature
|
2016-11-10 19:08:21 +02:00
|
|
|
trait LocalTrait2 : DeprecatedTrait { }
|
2015-02-17 13:56:06 -08:00
|
|
|
|
|
|
|
impl Trait for S {
|
|
|
|
fn trait_stable(&self) {}
|
2015-03-05 18:33:58 -08:00
|
|
|
fn trait_unstable(&self) {} //~ ERROR use of unstable library feature
|
2015-02-17 13:56:06 -08:00
|
|
|
}
|
2013-08-31 17:13:57 +10:00
|
|
|
}
|
|
|
|
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
mod inheritance {
|
2015-03-05 18:33:58 -08:00
|
|
|
extern crate inherited_stability; //~ ERROR use of unstable library feature
|
|
|
|
use self::inherited_stability::*; //~ ERROR use of unstable library feature
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
|
|
|
|
fn test_inheritance() {
|
2015-03-05 18:33:58 -08:00
|
|
|
unstable(); //~ ERROR use of unstable library feature
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
stable();
|
|
|
|
|
2015-03-05 18:33:58 -08:00
|
|
|
stable_mod::unstable(); //~ ERROR use of unstable library feature
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
stable_mod::stable();
|
|
|
|
|
2022-04-11 18:12:26 -07:00
|
|
|
unstable_mod::deprecated(); //~ ERROR use of unstable library feature
|
2015-03-05 18:33:58 -08:00
|
|
|
unstable_mod::unstable(); //~ ERROR use of unstable library feature
|
2014-11-11 12:52:12 -08:00
|
|
|
|
2015-03-05 18:33:58 -08:00
|
|
|
let _ = Unstable::UnstableVariant; //~ ERROR use of unstable library feature
|
2022-04-11 18:12:26 -07:00
|
|
|
let _ = Unstable::StableVariant; //~ ERROR use of unstable library feature
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
|
2015-01-08 22:02:42 +11:00
|
|
|
let x: usize = 0;
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
x.stable();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-31 17:13:57 +10:00
|
|
|
mod this_crate {
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn deprecated() {}
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn deprecated_text() {}
|
|
|
|
|
2018-06-21 14:37:35 +01:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "99.99.99", note = "text")]
|
2018-06-21 14:37:35 +01:00
|
|
|
pub fn deprecated_future() {}
|
|
|
|
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn unstable() {}
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", reason = "text", issue = "none")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn unstable_text() {}
|
|
|
|
|
2015-01-23 21:48:20 -08:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn stable() {}
|
2015-10-13 06:01:31 +03:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn stable_text() {}
|
|
|
|
|
2015-01-23 21:48:20 -08:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub struct MethodTester;
|
|
|
|
|
|
|
|
impl MethodTester {
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn method_deprecated(&self) {}
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn method_deprecated_text(&self) {}
|
|
|
|
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn method_unstable(&self) {}
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", reason = "text", issue = "none")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn method_unstable_text(&self) {}
|
|
|
|
|
2015-01-23 21:48:20 -08:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn method_stable(&self) {}
|
2015-10-13 06:01:31 +03:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn method_stable_text(&self) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub trait Trait {
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
fn trait_deprecated(&self) {}
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
fn trait_deprecated_text(&self) {}
|
|
|
|
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2013-08-31 17:13:57 +10:00
|
|
|
fn trait_unstable(&self) {}
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", reason = "text", issue = "none")]
|
2013-08-31 17:13:57 +10:00
|
|
|
fn trait_unstable_text(&self) {}
|
|
|
|
|
2015-01-23 21:48:20 -08:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
fn trait_stable(&self) {}
|
2015-10-13 06:01:31 +03:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
fn trait_stable_text(&self) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Trait for MethodTester {}
|
|
|
|
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2015-02-25 22:34:21 +11:00
|
|
|
pub struct DeprecatedStruct {
|
2018-07-23 12:22:23 +01:00
|
|
|
#[stable(feature = "stable_test_feature", since = "1.0.0")] i: isize
|
2015-02-25 22:34:21 +11:00
|
|
|
}
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2015-02-25 22:34:21 +11:00
|
|
|
pub struct UnstableStruct {
|
2018-07-23 12:22:23 +01:00
|
|
|
#[stable(feature = "stable_test_feature", since = "1.0.0")] i: isize
|
2015-02-25 22:34:21 +11:00
|
|
|
}
|
2015-01-23 21:48:20 -08:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2015-02-25 22:34:21 +11:00
|
|
|
pub struct StableStruct {
|
2018-07-23 12:22:23 +01:00
|
|
|
#[stable(feature = "stable_test_feature", since = "1.0.0")] i: isize
|
2015-02-25 22:34:21 +11:00
|
|
|
}
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub struct DeprecatedUnitStruct;
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub struct UnstableUnitStruct;
|
2015-01-23 21:48:20 -08:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub struct StableUnitStruct;
|
|
|
|
|
|
|
|
pub enum Enum {
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
DeprecatedVariant,
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2013-08-31 17:13:57 +10:00
|
|
|
UnstableVariant,
|
|
|
|
|
2015-01-23 21:48:20 -08:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
StableVariant,
|
|
|
|
}
|
|
|
|
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2015-01-08 21:54:35 +11:00
|
|
|
pub struct DeprecatedTupleStruct(isize);
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2015-01-08 21:54:35 +11:00
|
|
|
pub struct UnstableTupleStruct(isize);
|
2015-01-23 21:48:20 -08:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0")]
|
2015-01-08 21:54:35 +11:00
|
|
|
pub struct StableTupleStruct(isize);
|
2014-01-30 23:36:05 +11:00
|
|
|
|
2013-08-31 17:13:57 +10:00
|
|
|
fn test() {
|
2014-08-11 16:39:34 -07:00
|
|
|
// Only the deprecated cases of the following should generate
|
|
|
|
// errors, because other stability attributes now have meaning
|
|
|
|
// only *across* crates, not within a single crate.
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
|
2015-02-19 22:28:20 +02:00
|
|
|
type Foo = MethodTester;
|
2013-08-31 17:13:57 +10:00
|
|
|
let foo = MethodTester;
|
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
deprecated();
|
|
|
|
foo.method_deprecated();
|
|
|
|
Foo::method_deprecated(&foo);
|
|
|
|
<Foo>::method_deprecated(&foo);
|
|
|
|
foo.trait_deprecated();
|
|
|
|
Trait::trait_deprecated(&foo);
|
|
|
|
<Foo>::trait_deprecated(&foo);
|
|
|
|
<Foo as Trait>::trait_deprecated(&foo);
|
|
|
|
|
|
|
|
deprecated_text();
|
|
|
|
foo.method_deprecated_text();
|
|
|
|
Foo::method_deprecated_text(&foo);
|
|
|
|
<Foo>::method_deprecated_text(&foo);
|
|
|
|
foo.trait_deprecated_text();
|
|
|
|
Trait::trait_deprecated_text(&foo);
|
|
|
|
<Foo>::trait_deprecated_text(&foo);
|
|
|
|
<Foo as Trait>::trait_deprecated_text(&foo);
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2018-06-21 14:37:35 +01:00
|
|
|
deprecated_future();
|
|
|
|
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
unstable();
|
|
|
|
foo.method_unstable();
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_unstable(&foo);
|
|
|
|
<Foo>::method_unstable(&foo);
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
foo.trait_unstable();
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_unstable(&foo);
|
|
|
|
<Foo>::trait_unstable(&foo);
|
|
|
|
<Foo as Trait>::trait_unstable(&foo);
|
2013-08-31 17:13:57 +10:00
|
|
|
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
unstable_text();
|
|
|
|
foo.method_unstable_text();
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_unstable_text(&foo);
|
|
|
|
<Foo>::method_unstable_text(&foo);
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
foo.trait_unstable_text();
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_unstable_text(&foo);
|
|
|
|
<Foo>::trait_unstable_text(&foo);
|
|
|
|
<Foo as Trait>::trait_unstable_text(&foo);
|
2013-08-31 17:13:57 +10:00
|
|
|
|
|
|
|
stable();
|
|
|
|
foo.method_stable();
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_stable(&foo);
|
|
|
|
<Foo>::method_stable(&foo);
|
2013-08-31 17:13:57 +10:00
|
|
|
foo.trait_stable();
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_stable(&foo);
|
|
|
|
<Foo>::trait_stable(&foo);
|
|
|
|
<Foo as Trait>::trait_stable(&foo);
|
2013-08-31 17:13:57 +10:00
|
|
|
|
|
|
|
stable_text();
|
|
|
|
foo.method_stable_text();
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_stable_text(&foo);
|
|
|
|
<Foo>::method_stable_text(&foo);
|
2013-08-31 17:13:57 +10:00
|
|
|
foo.trait_stable_text();
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_stable_text(&foo);
|
|
|
|
<Foo>::trait_stable_text(&foo);
|
|
|
|
<Foo as Trait>::trait_stable_text(&foo);
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2015-06-06 17:14:46 -07:00
|
|
|
let _ = DeprecatedStruct {
|
2016-11-10 19:08:21 +02:00
|
|
|
i: 0
|
2015-06-06 17:14:46 -07:00
|
|
|
};
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
let _ = UnstableStruct { i: 0 };
|
2013-08-31 17:13:57 +10:00
|
|
|
let _ = StableStruct { i: 0 };
|
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
let _ = DeprecatedUnitStruct;
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
let _ = UnstableUnitStruct;
|
2013-08-31 17:13:57 +10:00
|
|
|
let _ = StableUnitStruct;
|
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
let _ = Enum::DeprecatedVariant;
|
2014-11-06 00:05:53 -08:00
|
|
|
let _ = Enum::UnstableVariant;
|
|
|
|
let _ = Enum::StableVariant;
|
2014-01-30 23:36:05 +11:00
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
let _ = DeprecatedTupleStruct (1);
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
let _ = UnstableTupleStruct (1);
|
2014-01-30 23:36:05 +11:00
|
|
|
let _ = StableTupleStruct (1);
|
2013-08-31 17:13:57 +10:00
|
|
|
}
|
2013-12-15 21:52:48 -05:00
|
|
|
|
2015-02-19 22:28:20 +02:00
|
|
|
fn test_method_param<Foo: Trait>(foo: Foo) {
|
2016-11-10 19:08:21 +02:00
|
|
|
foo.trait_deprecated();
|
|
|
|
Trait::trait_deprecated(&foo);
|
|
|
|
<Foo>::trait_deprecated(&foo);
|
|
|
|
<Foo as Trait>::trait_deprecated(&foo);
|
|
|
|
foo.trait_deprecated_text();
|
|
|
|
Trait::trait_deprecated_text(&foo);
|
|
|
|
<Foo>::trait_deprecated_text(&foo);
|
|
|
|
<Foo as Trait>::trait_deprecated_text(&foo);
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
foo.trait_unstable();
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_unstable(&foo);
|
|
|
|
<Foo>::trait_unstable(&foo);
|
|
|
|
<Foo as Trait>::trait_unstable(&foo);
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
foo.trait_unstable_text();
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_unstable_text(&foo);
|
|
|
|
<Foo>::trait_unstable_text(&foo);
|
|
|
|
<Foo as Trait>::trait_unstable_text(&foo);
|
2013-12-15 21:52:48 -05:00
|
|
|
foo.trait_stable();
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_stable(&foo);
|
|
|
|
<Foo>::trait_stable(&foo);
|
|
|
|
<Foo as Trait>::trait_stable(&foo);
|
2013-12-15 21:52:48 -05:00
|
|
|
}
|
|
|
|
|
2019-05-28 14:46:13 -04:00
|
|
|
fn test_method_object(foo: &dyn Trait) {
|
2016-11-10 19:08:21 +02:00
|
|
|
foo.trait_deprecated();
|
|
|
|
foo.trait_deprecated_text();
|
Add stability inheritance
This commit makes several changes to the stability index infrastructure:
* Stability levels are now inherited lexically, i.e., each item's
stability level becomes the default for any nested items.
* The computed stability level for an item is stored as part of the
metadata. When using an item from an external crate, this data is
looked up and cached.
* The stability lint works from the computed stability level, rather
than manual stability attribute annotations. However, the lint still
checks only a limited set of item uses (e.g., it does not check every
component of a path on import). This will be addressed in a later PR,
as part of issue #8962.
* The stability lint only applies to items originating from external
crates, since the stability index is intended as a promise to
downstream crates.
* The "experimental" lint is now _allow_ by default. This is because
almost all existing crates have been marked "experimental", pending
library stabilization. With inheritance in place, this would generate
a massive explosion of warnings for every Rust program.
The lint should be changed back to deny-by-default after library
stabilization is complete.
* The "deprecated" lint still warns by default.
The net result: we can begin tracking stability index for the standard
libraries as we stabilize, without impacting most clients.
Closes #13540.
2014-06-11 17:23:11 -07:00
|
|
|
foo.trait_unstable();
|
|
|
|
foo.trait_unstable_text();
|
2013-12-15 21:52:48 -05:00
|
|
|
foo.trait_stable();
|
|
|
|
}
|
2014-11-05 15:49:37 -08:00
|
|
|
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2014-11-17 11:37:07 +01:00
|
|
|
fn test_fn_body() {
|
|
|
|
fn fn_in_body() {}
|
2016-11-10 19:08:21 +02:00
|
|
|
fn_in_body();
|
2014-11-17 11:37:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
impl MethodTester {
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2014-11-17 11:37:07 +01:00
|
|
|
fn test_method_body(&self) {
|
|
|
|
fn fn_in_body() {}
|
2016-11-10 19:08:21 +02:00
|
|
|
fn_in_body();
|
2014-11-17 11:37:07 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-21 13:16:18 +02:00
|
|
|
#[unstable(feature = "unstable_test_feature", issue = "none")]
|
2022-03-04 21:59:18 -05:00
|
|
|
#[deprecated(since = "1.0.0", note = "text")]
|
2015-02-12 10:29:52 -05:00
|
|
|
pub trait DeprecatedTrait {
|
|
|
|
fn dummy(&self) { }
|
|
|
|
}
|
2014-11-05 15:49:37 -08:00
|
|
|
|
|
|
|
struct S;
|
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
impl DeprecatedTrait for S { }
|
2014-11-05 15:49:37 -08:00
|
|
|
|
2016-11-10 19:08:21 +02:00
|
|
|
trait LocalTrait : DeprecatedTrait { }
|
2013-08-31 17:13:57 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|