Auto merge of #29882 - devonhollowood:master, r=Manishearth

Implement #14615
This commit is contained in:
bors 2015-11-18 02:02:00 +00:00
commit 50b969d3b2
7 changed files with 2 additions and 148 deletions

View File

@ -66,7 +66,6 @@
#![doc(test(no_crate_inject, attr(allow(unused_variables), deny(warnings))))]
#![no_core]
#![allow(raw_pointer_derive)]
#![deny(missing_docs)]
#![feature(allow_internal_unstable)]

@ -1 +1 @@
Subproject commit b1a043feeae3a67f45e75eaf10aa900a1f6832f9
Subproject commit 8531cc11e196b7ae9072ae7b384a930ff7b00dfb

View File

@ -46,7 +46,7 @@ use syntax::attr::{self, AttrMetaMethods};
use syntax::codemap::{self, Span};
use rustc_front::hir;
use rustc_front::visit::{self, FnKind, Visitor};
use rustc_front::visit::FnKind;
use bad_style::{MethodLateContext, method_context};
@ -138,92 +138,6 @@ impl LateLintPass for BoxPointers {
}
}
declare_lint! {
RAW_POINTER_DERIVE,
Warn,
"uses of #[derive] with raw pointers are rarely correct"
}
struct RawPtrDeriveVisitor<'a, 'tcx: 'a> {
cx: &'a LateContext<'a, 'tcx>
}
impl<'a, 'tcx, 'v> Visitor<'v> for RawPtrDeriveVisitor<'a, 'tcx> {
fn visit_ty(&mut self, ty: &hir::Ty) {
const MSG: &'static str = "use of `#[derive]` with a raw pointer";
if let hir::TyPtr(..) = ty.node {
self.cx.span_lint(RAW_POINTER_DERIVE, ty.span, MSG);
}
visit::walk_ty(self, ty);
}
// explicit override to a no-op to reduce code bloat
fn visit_expr(&mut self, _: &hir::Expr) {}
fn visit_block(&mut self, _: &hir::Block) {}
}
pub struct RawPointerDerive {
checked_raw_pointers: NodeSet,
}
impl RawPointerDerive {
pub fn new() -> RawPointerDerive {
RawPointerDerive {
checked_raw_pointers: NodeSet(),
}
}
}
impl LintPass for RawPointerDerive {
fn get_lints(&self) -> LintArray {
lint_array!(RAW_POINTER_DERIVE)
}
}
impl LateLintPass for RawPointerDerive {
fn check_item(&mut self, cx: &LateContext, item: &hir::Item) {
if !attr::contains_name(&item.attrs, "automatically_derived") {
return;
}
let did = match item.node {
hir::ItemImpl(_, _, _, ref t_ref_opt, _, _) => {
// Deriving the Copy trait does not cause a warning
if let &Some(ref trait_ref) = t_ref_opt {
let def_id = cx.tcx.trait_ref_to_def_id(trait_ref);
if Some(def_id) == cx.tcx.lang_items.copy_trait() {
return;
}
}
match cx.tcx.node_id_to_type(item.id).sty {
ty::TyEnum(def, _) => def.did,
ty::TyStruct(def, _) => def.did,
_ => return,
}
}
_ => return,
};
let node_id = if let Some(node_id) = cx.tcx.map.as_local_node_id(did) {
node_id
} else {
return;
};
let item = match cx.tcx.map.find(node_id) {
Some(hir_map::NodeItem(item)) => item,
_ => return,
};
if !self.checked_raw_pointers.insert(item.id) {
return;
}
match item.node {
hir::ItemStruct(..) | hir::ItemEnum(..) => {
let mut visitor = RawPtrDeriveVisitor { cx: cx };
visit::walk_item(&mut visitor, &item);
}
_ => {}
}
}
}
declare_lint! {
NON_SHORTHAND_FIELD_PATTERNS,
Warn,

View File

@ -135,7 +135,6 @@ pub fn register_builtins(store: &mut lint::LintStore, sess: Option<&Session>) {
add_builtin_with_new!(sess,
TypeLimits,
RawPointerDerive,
MissingDoc,
MissingDebugImplementations,
);
@ -152,8 +151,6 @@ pub fn register_builtins(store: &mut lint::LintStore, sess: Option<&Session>) {
store.register_late_pass(sess, false, box lint::GatherNodeLevels);
// Insert temporary renamings for a one-time deprecation
store.register_renamed("raw_pointer_deriving", "raw_pointer_derive");
store.register_renamed("unknown_features", "unused_features");
store.register_removed("unsigned_negation", "replaced by negate_unsigned feature gate");

View File

@ -37,7 +37,6 @@ impl OptimizationDiagnosticKind {
}
}
#[allow(raw_pointer_derive)]
#[derive(Copy, Clone)]
pub struct OptimizationDiagnostic {
pub kind: OptimizationDiagnosticKind,

View File

@ -1,34 +0,0 @@
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
// 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.
#![allow(dead_code)]
#![deny(raw_pointer_derive)]
#[derive(Clone)]
struct Foo {
x: *const isize //~ ERROR use of `#[derive]` with a raw pointer
}
#[derive(Clone)]
struct Bar(*mut isize); //~ ERROR use of `#[derive]` with a raw pointer
#[derive(Clone)]
enum Baz {
A(*const isize), //~ ERROR use of `#[derive]` with a raw pointer
B { x: *mut isize } //~ ERROR use of `#[derive]` with a raw pointer
}
#[derive(Clone)]
struct Buzz {
x: (*const isize, //~ ERROR use of `#[derive]` with a raw pointer
*const usize) //~ ERROR use of `#[derive]` with a raw pointer
}
fn main() {}

View File

@ -1,21 +0,0 @@
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
// 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.
// pretty-expanded FIXME #23616
#[forbid(raw_pointer_derive)]
#[derive(Copy)]
struct Test(*const i32);
impl Clone for Test {
fn clone(&self) -> Test { *self }
}
fn main() {}