2013-12-08 01:55:27 -06: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.
|
|
|
|
|
2014-03-21 20:05:05 -05:00
|
|
|
#![no_std]
|
|
|
|
#![allow(unused_variable)]
|
|
|
|
#![allow(non_camel_case_types)]
|
|
|
|
#![allow(visible_private_types)]
|
|
|
|
#![deny(dead_code)]
|
2013-12-08 01:55:27 -06:00
|
|
|
|
2014-03-21 20:05:05 -05:00
|
|
|
#![crate_type="lib"]
|
2013-12-08 01:55:27 -06:00
|
|
|
|
|
|
|
pub use foo2::Bar2;
|
2014-04-02 19:38:45 -05:00
|
|
|
|
|
|
|
#[lang="sized"]
|
|
|
|
pub trait Sized {}
|
|
|
|
|
2013-12-08 01:55:27 -06:00
|
|
|
mod foo {
|
|
|
|
pub struct Bar; //~ ERROR: code is never used
|
|
|
|
}
|
|
|
|
|
|
|
|
mod foo2 {
|
|
|
|
pub struct Bar2;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub static pub_static: int = 0;
|
|
|
|
static priv_static: int = 0; //~ ERROR: code is never used
|
|
|
|
static used_static: int = 0;
|
|
|
|
pub static used_static2: int = used_static;
|
2013-12-11 19:49:46 -06:00
|
|
|
static USED_STATIC: int = 0;
|
2013-12-16 01:15:00 -06:00
|
|
|
static STATIC_USED_IN_ENUM_DISCRIMINANT: uint = 10;
|
2013-12-08 01:55:27 -06:00
|
|
|
|
2014-05-05 20:56:44 -05:00
|
|
|
pub type typ = *UsedStruct4;
|
2013-12-08 01:55:27 -06:00
|
|
|
pub struct PubStruct();
|
|
|
|
struct PrivStruct; //~ ERROR: code is never used
|
2014-06-06 08:51:42 -05:00
|
|
|
struct UsedStruct1 {
|
|
|
|
#[allow(dead_code)]
|
|
|
|
x: int
|
|
|
|
}
|
2013-12-08 01:55:27 -06:00
|
|
|
struct UsedStruct2(int);
|
|
|
|
struct UsedStruct3;
|
|
|
|
struct UsedStruct4;
|
|
|
|
// this struct is never used directly, but its method is, so we don't want
|
|
|
|
// to warn it
|
|
|
|
struct SemiUsedStruct;
|
|
|
|
impl SemiUsedStruct {
|
|
|
|
fn la_la_la() {}
|
|
|
|
}
|
2013-12-16 01:15:00 -06:00
|
|
|
struct StructUsedAsField;
|
|
|
|
struct StructUsedInEnum;
|
2013-12-16 17:01:36 -06:00
|
|
|
struct StructUsedInGeneric;
|
2013-12-16 01:15:00 -06:00
|
|
|
pub struct PubStruct2 {
|
2014-06-06 08:51:42 -05:00
|
|
|
#[allow(dead_code)]
|
2013-12-16 01:15:00 -06:00
|
|
|
struct_used_as_field: *StructUsedAsField
|
|
|
|
}
|
2013-12-08 01:55:27 -06:00
|
|
|
|
|
|
|
pub enum pub_enum { foo1, bar1 }
|
2014-05-05 20:56:44 -05:00
|
|
|
pub enum pub_enum2 { a(*StructUsedInEnum) }
|
2013-12-16 01:15:00 -06:00
|
|
|
pub enum pub_enum3 { Foo = STATIC_USED_IN_ENUM_DISCRIMINANT }
|
2013-12-08 01:55:27 -06:00
|
|
|
enum priv_enum { foo2, bar2 } //~ ERROR: code is never used
|
|
|
|
enum used_enum { foo3, bar3 }
|
|
|
|
|
2013-12-16 17:01:36 -06:00
|
|
|
fn f<T>() {}
|
|
|
|
|
2013-12-11 19:49:46 -06:00
|
|
|
pub fn pub_fn() {
|
|
|
|
used_fn();
|
|
|
|
let used_struct1 = UsedStruct1 { x: 1 };
|
|
|
|
let used_struct2 = UsedStruct2(1);
|
|
|
|
let used_struct3 = UsedStruct3;
|
|
|
|
let e = foo3;
|
|
|
|
SemiUsedStruct::la_la_la();
|
|
|
|
|
|
|
|
let i = 1;
|
|
|
|
match i {
|
|
|
|
USED_STATIC => (),
|
|
|
|
_ => ()
|
|
|
|
}
|
2013-12-16 17:01:36 -06:00
|
|
|
f::<StructUsedInGeneric>();
|
2013-12-11 19:49:46 -06:00
|
|
|
}
|
|
|
|
fn priv_fn() { //~ ERROR: code is never used
|
|
|
|
let unused_struct = PrivStruct;
|
|
|
|
}
|
|
|
|
fn used_fn() {}
|
|
|
|
|
2013-12-08 01:55:27 -06:00
|
|
|
fn foo() { //~ ERROR: code is never used
|
|
|
|
bar();
|
|
|
|
let unused_enum = foo2;
|
|
|
|
}
|
|
|
|
|
|
|
|
fn bar() { //~ ERROR: code is never used
|
|
|
|
foo();
|
|
|
|
}
|
2014-01-11 02:21:53 -06:00
|
|
|
|
|
|
|
// Code with #[allow(dead_code)] should be marked live (and thus anything it
|
|
|
|
// calls is marked live)
|
|
|
|
#[allow(dead_code)]
|
|
|
|
fn g() { h(); }
|
|
|
|
fn h() {}
|
|
|
|
|
|
|
|
// Similarly, lang items are live
|
|
|
|
#[lang="fail_"]
|
|
|
|
fn fail(_: *u8, _: *u8, _: uint) -> ! { loop {} }
|