2021-06-27 02:22:46 -04:00
|
|
|
// edition:2021
|
2021-03-06 21:47:53 -05:00
|
|
|
|
|
|
|
// Given how the closure desugaring is implemented (at least at the time of writing this test),
|
|
|
|
// we don't need to truncate the captured path to a reference into a packed-struct if the field
|
|
|
|
// being referenced will be moved into the closure, since it's safe to move out a field from a
|
|
|
|
// packed-struct.
|
|
|
|
//
|
|
|
|
// However to avoid surprises for the user, or issues when the closure is
|
|
|
|
// inlined we will truncate the capture to access just the struct regardless of if the field
|
|
|
|
// might get moved into the closure.
|
|
|
|
//
|
2022-03-27 12:42:19 -04:00
|
|
|
// It is possible for someone to try writing the code that relies on the desugaring to create a ref
|
|
|
|
// into a packed-struct. Here we test that the compiler still detects that case.
|
2021-03-06 21:47:53 -05:00
|
|
|
fn test_missing_unsafe_warning_on_repr_packed() {
|
|
|
|
#[repr(packed)]
|
|
|
|
struct Foo { x: String }
|
|
|
|
|
|
|
|
let foo = Foo { x: String::new() };
|
|
|
|
|
|
|
|
let c = || {
|
|
|
|
println!("{}", foo.x);
|
2022-03-27 12:42:19 -04:00
|
|
|
//~^ ERROR: reference to packed field is unaligned
|
2021-03-06 21:47:53 -05:00
|
|
|
let _z = foo.x;
|
|
|
|
};
|
|
|
|
|
|
|
|
c();
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
test_missing_unsafe_warning_on_repr_packed();
|
|
|
|
}
|