2015-08-20 00:04:01 +02:00
|
|
|
#![feature(plugin)]
|
|
|
|
#![plugin(clippy)]
|
|
|
|
|
2017-05-17 14:19:44 +02:00
|
|
|
#[warn(cast_precision_loss, cast_possible_truncation, cast_sign_loss, cast_possible_wrap)]
|
2016-05-13 16:43:47 +02:00
|
|
|
#[allow(no_effect, unnecessary_operation)]
|
2015-08-20 00:04:01 +02:00
|
|
|
fn main() {
|
|
|
|
// Test cast_precision_loss
|
2017-02-08 14:58:07 +01:00
|
|
|
1i32 as f32;
|
|
|
|
1i64 as f32;
|
|
|
|
1i64 as f64;
|
|
|
|
1u32 as f32;
|
|
|
|
1u64 as f32;
|
|
|
|
1u64 as f64;
|
2015-08-22 21:36:54 +02:00
|
|
|
1i32 as f64; // Should not trigger the lint
|
|
|
|
1u32 as f64; // Should not trigger the lint
|
2015-08-20 22:44:40 +02:00
|
|
|
// Test cast_possible_truncation
|
2017-02-08 14:58:07 +01:00
|
|
|
1f32 as i32;
|
|
|
|
1f32 as u32;
|
|
|
|
1f64 as f32;
|
|
|
|
1i32 as i8;
|
|
|
|
1i32 as u8;
|
|
|
|
1f64 as isize;
|
|
|
|
1f64 as usize;
|
2015-08-22 21:36:54 +02:00
|
|
|
// Test cast_possible_wrap
|
2017-02-08 14:58:07 +01:00
|
|
|
1u8 as i8;
|
|
|
|
1u16 as i16;
|
|
|
|
1u32 as i32;
|
|
|
|
1u64 as i64;
|
|
|
|
1usize as isize;
|
2015-08-20 00:04:01 +02:00
|
|
|
// Test cast_sign_loss
|
2017-02-08 14:58:07 +01:00
|
|
|
1i32 as u32;
|
|
|
|
1isize as usize;
|
2015-08-22 21:36:54 +02:00
|
|
|
// Extra checks for *size
|
|
|
|
// Casting from *size
|
2017-02-08 14:58:07 +01:00
|
|
|
1isize as i8;
|
|
|
|
1isize as f64;
|
|
|
|
1usize as f64;
|
|
|
|
1isize as f32;
|
|
|
|
1usize as f32;
|
|
|
|
1isize as i32;
|
|
|
|
1isize as u32;
|
|
|
|
1usize as u32;
|
|
|
|
1usize as i32;
|
2015-08-22 21:36:54 +02:00
|
|
|
// Casting to *size
|
2017-02-08 14:58:07 +01:00
|
|
|
1i64 as isize;
|
|
|
|
1i64 as usize;
|
|
|
|
1u64 as isize;
|
|
|
|
1u64 as usize;
|
|
|
|
1u32 as isize;
|
2015-08-22 23:49:03 +02:00
|
|
|
1u32 as usize; // Should not trigger any lint
|
|
|
|
1i32 as isize; // Neither should this
|
2017-02-08 14:58:07 +01:00
|
|
|
1i32 as usize;
|
2017-02-15 22:20:20 +08:00
|
|
|
// Test cast_unnecessary
|
|
|
|
1i32 as i32;
|
|
|
|
1f32 as f32;
|
|
|
|
false as bool;
|
|
|
|
&1i32 as &i32;
|
2017-02-16 22:55:41 +08:00
|
|
|
// Should not trigger
|
|
|
|
1i32 as i64;
|
2017-02-15 22:20:20 +08:00
|
|
|
let v = vec!(1);
|
2017-02-16 22:55:41 +08:00
|
|
|
&v as &[i32];
|
|
|
|
1.0 as f64;
|
|
|
|
1 as u64;
|
2015-09-28 07:11:03 +02:00
|
|
|
}
|