forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 7
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of rust-lang#106967 - saethlin:remove-vec-as-ptr-assume, r…
…=thomcc Remove the assume(!is_null) from Vec::as_ptr At a guess, this code is leftover from LLVM was worse at keeping track of the niche information here. In any case, we don't need this anymore: Removing this `assume` doesn't get rid of the `nonnull` attribute on the return type.
- Loading branch information
Showing
2 changed files
with
21 additions
and
11 deletions.
There are no files selected for viewing
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
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,19 @@ | ||
// compile-flags: -O -Zmerge-functions=disabled | ||
|
||
#![crate_type = "lib"] | ||
|
||
// Test that even though we return a *const u8 not a &[u8] or a NonNull<u8>, LLVM knows that this | ||
// pointer is nonnull. | ||
// CHECK: nonnull {{i8\*|ptr}} @vec_as_ptr | ||
#[no_mangle] | ||
pub fn vec_as_ptr(v: &Vec<u8>) -> *const u8 { | ||
v.as_ptr() | ||
} | ||
|
||
// Test that even though we return a *const u8 not a &[u8] or a NonNull<u8>, LLVM knows that this | ||
// pointer is nonnull. | ||
// CHECK: nonnull {{i8\*|ptr}} @vec_as_mut_ptr | ||
#[no_mangle] | ||
pub fn vec_as_mut_ptr(v: &mut Vec<u8>) -> *mut u8 { | ||
v.as_mut_ptr() | ||
} |