2013-04-09 01:31:10 -04:00
|
|
|
// 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.
|
|
|
|
|
|
|
|
// Exercise the unused_unsafe attribute in some positive and negative cases
|
|
|
|
|
2013-12-08 02:55:27 -05:00
|
|
|
#[allow(dead_code)];
|
2013-04-09 01:31:10 -04:00
|
|
|
#[deny(unused_unsafe)];
|
2014-03-13 18:53:14 +11:00
|
|
|
#[allow(deprecated_owned_vector)];
|
2013-04-09 01:31:10 -04:00
|
|
|
|
2013-05-09 14:14:42 -07:00
|
|
|
mod foo {
|
2013-07-18 19:08:57 -07:00
|
|
|
extern {
|
2013-05-09 14:14:42 -07:00
|
|
|
pub fn bar();
|
|
|
|
}
|
2013-04-23 11:11:50 -04:00
|
|
|
}
|
2013-04-09 01:31:10 -04:00
|
|
|
|
2013-11-19 16:34:19 -08:00
|
|
|
fn callback<T>(_f: || -> T) -> T { fail!() }
|
2013-04-23 11:11:50 -04:00
|
|
|
unsafe fn unsf() {}
|
2013-04-09 01:31:10 -04:00
|
|
|
|
2013-04-23 02:06:47 -04:00
|
|
|
fn bad1() { unsafe {} } //~ ERROR: unnecessary `unsafe` block
|
|
|
|
fn bad2() { unsafe { bad1() } } //~ ERROR: unnecessary `unsafe` block
|
2013-04-23 11:11:50 -04:00
|
|
|
unsafe fn bad3() { unsafe {} } //~ ERROR: unnecessary `unsafe` block
|
2013-11-21 17:23:21 -08:00
|
|
|
fn bad4() { unsafe { callback(||{}) } } //~ ERROR: unnecessary `unsafe` block
|
2013-04-23 11:11:50 -04:00
|
|
|
unsafe fn bad5() { unsafe { unsf() } } //~ ERROR: unnecessary `unsafe` block
|
|
|
|
fn bad6() {
|
2013-05-24 19:35:29 -07:00
|
|
|
unsafe { // don't put the warning here
|
|
|
|
unsafe { //~ ERROR: unnecessary `unsafe` block
|
2013-04-23 11:11:50 -04:00
|
|
|
unsf()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
unsafe fn bad7() {
|
|
|
|
unsafe { //~ ERROR: unnecessary `unsafe` block
|
|
|
|
unsafe { //~ ERROR: unnecessary `unsafe` block
|
|
|
|
unsf()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2013-04-09 01:31:10 -04:00
|
|
|
|
2013-04-23 11:11:50 -04:00
|
|
|
unsafe fn good0() { unsf() }
|
|
|
|
fn good1() { unsafe { unsf() } }
|
2013-04-09 01:31:10 -04:00
|
|
|
fn good2() {
|
|
|
|
/* bug uncovered when implementing warning about unused unsafe blocks. Be
|
|
|
|
sure that when purity is inherited that the source of the unsafe-ness
|
|
|
|
is tracked correctly */
|
|
|
|
unsafe {
|
2013-10-21 13:08:31 -07:00
|
|
|
unsafe fn what() -> ~[~str] { fail!() }
|
2013-04-09 01:31:10 -04:00
|
|
|
|
2013-11-21 17:23:21 -08:00
|
|
|
callback(|| {
|
2013-04-09 01:31:10 -04:00
|
|
|
what();
|
2013-11-21 17:23:21 -08:00
|
|
|
});
|
2013-04-09 01:31:10 -04:00
|
|
|
}
|
|
|
|
}
|
2013-08-14 21:41:40 -04:00
|
|
|
|
2013-04-23 11:11:50 -04:00
|
|
|
unsafe fn good3() { foo::bar() }
|
|
|
|
fn good4() { unsafe { foo::bar() } }
|
2013-04-09 01:31:10 -04:00
|
|
|
|
2013-04-20 15:51:29 -04:00
|
|
|
#[allow(unused_unsafe)] fn allowed() { unsafe {} }
|
2013-04-09 01:31:10 -04:00
|
|
|
|
2013-04-23 11:11:50 -04:00
|
|
|
fn main() {}
|