mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-25 16:24:46 +00:00
a9570a34cd
A couple of codegen tests are doing ``` // CHECK-NOT: slice_index_len_fail ``` However, that function no longer exists: [the only places](https://github.com/search?q=repo%3Arust-lang%2Frust+slice_index_len_fail&type=code) it occurs in the repo are in those tests. So this PR updates the tests to check for the absense of the functions that are actually used today to panic for out-of-bounds indexing.
41 lines
1.2 KiB
Rust
41 lines
1.2 KiB
Rust
// compile-flags: -O
|
|
// ignore-debug: the debug assertions get in the way
|
|
#![crate_type = "lib"]
|
|
|
|
// Make sure no bounds checks are emitted when slicing or indexing
|
|
// with an index from `binary_search`.
|
|
|
|
// CHECK-LABEL: @binary_search_index_no_bounds_check
|
|
#[no_mangle]
|
|
pub fn binary_search_index_no_bounds_check(s: &[u8]) -> u8 {
|
|
// CHECK-NOT: panic
|
|
// CHECK-NOT: slice_start_index_len_fail
|
|
// CHECK-NOT: slice_end_index_len_fail
|
|
// CHECK-NOT: panic_bounds_check
|
|
if let Ok(idx) = s.binary_search(&b'\\') {
|
|
s[idx]
|
|
} else {
|
|
42
|
|
}
|
|
}
|
|
|
|
// Similarly, check that `partition_point` is known to return a valid fencepost.
|
|
|
|
// CHECK-LABEL: @unknown_split
|
|
#[no_mangle]
|
|
pub fn unknown_split(x: &[i32], i: usize) -> (&[i32], &[i32]) {
|
|
// This just makes sure that the subsequent function is looking for the
|
|
// absence of something that might actually be there.
|
|
|
|
// CHECK: call core::panicking::panic
|
|
x.split_at(i)
|
|
}
|
|
|
|
// CHECK-LABEL: @partition_point_split_no_bounds_check
|
|
#[no_mangle]
|
|
pub fn partition_point_split_no_bounds_check(x: &[i32], needle: i32) -> (&[i32], &[i32]) {
|
|
// CHECK-NOT: call core::panicking::panic
|
|
let i = x.partition_point(|p| p < &needle);
|
|
x.split_at(i)
|
|
}
|