forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Rollup merge of rust-lang#75886 - erikdesjardins:index, r=nikic
Test that bounds checks are elided for [..index] after .position() Closes rust-lang#73396. This was fixed by the LLVM 11 update in rust-lang#73526.
- Loading branch information
Showing
1 changed file
with
78 additions
and
0 deletions.
There are no files selected for viewing
78 changes: 78 additions & 0 deletions
78
src/test/codegen/issue-73396-bounds-check-after-position.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
// min-llvm-version: 11.0.0 | ||
// 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 `position()` or `rposition()`. | ||
|
||
// CHECK-LABEL: @position_slice_to_no_bounds_check | ||
#[no_mangle] | ||
pub fn position_slice_to_no_bounds_check(s: &[u8]) -> &[u8] { | ||
// CHECK-NOT: panic | ||
// CHECK-NOT: slice_index_len_fail | ||
if let Some(idx) = s.iter().position(|b| *b == b'\\') { | ||
&s[..idx] | ||
} else { | ||
s | ||
} | ||
} | ||
|
||
// CHECK-LABEL: @position_slice_from_no_bounds_check | ||
#[no_mangle] | ||
pub fn position_slice_from_no_bounds_check(s: &[u8]) -> &[u8] { | ||
// CHECK-NOT: panic | ||
// CHECK-NOT: slice_index_len_fail | ||
if let Some(idx) = s.iter().position(|b| *b == b'\\') { | ||
&s[idx..] | ||
} else { | ||
s | ||
} | ||
} | ||
|
||
// CHECK-LABEL: @position_index_no_bounds_check | ||
#[no_mangle] | ||
pub fn position_index_no_bounds_check(s: &[u8]) -> u8 { | ||
// CHECK-NOT: panic | ||
// CHECK-NOT: slice_index_len_fail | ||
if let Some(idx) = s.iter().position(|b| *b == b'\\') { | ||
s[idx] | ||
} else { | ||
42 | ||
} | ||
} | ||
// CHECK-LABEL: @rposition_slice_to_no_bounds_check | ||
#[no_mangle] | ||
pub fn rposition_slice_to_no_bounds_check(s: &[u8]) -> &[u8] { | ||
// CHECK-NOT: panic | ||
// CHECK-NOT: slice_index_len_fail | ||
if let Some(idx) = s.iter().rposition(|b| *b == b'\\') { | ||
&s[..idx] | ||
} else { | ||
s | ||
} | ||
} | ||
|
||
// CHECK-LABEL: @rposition_slice_from_no_bounds_check | ||
#[no_mangle] | ||
pub fn rposition_slice_from_no_bounds_check(s: &[u8]) -> &[u8] { | ||
// CHECK-NOT: panic | ||
// CHECK-NOT: slice_index_len_fail | ||
if let Some(idx) = s.iter().rposition(|b| *b == b'\\') { | ||
&s[idx..] | ||
} else { | ||
s | ||
} | ||
} | ||
|
||
// CHECK-LABEL: @rposition_index_no_bounds_check | ||
#[no_mangle] | ||
pub fn rposition_index_no_bounds_check(s: &[u8]) -> u8 { | ||
// CHECK-NOT: panic | ||
// CHECK-NOT: slice_index_len_fail | ||
if let Some(idx) = s.iter().rposition(|b| *b == b'\\') { | ||
s[idx] | ||
} else { | ||
42 | ||
} | ||
} |