auto merge of #10599 : thestinger/rust/unsafe, r=cmr
This is just meant to be for containing usage of `unsafe`, much like `heap_memory`.
This commit is contained in:
commit
1dea21f41d
@ -75,6 +75,7 @@ pub enum lint {
|
|||||||
type_limits,
|
type_limits,
|
||||||
type_overflow,
|
type_overflow,
|
||||||
unused_unsafe,
|
unused_unsafe,
|
||||||
|
unsafe_block,
|
||||||
|
|
||||||
managed_heap_memory,
|
managed_heap_memory,
|
||||||
owned_heap_memory,
|
owned_heap_memory,
|
||||||
@ -236,6 +237,13 @@ static lint_table: &'static [(&'static str, LintSpec)] = &[
|
|||||||
default: warn
|
default: warn
|
||||||
}),
|
}),
|
||||||
|
|
||||||
|
("unsafe_block",
|
||||||
|
LintSpec {
|
||||||
|
lint: unsafe_block,
|
||||||
|
desc: "usage of an `unsafe` block",
|
||||||
|
default: allow
|
||||||
|
}),
|
||||||
|
|
||||||
("unused_variable",
|
("unused_variable",
|
||||||
LintSpec {
|
LintSpec {
|
||||||
lint: unused_variable,
|
lint: unused_variable,
|
||||||
@ -870,8 +878,7 @@ fn check_pat_non_uppercase_statics(cx: &Context, p: &ast::Pat) {
|
|||||||
|
|
||||||
fn check_unused_unsafe(cx: &Context, e: &ast::Expr) {
|
fn check_unused_unsafe(cx: &Context, e: &ast::Expr) {
|
||||||
match e.node {
|
match e.node {
|
||||||
// Don't warn about generated blocks, that'll just pollute the
|
// Don't warn about generated blocks, that'll just pollute the output.
|
||||||
// output.
|
|
||||||
ast::ExprBlock(ref blk) => {
|
ast::ExprBlock(ref blk) => {
|
||||||
if blk.rules == ast::UnsafeBlock(ast::UserProvided) &&
|
if blk.rules == ast::UnsafeBlock(ast::UserProvided) &&
|
||||||
!cx.tcx.used_unsafe.contains(&blk.id) {
|
!cx.tcx.used_unsafe.contains(&blk.id) {
|
||||||
@ -883,6 +890,16 @@ fn check_unused_unsafe(cx: &Context, e: &ast::Expr) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn check_unsafe_block(cx: &Context, e: &ast::Expr) {
|
||||||
|
match e.node {
|
||||||
|
// Don't warn about generated blocks, that'll just pollute the output.
|
||||||
|
ast::ExprBlock(ref blk) if blk.rules == ast::UnsafeBlock(ast::UserProvided) => {
|
||||||
|
cx.span_lint(unsafe_block, blk.span, "usage of an `unsafe` block");
|
||||||
|
}
|
||||||
|
_ => ()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fn check_unused_mut_pat(cx: &Context, p: @ast::Pat) {
|
fn check_unused_mut_pat(cx: &Context, p: @ast::Pat) {
|
||||||
match p.node {
|
match p.node {
|
||||||
ast::PatIdent(ast::BindByValue(ast::MutMutable),
|
ast::PatIdent(ast::BindByValue(ast::MutMutable),
|
||||||
@ -1126,6 +1143,7 @@ impl<'self> Visitor<()> for Context<'self> {
|
|||||||
check_while_true_expr(self, e);
|
check_while_true_expr(self, e);
|
||||||
check_stability(self, e);
|
check_stability(self, e);
|
||||||
check_unused_unsafe(self, e);
|
check_unused_unsafe(self, e);
|
||||||
|
check_unsafe_block(self, e);
|
||||||
check_unnecessary_allocation(self, e);
|
check_unnecessary_allocation(self, e);
|
||||||
check_heap_expr(self, e);
|
check_heap_expr(self, e);
|
||||||
|
|
||||||
|
20
src/test/compile-fail/lint-unsafe-block.rs
Normal file
20
src/test/compile-fail/lint-unsafe-block.rs
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
// 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(unused_unsafe)];
|
||||||
|
#[deny(unsafe_block)];
|
||||||
|
|
||||||
|
unsafe fn allowed() {}
|
||||||
|
|
||||||
|
#[allow(unsafe_block)] fn also_allowed() { unsafe {} }
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
unsafe {} //~ ERROR: usage of an `unsafe` block
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user