2014-02-07 20:08:32 +01:00
|
|
|
// Copyright 2013-2014 The Rust Project Developers. See the COPYRIGHT
|
2013-08-31 17:13:57 +10:00
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
|
|
|
// 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
|
|
|
|
// aux-build:stability_cfg2.rs
|
2015-01-16 14:08:24 -08:00
|
|
|
// ignore-tidy-linelength
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2014-03-21 18:05:05 -07:00
|
|
|
#![deny(deprecated)]
|
|
|
|
#![allow(dead_code)]
|
2015-01-21 18:21:14 -08:00
|
|
|
#![feature(staged_api)]
|
2015-01-07 15:48:16 -08:00
|
|
|
#![staged_api]
|
2013-08-31 17:13:57 +10:00
|
|
|
|
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-01-16 14:08:24 -08:00
|
|
|
extern crate stability_cfg2; //~ WARNING: 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;
|
|
|
|
|
|
|
|
deprecated(); //~ ERROR use of deprecated item
|
2013-12-15 21:52:48 -05:00
|
|
|
foo.method_deprecated(); //~ ERROR use of deprecated item
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_deprecated(&foo); //~ ERROR use of deprecated item
|
|
|
|
<Foo>::method_deprecated(&foo); //~ ERROR use of deprecated item
|
2013-12-15 21:52:48 -05:00
|
|
|
foo.trait_deprecated(); //~ ERROR use of deprecated item
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
|
|
|
<Foo>::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
|
|
|
<Foo as Trait>::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
2013-08-31 17:13:57 +10:00
|
|
|
|
|
|
|
deprecated_text(); //~ ERROR use of deprecated item: text
|
2013-12-15 21:52:48 -05:00
|
|
|
foo.method_deprecated_text(); //~ ERROR use of deprecated item: text
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
<Foo>::method_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
2013-12-15 21:52:48 -05:00
|
|
|
foo.trait_deprecated_text(); //~ ERROR use of deprecated item: text
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
<Foo>::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
<Foo as Trait>::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2015-01-22 12:33:46 -08:00
|
|
|
deprecated_unstable(); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
foo.method_deprecated_unstable(); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_deprecated_unstable(&foo); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
<Foo>::method_deprecated_unstable(&foo); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-01-22 12:33:46 -08:00
|
|
|
foo.trait_deprecated_unstable(); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated_unstable(&foo); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
<Foo>::trait_deprecated_unstable(&foo); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
<Foo as Trait>::trait_deprecated_unstable(&foo); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-01-22 12:33:46 -08:00
|
|
|
|
|
|
|
deprecated_unstable_text(); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
foo.method_deprecated_unstable_text(); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_deprecated_unstable_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
<Foo>::method_deprecated_unstable_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-01-22 12:33:46 -08:00
|
|
|
foo.trait_deprecated_unstable_text(); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated_unstable_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
<Foo>::trait_deprecated_unstable_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
<Foo as Trait>::trait_deprecated_unstable_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-01-22 12:33:46 -08:00
|
|
|
|
2015-01-16 14:08:24 -08:00
|
|
|
unstable(); //~ WARNING use of unstable library feature
|
|
|
|
foo.method_unstable(); //~ WARNING use of unstable library feature
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_unstable(&foo); //~ WARNING use of unstable library feature
|
|
|
|
<Foo>::method_unstable(&foo); //~ WARNING use of unstable library feature
|
2015-01-16 14:08:24 -08:00
|
|
|
foo.trait_unstable(); //~ WARNING use of unstable library feature
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_unstable(&foo); //~ WARNING use of unstable library feature
|
|
|
|
<Foo>::trait_unstable(&foo); //~ WARNING use of unstable library feature
|
|
|
|
<Foo as Trait>::trait_unstable(&foo); //~ WARNING use of unstable library feature
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2015-02-19 22:28:20 +02:00
|
|
|
unstable_text();
|
|
|
|
//~^ WARNING use of unstable library feature 'test_feature': text
|
|
|
|
foo.method_unstable_text();
|
|
|
|
//~^ WARNING use of unstable library feature 'test_feature': text
|
|
|
|
Foo::method_unstable_text(&foo);
|
|
|
|
//~^ WARNING use of unstable library feature 'test_feature': text
|
|
|
|
<Foo>::method_unstable_text(&foo);
|
|
|
|
//~^ WARNING use of unstable library feature 'test_feature': text
|
|
|
|
foo.trait_unstable_text();
|
|
|
|
//~^ WARNING use of unstable library feature 'test_feature': text
|
|
|
|
Trait::trait_unstable_text(&foo);
|
|
|
|
//~^ WARNING use of unstable library feature 'test_feature': text
|
|
|
|
<Foo>::trait_unstable_text(&foo);
|
|
|
|
//~^ WARNING use of unstable library feature 'test_feature': text
|
|
|
|
<Foo as Trait>::trait_unstable_text(&foo);
|
|
|
|
//~^ WARNING use of unstable library feature '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
|
|
|
|
|
|
|
let _ = DeprecatedStruct { i: 0 }; //~ ERROR use of deprecated item
|
2015-01-22 12:33:46 -08:00
|
|
|
let _ = DeprecatedUnstableStruct { i: 0 }; //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-01-16 14:08:24 -08:00
|
|
|
let _ = UnstableStruct { i: 0 }; //~ WARNING use of unstable library feature
|
2013-08-31 17:13:57 +10:00
|
|
|
let _ = StableStruct { i: 0 };
|
|
|
|
|
|
|
|
let _ = DeprecatedUnitStruct; //~ ERROR use of deprecated item
|
2015-01-22 12:33:46 -08:00
|
|
|
let _ = DeprecatedUnstableUnitStruct; //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-01-16 14:08:24 -08:00
|
|
|
let _ = UnstableUnitStruct; //~ WARNING use of unstable library feature
|
2013-08-31 17:13:57 +10:00
|
|
|
let _ = StableUnitStruct;
|
|
|
|
|
2014-11-06 00:05:53 -08:00
|
|
|
let _ = Enum::DeprecatedVariant; //~ ERROR use of deprecated item
|
2015-01-22 12:33:46 -08:00
|
|
|
let _ = Enum::DeprecatedUnstableVariant; //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-01-16 14:08:24 -08:00
|
|
|
let _ = Enum::UnstableVariant; //~ WARNING use of unstable library feature
|
2014-11-06 00:05:53 -08:00
|
|
|
let _ = Enum::StableVariant;
|
2014-01-30 23:36:05 +11:00
|
|
|
|
|
|
|
let _ = DeprecatedTupleStruct (1); //~ ERROR use of deprecated item
|
2015-01-22 12:33:46 -08:00
|
|
|
let _ = DeprecatedUnstableTupleStruct (1); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-01-16 14:08:24 -08:00
|
|
|
let _ = UnstableTupleStruct (1); //~ WARNING 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.
|
2014-09-18 00:15:36 +02:00
|
|
|
macro_test_arg!(deprecated_text()); //~ ERROR use of deprecated item: text
|
2015-01-22 12:33:46 -08:00
|
|
|
macro_test_arg!(deprecated_unstable_text()); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
2014-09-24 11:14:19 +02:00
|
|
|
macro_test_arg!(macro_test_arg!(deprecated_text())); //~ ERROR use of deprecated item: 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) {
|
2013-12-15 21:52:48 -05:00
|
|
|
foo.trait_deprecated(); //~ ERROR use of deprecated item
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
|
|
|
<Foo>::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
|
|
|
<Foo as Trait>::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
2013-12-15 21:52:48 -05:00
|
|
|
foo.trait_deprecated_text(); //~ ERROR use of deprecated item: text
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
<Foo>::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
<Foo as Trait>::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
2015-01-22 12:33:46 -08:00
|
|
|
foo.trait_deprecated_unstable(); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated_unstable(&foo); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
<Foo>::trait_deprecated_unstable(&foo); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
<Foo as Trait>::trait_deprecated_unstable(&foo); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-01-22 12:33:46 -08:00
|
|
|
foo.trait_deprecated_unstable_text(); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated_unstable_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
<Foo>::trait_deprecated_unstable_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
<Foo as Trait>::trait_deprecated_unstable_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-01-16 14:08:24 -08:00
|
|
|
foo.trait_unstable(); //~ WARNING use of unstable library feature
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_unstable(&foo); //~ WARNING use of unstable library feature
|
|
|
|
<Foo>::trait_unstable(&foo); //~ WARNING use of unstable library feature
|
|
|
|
<Foo as Trait>::trait_unstable(&foo); //~ WARNING use of unstable library feature
|
|
|
|
foo.trait_unstable_text();
|
|
|
|
//~^ WARNING use of unstable library feature 'test_feature': text
|
|
|
|
Trait::trait_unstable_text(&foo);
|
|
|
|
//~^ WARNING use of unstable library feature 'test_feature': text
|
|
|
|
<Foo>::trait_unstable_text(&foo);
|
|
|
|
//~^ WARNING use of unstable library feature 'test_feature': text
|
|
|
|
<Foo as Trait>::trait_unstable_text(&foo);
|
|
|
|
//~^ WARNING use of unstable library feature '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
|
|
|
}
|
|
|
|
|
|
|
|
fn test_method_object(foo: &Trait) {
|
|
|
|
foo.trait_deprecated(); //~ ERROR use of deprecated item
|
|
|
|
foo.trait_deprecated_text(); //~ ERROR use of deprecated item: text
|
2015-01-22 12:33:46 -08:00
|
|
|
foo.trait_deprecated_unstable(); //~ ERROR use of deprecated item
|
|
|
|
//~^ WARNING use of unstable library feature
|
|
|
|
foo.trait_deprecated_unstable_text(); //~ ERROR use of deprecated item: text
|
|
|
|
//~^ WARNING use of unstable library feature
|
2015-01-16 14:08:24 -08:00
|
|
|
foo.trait_unstable(); //~ WARNING use of unstable library feature
|
2015-02-19 22:28:20 +02:00
|
|
|
foo.trait_unstable_text();
|
|
|
|
//~^ WARNING use of unstable library feature 'test_feature': text
|
2013-12-15 21:52:48 -05:00
|
|
|
foo.trait_stable();
|
|
|
|
}
|
2014-11-05 15:49:37 -08:00
|
|
|
|
|
|
|
struct S;
|
|
|
|
|
2015-01-16 14:08:24 -08:00
|
|
|
impl UnstableTrait for S { } //~ WARNING use of unstable library feature
|
2014-11-05 15:49:37 -08:00
|
|
|
|
2015-01-16 14:08:24 -08:00
|
|
|
trait LocalTrait : UnstableTrait { } //~ WARNING use of unstable library feature
|
2015-02-17 13:56:06 -08:00
|
|
|
|
|
|
|
impl Trait for S {
|
|
|
|
fn trait_stable(&self) {}
|
|
|
|
fn trait_unstable(&self) {} //~ WARNING use of unstable library feature
|
|
|
|
}
|
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-01-16 14:08:24 -08:00
|
|
|
extern crate inherited_stability; //~ WARNING: use of unstable library feature
|
2015-02-09 16:33:19 -08:00
|
|
|
use self::inherited_stability::*; //~ WARNING: 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-01-16 14:08:24 -08:00
|
|
|
unstable(); //~ WARNING 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-01-16 14:08:24 -08:00
|
|
|
stable_mod::unstable(); //~ WARNING 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();
|
|
|
|
|
2015-01-12 18:40:19 -08:00
|
|
|
unstable_mod::deprecated(); //~ ERROR use of deprecated item
|
2015-01-16 14:08:24 -08:00
|
|
|
unstable_mod::unstable(); //~ WARNING use of unstable library feature
|
2014-11-11 12:52:12 -08:00
|
|
|
|
2015-01-16 14:08:24 -08:00
|
|
|
let _ = Unstable::UnstableVariant; //~ WARNING use of unstable library feature
|
2015-01-12 18:40:19 -08:00
|
|
|
let _ = Unstable::StableVariant;
|
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;
|
2015-01-16 14:08:24 -08:00
|
|
|
x.unstable(); //~ WARNING 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
|
|
|
x.stable();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-31 17:13:57 +10:00
|
|
|
mod this_crate {
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn deprecated() {}
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0", reason = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn deprecated_text() {}
|
|
|
|
|
2015-01-22 18:22:03 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn unstable() {}
|
2015-01-22 18:22:03 -08:00
|
|
|
#[unstable(feature = "test_feature", reason = "text")]
|
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-01-23 21:48:20 -08:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0", reason = "text")]
|
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 {
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn method_deprecated(&self) {}
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0", reason = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn method_deprecated_text(&self) {}
|
|
|
|
|
2015-01-22 18:22:03 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn method_unstable(&self) {}
|
2015-01-22 18:22:03 -08:00
|
|
|
#[unstable(feature = "test_feature", reason = "text")]
|
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-01-23 21:48:20 -08:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0", reason = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub fn method_stable_text(&self) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub trait Trait {
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
fn trait_deprecated(&self) {}
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0", reason = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
fn trait_deprecated_text(&self) {}
|
|
|
|
|
2015-01-22 18:22:03 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
2013-08-31 17:13:57 +10:00
|
|
|
fn trait_unstable(&self) {}
|
2015-01-22 18:22:03 -08:00
|
|
|
#[unstable(feature = "test_feature", reason = "text")]
|
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-01-23 21:48:20 -08:00
|
|
|
#[stable(feature = "rust1", since = "1.0.0", reason = "text")]
|
2013-08-31 17:13:57 +10:00
|
|
|
fn trait_stable_text(&self) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Trait for MethodTester {}
|
|
|
|
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0")]
|
2015-02-25 22:34:21 +11:00
|
|
|
pub struct DeprecatedStruct {
|
|
|
|
#[stable(feature = "test_feature", since = "1.0.0")] i: isize
|
|
|
|
}
|
2015-01-22 18:22:03 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
2015-02-25 22:34:21 +11:00
|
|
|
pub struct UnstableStruct {
|
|
|
|
#[stable(feature = "test_feature", since = "1.0.0")] i: isize
|
|
|
|
}
|
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 {
|
|
|
|
#[stable(feature = "test_feature", since = "1.0.0")] i: isize
|
|
|
|
}
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
pub struct DeprecatedUnitStruct;
|
2015-01-22 18:22:03 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
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 {
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0")]
|
2013-08-31 17:13:57 +10:00
|
|
|
DeprecatedVariant,
|
2015-01-22 18:22:03 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
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,
|
|
|
|
}
|
|
|
|
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0")]
|
2015-01-08 21:54:35 +11:00
|
|
|
pub struct DeprecatedTupleStruct(isize);
|
2015-01-22 18:22:03 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
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;
|
|
|
|
|
2014-08-11 16:39:34 -07:00
|
|
|
deprecated(); //~ ERROR use of deprecated item
|
|
|
|
foo.method_deprecated(); //~ ERROR use of deprecated item
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_deprecated(&foo); //~ ERROR use of deprecated item
|
|
|
|
<Foo>::method_deprecated(&foo); //~ ERROR use of deprecated item
|
2014-08-11 16:39:34 -07:00
|
|
|
foo.trait_deprecated(); //~ ERROR use of deprecated item
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
|
|
|
<Foo>::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
|
|
|
<Foo as Trait>::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
2013-08-31 17:13:57 +10:00
|
|
|
|
2014-08-11 16:39:34 -07:00
|
|
|
deprecated_text(); //~ ERROR use of deprecated item: text
|
|
|
|
foo.method_deprecated_text(); //~ ERROR use of deprecated item: text
|
2015-02-19 22:28:20 +02:00
|
|
|
Foo::method_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
<Foo>::method_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
2014-08-11 16:39:34 -07:00
|
|
|
foo.trait_deprecated_text(); //~ ERROR use of deprecated item: text
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
<Foo>::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
<Foo as Trait>::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
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();
|
|
|
|
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
|
|
|
|
2014-08-11 16:39:34 -07:00
|
|
|
let _ = DeprecatedStruct { i: 0 }; //~ ERROR use of deprecated item
|
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 };
|
|
|
|
|
2014-08-11 16:39:34 -07:00
|
|
|
let _ = DeprecatedUnitStruct; //~ ERROR use of deprecated item
|
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;
|
|
|
|
|
2014-11-06 00:05:53 -08:00
|
|
|
let _ = Enum::DeprecatedVariant; //~ ERROR use of deprecated item
|
|
|
|
let _ = Enum::UnstableVariant;
|
|
|
|
let _ = Enum::StableVariant;
|
2014-01-30 23:36:05 +11:00
|
|
|
|
2014-08-11 16:39:34 -07:00
|
|
|
let _ = DeprecatedTupleStruct (1); //~ ERROR use of deprecated item
|
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) {
|
2014-08-11 16:39:34 -07:00
|
|
|
foo.trait_deprecated(); //~ ERROR use of deprecated item
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
|
|
|
<Foo>::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
|
|
|
<Foo as Trait>::trait_deprecated(&foo); //~ ERROR use of deprecated item
|
2014-08-11 16:39:34 -07:00
|
|
|
foo.trait_deprecated_text(); //~ ERROR use of deprecated item: text
|
2015-02-19 22:28:20 +02:00
|
|
|
Trait::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
<Foo>::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: text
|
|
|
|
<Foo as Trait>::trait_deprecated_text(&foo); //~ ERROR use of deprecated item: 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();
|
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
|
|
|
}
|
|
|
|
|
|
|
|
fn test_method_object(foo: &Trait) {
|
2014-08-11 16:39:34 -07:00
|
|
|
foo.trait_deprecated(); //~ ERROR use of deprecated item
|
|
|
|
foo.trait_deprecated_text(); //~ ERROR use of deprecated item: 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
|
|
|
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0")]
|
2014-11-17 11:37:07 +01:00
|
|
|
fn test_fn_body() {
|
|
|
|
fn fn_in_body() {}
|
|
|
|
fn_in_body();
|
|
|
|
}
|
|
|
|
|
|
|
|
impl MethodTester {
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0")]
|
2014-11-17 11:37:07 +01:00
|
|
|
fn test_method_body(&self) {
|
|
|
|
fn fn_in_body() {}
|
|
|
|
fn_in_body();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-22 12:33:46 -08:00
|
|
|
#[unstable(feature = "test_feature")]
|
|
|
|
#[deprecated(since = "1.0.0")]
|
2015-02-12 10:29:52 -05:00
|
|
|
pub trait DeprecatedTrait {
|
|
|
|
fn dummy(&self) { }
|
|
|
|
}
|
2014-11-05 15:49:37 -08:00
|
|
|
|
|
|
|
struct S;
|
|
|
|
|
|
|
|
impl DeprecatedTrait for S { } //~ ERROR use of deprecated item
|
|
|
|
|
|
|
|
trait LocalTrait : DeprecatedTrait { } //~ ERROR use of deprecated item
|
2013-08-31 17:13:57 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|