about summary refs log tree commit diff
path: root/tests/codegen
diff options
context:
space:
mode:
authorbendn <bend.n@outlook.com>2023-10-19 06:46:28 +0700
committerbendn <bend.n@outlook.com>2023-12-04 06:00:12 +0700
commit73afc00cf99f9db95dc35b0bd33604c3879ca3e7 (patch)
tree3d8d59c45704f9ee60a2cb724b5c85997716edac /tests/codegen
parent9fad6859925b34f9a0b1af592a7839ccb1e71f60 (diff)
downloadrust-73afc00cf99f9db95dc35b0bd33604c3879ca3e7.tar.gz
rust-73afc00cf99f9db95dc35b0bd33604c3879ca3e7.zip
use `assume(idx < self.len())` in `[T]::get_unchecked`
Diffstat (limited to 'tests/codegen')
-rw-r--r--tests/codegen/issues/issue-116878.rs13
1 files changed, 13 insertions, 0 deletions
diff --git a/tests/codegen/issues/issue-116878.rs b/tests/codegen/issues/issue-116878.rs
new file mode 100644
index 00000000000..d5f679459f7
--- /dev/null
+++ b/tests/codegen/issues/issue-116878.rs
@@ -0,0 +1,13 @@
+// no-system-llvm
+// compile-flags: -O
+// ignore-debug: the debug assertions get in the way
+#![crate_type = "lib"]
+
+/// Make sure no bounds checks are emitted after a `get_unchecked`.
+// CHECK-LABEL: @unchecked_slice_no_bounds_check
+#[no_mangle]
+pub unsafe fn unchecked_slice_no_bounds_check(s: &[u8]) -> u8 {
+    let a = *s.get_unchecked(1);
+    // CHECK-NOT: panic_bounds_check
+    a + s[0]
+}