mirror of
https://github.com/rust-lang/rust.git
synced 2024-12-11 08:05:12 +00:00
3aa14e3b2e
In its first step of computing transmutability, `rustc_transmutability` constructs a byte-level representation of type layout (`Tree`). Previously, this representation was computed for ADTs by inspecting the ADT definition and performing our own layout computations. This process was error-prone, verbose, and limited our ability to analyze many types (particularly default-repr types). In this PR, we instead construct `Tree`s from `rustc_target::abi::Layout`s. This helps ensure that layout optimizations are reflected our analyses, and increases the kinds of types we can now analyze, including: - default repr ADTs - transparent unions - `UnsafeCell`-containing types Overall, this PR expands the expressvity of `rustc_transmutability` to be much closer to the transmutability analysis performed by miri. Future PRs will work to close the remaining gaps (e.g., support for `Box`, raw pointers, `NonZero*`, coroutines, etc.). |
||
---|---|---|
.. | ||
repr | ||
boolish.rs | ||
should_pad_variants.rs | ||
should_pad_variants.stderr | ||
should_permit_intersecting_if_validity_is_assumed.rs | ||
should_reject_contraction.rs | ||
should_reject_contraction.stderr | ||
should_reject_disjoint.rs | ||
should_reject_disjoint.stderr | ||
should_reject_intersecting.rs | ||
should_reject_intersecting.stderr |