From 715b8852e4a94875683c41771e45043d579065ce Mon Sep 17 00:00:00 2001 From: ljedrz Date: Wed, 11 Jul 2018 17:39:49 +0200 Subject: [PATCH] Deny bare trait objects in in src/librustc_codegen_utils --- src/librustc_codegen_utils/codegen_backend.rs | 24 +++++++++---------- src/librustc_codegen_utils/lib.rs | 1 + 2 files changed, 13 insertions(+), 12 deletions(-) diff --git a/src/librustc_codegen_utils/codegen_backend.rs b/src/librustc_codegen_utils/codegen_backend.rs index 57e6c0d7b85e1..3f230dd5d451b 100644 --- a/src/librustc_codegen_utils/codegen_backend.rs +++ b/src/librustc_codegen_utils/codegen_backend.rs @@ -56,23 +56,23 @@ pub trait CodegenBackend { fn print_version(&self) {} fn diagnostics(&self) -> &[(&'static str, &'static str)] { &[] } - fn metadata_loader(&self) -> Box; + fn metadata_loader(&self) -> Box; fn provide(&self, _providers: &mut Providers); fn provide_extern(&self, _providers: &mut Providers); fn codegen_crate<'a, 'tcx>( &self, tcx: TyCtxt<'a, 'tcx, 'tcx>, - rx: mpsc::Receiver> - ) -> Box; + rx: mpsc::Receiver> + ) -> Box; - /// This is called on the returned `Box` from `codegen_backend` + /// This is called on the returned `Box` from `codegen_backend` /// /// # Panics /// - /// Panics when the passed `Box` was not returned by `codegen_backend`. + /// Panics when the passed `Box` was not returned by `codegen_backend`. fn join_codegen_and_link( &self, - ongoing_codegen: Box, + ongoing_codegen: Box, sess: &Session, dep_graph: &DepGraph, outputs: &OutputFilenames, @@ -105,7 +105,7 @@ pub struct OngoingCodegen { } impl MetadataOnlyCodegenBackend { - pub fn new() -> Box { + pub fn new() -> Box { box MetadataOnlyCodegenBackend(()) } } @@ -125,7 +125,7 @@ impl CodegenBackend for MetadataOnlyCodegenBackend { } } - fn metadata_loader(&self) -> Box { + fn metadata_loader(&self) -> Box { box NoLlvmMetadataLoader } @@ -145,8 +145,8 @@ impl CodegenBackend for MetadataOnlyCodegenBackend { fn codegen_crate<'a, 'tcx>( &self, tcx: TyCtxt<'a, 'tcx, 'tcx>, - _rx: mpsc::Receiver> - ) -> Box { + _rx: mpsc::Receiver> + ) -> Box { use rustc_mir::monomorphize::item::MonoItem; ::check_for_rustc_errors_attr(tcx); @@ -193,13 +193,13 @@ impl CodegenBackend for MetadataOnlyCodegenBackend { fn join_codegen_and_link( &self, - ongoing_codegen: Box, + ongoing_codegen: Box, sess: &Session, _dep_graph: &DepGraph, outputs: &OutputFilenames, ) -> Result<(), CompileIncomplete> { let ongoing_codegen = ongoing_codegen.downcast::() - .expect("Expected MetadataOnlyCodegenBackend's OngoingCodegen, found Box"); + .expect("Expected MetadataOnlyCodegenBackend's OngoingCodegen, found Box"); for &crate_type in sess.opts.crate_types.iter() { if crate_type != CrateType::CrateTypeRlib && crate_type != CrateType::CrateTypeDylib { continue; diff --git a/src/librustc_codegen_utils/lib.rs b/src/librustc_codegen_utils/lib.rs index f59cf5832fcb4..e9031007a4eed 100644 --- a/src/librustc_codegen_utils/lib.rs +++ b/src/librustc_codegen_utils/lib.rs @@ -20,6 +20,7 @@ #![feature(box_syntax)] #![feature(custom_attribute)] #![allow(unused_attributes)] +#![deny(bare_trait_objects)] #![feature(quote)] #![feature(rustc_diagnostic_macros)]