From d0311e71548ad5c7fb259901014552a8279ecb3b Mon Sep 17 00:00:00 2001 From: Matthew Jasper Date: Sat, 22 Jun 2019 17:13:19 +0100 Subject: [PATCH] Deny explicit_outlives_requirements in the compiler --- src/librustc/hir/itemlikevisit.rs | 2 +- src/librustc/infer/nll_relate/mod.rs | 2 +- src/librustc/lib.rs | 1 - src/librustc/ty/context.rs | 6 +++--- src/librustc/ty/query/plumbing.rs | 4 ++-- src/librustc_codegen_llvm/lib.rs | 1 - src/librustc_codegen_ssa/lib.rs | 1 - src/librustc_mir/dataflow/graphviz.rs | 2 +- src/librustc_mir/dataflow/mod.rs | 2 +- src/librustc_mir/interpret/intern.rs | 2 +- src/librustc_mir/lib.rs | 1 - src/librustc_mir/util/elaborate_drops.rs | 2 +- src/librustc_typeck/lib.rs | 1 - 13 files changed, 11 insertions(+), 16 deletions(-) diff --git a/src/librustc/hir/itemlikevisit.rs b/src/librustc/hir/itemlikevisit.rs index bfc9e8f06e235..35b181245837f 100644 --- a/src/librustc/hir/itemlikevisit.rs +++ b/src/librustc/hir/itemlikevisit.rs @@ -51,7 +51,7 @@ pub trait ItemLikeVisitor<'hir> { fn visit_impl_item(&mut self, impl_item: &'hir ImplItem); } -pub struct DeepVisitor<'v, V: 'v> { +pub struct DeepVisitor<'v, V> { visitor: &'v mut V, } diff --git a/src/librustc/infer/nll_relate/mod.rs b/src/librustc/infer/nll_relate/mod.rs index 21489965b1bf6..a1a93eb552138 100644 --- a/src/librustc/infer/nll_relate/mod.rs +++ b/src/librustc/infer/nll_relate/mod.rs @@ -800,7 +800,7 @@ impl<'me, 'tcx> TypeVisitor<'tcx> for ScopeInstantiator<'me, 'tcx> { /// [blog post]: https://is.gd/0hKvIr struct TypeGeneralizer<'me, 'tcx, D> where - D: TypeRelatingDelegate<'tcx> + 'me, + D: TypeRelatingDelegate<'tcx>, { infcx: &'me InferCtxt<'me, 'tcx>, diff --git a/src/librustc/lib.rs b/src/librustc/lib.rs index e2f2799d9634d..257d5159f1131 100644 --- a/src/librustc/lib.rs +++ b/src/librustc/lib.rs @@ -31,7 +31,6 @@ #![deny(rust_2018_idioms)] #![deny(internal)] #![deny(unused_lifetimes)] -#![allow(explicit_outlives_requirements)] #![feature(arbitrary_self_types)] #![feature(box_patterns)] diff --git a/src/librustc/ty/context.rs b/src/librustc/ty/context.rs index ce785f9a0246b..28399ed5439f7 100644 --- a/src/librustc/ty/context.rs +++ b/src/librustc/ty/context.rs @@ -231,7 +231,7 @@ pub struct CommonConsts<'tcx> { pub err: &'tcx Const<'tcx>, } -pub struct LocalTableInContext<'a, V: 'a> { +pub struct LocalTableInContext<'a, V> { local_id_root: Option, data: &'a ItemLocalMap } @@ -294,7 +294,7 @@ impl<'a, V> ::std::ops::Index for LocalTableInContext<'a, V> { } } -pub struct LocalTableInContextMut<'a, V: 'a> { +pub struct LocalTableInContextMut<'a, V> { local_id_root: Option, data: &'a mut ItemLocalMap } @@ -2171,7 +2171,7 @@ impl<'tcx> TyCtxt<'tcx> { /// An entry in an interner. -struct Interned<'tcx, T: 'tcx+?Sized>(&'tcx T); +struct Interned<'tcx, T: ?Sized>(&'tcx T); impl<'tcx, T: 'tcx+?Sized> Clone for Interned<'tcx, T> { fn clone(&self) -> Self { diff --git a/src/librustc/ty/query/plumbing.rs b/src/librustc/ty/query/plumbing.rs index 0f158d2982a20..7d5f984c1b6f2 100644 --- a/src/librustc/ty/query/plumbing.rs +++ b/src/librustc/ty/query/plumbing.rs @@ -89,7 +89,7 @@ macro_rules! profq_query_msg { /// A type representing the responsibility to execute the job in the `job` field. /// This will poison the relevant query if dropped. -pub(super) struct JobOwner<'a, 'tcx, Q: QueryDescription<'tcx> + 'a> { +pub(super) struct JobOwner<'a, 'tcx, Q: QueryDescription<'tcx>> { cache: &'a Lock>, key: Q::Key, job: Lrc>, @@ -230,7 +230,7 @@ pub struct CycleError<'tcx> { } /// The result of `try_get_lock` -pub(super) enum TryGetJob<'a, 'tcx, D: QueryDescription<'tcx> + 'a> { +pub(super) enum TryGetJob<'a, 'tcx, D: QueryDescription<'tcx>> { /// The query is not yet started. Contains a guard to the cache eventually used to start it. NotYetStarted(JobOwner<'a, 'tcx, D>), diff --git a/src/librustc_codegen_llvm/lib.rs b/src/librustc_codegen_llvm/lib.rs index 1eb6e9a5283bd..7283aa95b3027 100644 --- a/src/librustc_codegen_llvm/lib.rs +++ b/src/librustc_codegen_llvm/lib.rs @@ -24,7 +24,6 @@ #![deny(rust_2018_idioms)] #![deny(internal)] #![deny(unused_lifetimes)] -#![allow(explicit_outlives_requirements)] use back::write::{create_target_machine, create_informational_target_machine}; use syntax_pos::symbol::Symbol; diff --git a/src/librustc_codegen_ssa/lib.rs b/src/librustc_codegen_ssa/lib.rs index 71393e224e42d..b76f098773f0b 100644 --- a/src/librustc_codegen_ssa/lib.rs +++ b/src/librustc_codegen_ssa/lib.rs @@ -15,7 +15,6 @@ #![deny(rust_2018_idioms)] #![deny(internal)] #![deny(unused_lifetimes)] -#![allow(explicit_outlives_requirements)] #![recursion_limit="256"] diff --git a/src/librustc_mir/dataflow/graphviz.rs b/src/librustc_mir/dataflow/graphviz.rs index f62ad2fbef71f..7896592eea685 100644 --- a/src/librustc_mir/dataflow/graphviz.rs +++ b/src/librustc_mir/dataflow/graphviz.rs @@ -30,7 +30,7 @@ impl<'a, 'tcx, BD> MirWithFlowState<'tcx> for DataflowBuilder<'a, 'tcx, BD> fn flow_state(&self) -> &DataflowState<'tcx, Self::BD> { &self.flow_state.flow_state } } -struct Graph<'a, 'tcx, MWF:'a, P> where +struct Graph<'a, 'tcx, MWF, P> where MWF: MirWithFlowState<'tcx> { mbcx: &'a MWF, diff --git a/src/librustc_mir/dataflow/mod.rs b/src/librustc_mir/dataflow/mod.rs index 0728d5b21bbd1..89b952e9f8b5a 100644 --- a/src/librustc_mir/dataflow/mod.rs +++ b/src/librustc_mir/dataflow/mod.rs @@ -181,7 +181,7 @@ where struct PropagationContext<'b, 'a, 'tcx, O> where - O: 'b + BitDenotation<'tcx>, + O: BitDenotation<'tcx>, { builder: &'b mut DataflowAnalysis<'a, 'tcx, O>, } diff --git a/src/librustc_mir/interpret/intern.rs b/src/librustc_mir/interpret/intern.rs index d998f40c86ecc..416b66daa0594 100644 --- a/src/librustc_mir/interpret/intern.rs +++ b/src/librustc_mir/interpret/intern.rs @@ -21,7 +21,7 @@ use super::{ }; use crate::const_eval::{CompileTimeInterpreter, CompileTimeEvalContext}; -struct InternVisitor<'rt, 'mir: 'rt, 'tcx: 'rt + 'mir> { +struct InternVisitor<'rt, 'mir, 'tcx> { /// previously encountered safe references ref_tracking: &'rt mut RefTracking<(MPlaceTy<'tcx>, Mutability, InternMode)>, ecx: &'rt mut CompileTimeEvalContext<'mir, 'tcx>, diff --git a/src/librustc_mir/lib.rs b/src/librustc_mir/lib.rs index a7cbe84330d89..cb02e1a778c93 100644 --- a/src/librustc_mir/lib.rs +++ b/src/librustc_mir/lib.rs @@ -30,7 +30,6 @@ Rust MIR: a lowered representation of Rust. Also: an experiment! #![deny(rust_2018_idioms)] #![deny(internal)] #![deny(unused_lifetimes)] -#![allow(explicit_outlives_requirements)] #[macro_use] extern crate log; #[macro_use] diff --git a/src/librustc_mir/util/elaborate_drops.rs b/src/librustc_mir/util/elaborate_drops.rs index 815d210d36ea4..91fc19b71d8ba 100644 --- a/src/librustc_mir/util/elaborate_drops.rs +++ b/src/librustc_mir/util/elaborate_drops.rs @@ -92,7 +92,7 @@ pub trait DropElaborator<'a, 'tcx>: fmt::Debug { #[derive(Debug)] struct DropCtxt<'l, 'b, 'tcx, D> where - D: DropElaborator<'b, 'tcx> + 'l, + D: DropElaborator<'b, 'tcx>, { elaborator: &'l mut D, diff --git a/src/librustc_typeck/lib.rs b/src/librustc_typeck/lib.rs index cc6f7a07d9621..ec0f431d9b25e 100644 --- a/src/librustc_typeck/lib.rs +++ b/src/librustc_typeck/lib.rs @@ -75,7 +75,6 @@ This API is completely unstable and subject to change. #![deny(rust_2018_idioms)] #![deny(internal)] #![deny(unused_lifetimes)] -#![allow(explicit_outlives_requirements)] #[macro_use] extern crate log; #[macro_use] extern crate syntax;