2018-07-29 13:41:43 +02:00
|
|
|
// no-system-llvm
|
2018-07-31 10:35:27 +02:00
|
|
|
// compile-flags: -O -C panic=abort
|
2018-07-29 13:41:43 +02:00
|
|
|
#![crate_type = "lib"]
|
|
|
|
|
|
|
|
fn search<T: Ord + Eq>(arr: &mut [T], a: &T) -> Result<usize, ()> {
|
|
|
|
match arr.iter().position(|x| x == a) {
|
|
|
|
Some(p) => {
|
|
|
|
Ok(p)
|
|
|
|
},
|
|
|
|
None => Err(()),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK-LABEL: @position_no_bounds_check
|
|
|
|
#[no_mangle]
|
|
|
|
pub fn position_no_bounds_check(y: &mut [u32], x: &u32, z: &u32) -> bool {
|
|
|
|
// This contains "call assume" so we cannot just rule out all calls
|
2018-07-31 10:35:27 +02:00
|
|
|
// CHECK-NOT: panic_bounds_check
|
2018-07-29 13:41:43 +02:00
|
|
|
if let Ok(p) = search(y, x) {
|
|
|
|
y[p] == *z
|
|
|
|
} else {
|
|
|
|
false
|
|
|
|
}
|
|
|
|
}
|
2018-07-29 22:29:49 +02:00
|
|
|
|
2018-07-31 10:35:27 +02:00
|
|
|
// just to make sure that panicking really emits "panic_bounds_check" somewhere in the IR
|
2018-07-29 22:29:49 +02:00
|
|
|
// CHECK-LABEL: @test_check
|
|
|
|
#[no_mangle]
|
2018-07-31 10:35:27 +02:00
|
|
|
pub fn test_check(y: &[i32]) -> i32 {
|
|
|
|
// CHECK: panic_bounds_check
|
|
|
|
y[12]
|
2018-07-29 22:29:49 +02:00
|
|
|
}
|