rust/tests/codegen/issues/issue-45964-bounds-check-slice-pos.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

40 lines
830 B
Rust
Raw Normal View History

2020-10-22 17:12:20 -05:00
// This test case checks that slice::{r}position functions do not
// prevent optimizing away bounds checks
// compile-flags: -O
// ignore-debug: the debug assertions get in the way
2020-10-22 17:12:20 -05:00
#![crate_type="rlib"]
// CHECK-LABEL: @test
#[no_mangle]
pub fn test(y: &[u32], x: &u32, z: &u32) -> bool {
let result = match y.iter().position(|a| a == x) {
Some(p) => Ok(p),
None => Err(()),
};
if let Ok(p) = result {
// CHECK-NOT: panic
y[p] == *z
} else {
false
}
}
// CHECK-LABEL: @rtest
#[no_mangle]
pub fn rtest(y: &[u32], x: &u32, z: &u32) -> bool {
let result = match y.iter().rposition(|a| a == x) {
Some(p) => Ok(p),
None => Err(()),
};
if let Ok(p) = result {
// CHECK-NOT: panic
y[p] == *z
} else {
false
}
}