summaryrefslogtreecommitdiffstats
path: root/src/test/codegen/slice-position-bounds-check.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/codegen/slice-position-bounds-check.rs')
-rw-r--r--src/test/codegen/slice-position-bounds-check.rs32
1 files changed, 0 insertions, 32 deletions
diff --git a/src/test/codegen/slice-position-bounds-check.rs b/src/test/codegen/slice-position-bounds-check.rs
deleted file mode 100644
index b494f42b2..000000000
--- a/src/test/codegen/slice-position-bounds-check.rs
+++ /dev/null
@@ -1,32 +0,0 @@
-// no-system-llvm
-// compile-flags: -O -C panic=abort
-#![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
- // CHECK-NOT: panic_bounds_check
- if let Ok(p) = search(y, x) {
- y[p] == *z
- } else {
- false
- }
-}
-
-// just to make sure that panicking really emits "panic_bounds_check" somewhere in the IR
-// CHECK-LABEL: @test_check
-#[no_mangle]
-pub fn test_check(y: &[i32]) -> i32 {
- // CHECK: panic_bounds_check
- y[12]
-}