diff --git a/src/librustc/middle/stability.rs b/src/librustc/middle/stability.rs index d6a7d5e8472ac..4cdc9fdddbf80 100644 --- a/src/librustc/middle/stability.rs +++ b/src/librustc/middle/stability.rs @@ -614,10 +614,12 @@ impl<'a, 'gcx, 'tcx> TyCtxt<'a, 'gcx, 'tcx> { debug!("stability: \ inspecting def_id={:?} span={:?} of stability={:?}", def_id, span, stability); - if let Some(&Stability{rustc_depr: Some(attr::RustcDeprecation { reason, .. }), ..}) + if let Some(&Stability{rustc_depr: Some(attr::RustcDeprecation { reason, since }), ..}) = stability { if let Some(id) = id { - lint_deprecated(def_id, id, Some(reason)); + if deprecation_in_effect(&since.as_str()) { + lint_deprecated(def_id, id, Some(reason)); + } } } diff --git a/src/test/compile-fail/auxiliary/lint_stability.rs b/src/test/compile-fail/auxiliary/lint_stability.rs index 5e3cb606ce037..07e80b61cd0a6 100644 --- a/src/test/compile-fail/auxiliary/lint_stability.rs +++ b/src/test/compile-fail/auxiliary/lint_stability.rs @@ -7,6 +7,7 @@ // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. + #![crate_name="lint_stability"] #![crate_type = "lib"] #![feature(staged_api)] @@ -20,6 +21,10 @@ pub fn deprecated() {} #[rustc_deprecated(since = "1.0.0", reason = "text")] pub fn deprecated_text() {} +#[stable(feature = "test_feature", since = "1.0.0")] +#[rustc_deprecated(since = "99.99.99", reason = "text")] +pub fn deprecated_future() {} + #[unstable(feature = "test_feature", issue = "0")] #[rustc_deprecated(since = "1.0.0", reason = "text")] pub fn deprecated_unstable() {} diff --git a/src/test/compile-fail/lint-stability.rs b/src/test/compile-fail/lint-stability.rs index 49a52204295e5..bd390108bd8f3 100644 --- a/src/test/compile-fail/lint-stability.rs +++ b/src/test/compile-fail/lint-stability.rs @@ -50,6 +50,8 @@ mod cross_crate { ::trait_deprecated_text(&foo); ::trait_deprecated_text(&foo); + deprecated_future(); // Fine; no error. + deprecated_unstable(); //~^ ERROR use of unstable library feature Trait::trait_deprecated_unstable(&foo); @@ -218,6 +220,10 @@ mod this_crate { #[rustc_deprecated(since = "1.0.0", reason = "text")] pub fn deprecated_text() {} + #[stable(feature = "rust1", since = "1.0.0")] + #[rustc_deprecated(since = "99.99.99", reason = "text")] + pub fn deprecated_future() {} + #[unstable(feature = "test_feature", issue = "0")] pub fn unstable() {} #[unstable(feature = "test_feature", reason = "text", issue = "0")] @@ -338,6 +344,8 @@ mod this_crate { ::trait_deprecated_text(&foo); ::trait_deprecated_text(&foo); + deprecated_future(); + unstable(); foo.method_unstable(); Foo::method_unstable(&foo);