forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 6
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#85893 - pnkfelix:beta-backport-85564, r=simul…
…acrum [beta] backport of readd capture disjoint fields gate Beta backport of "readd capture disjoint fields gate", PR rust-lang#85564 Fix issue rust-lang#85435
- Loading branch information
Showing
2 changed files
with
45 additions
and
14 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
25 changes: 25 additions & 0 deletions
25
src/test/ui/unsafe/issue-85435-unsafe-op-in-let-under-unsafe-under-closure.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,25 @@ | ||
// check-pass | ||
|
||
// This is issue #85435. But the real story is reflected in issue #85561, where | ||
// a bug in the implementation of feature(capture_disjoint_fields) () was | ||
// exposed to non-feature-gated code by a diagnostic changing PR that removed | ||
// the gating in one case. | ||
|
||
// This test is double-checking that the case of interest continues to work as | ||
// expected in the *absence* of that feature gate. At the time of this writing, | ||
// enabling the feature gate will cause this test to fail. We obviously cannot | ||
// stabilize that feature until it can correctly handle this test. | ||
|
||
fn main() { | ||
let val: u8 = 5; | ||
let u8_ptr: *const u8 = &val; | ||
let _closure = || { | ||
unsafe { | ||
let tmp = *u8_ptr; | ||
tmp | ||
|
||
// Just dereferencing and returning directly compiles fine: | ||
// *u8_ptr | ||
} | ||
}; | ||
} |