-
Notifications
You must be signed in to change notification settings - Fork 13k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Make #[repr(Rust)]
incompatible with other (non-modifier) representation hints like C
and simd
#116829
Conversation
r? @b-naber (rustbot has picked a reviewer for you, use r? to override) |
#[derive(LintDiagnostic)] | ||
#[diag(passes_repr_conflicting, code = "E0566")] | ||
pub struct ReprConflicting; | ||
pub struct ReprConflictingLint; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If you're interested in a follow-up, it's probably time to bump this lint up to a hard-error 😸
I think this is pretty obviously an error, but since T-lang's triage meeting is tomorrow, I guess it doesn't hurt to wait until then. r=me after, though. |
cf1fba5
to
cae6344
Compare
Consensus from the lang team triage meeting (minutes):
|
Personally I think we can allow This PR can probably be merged as-is, but someone needs to create a follow-up with banning all other combinations. |
Imma update this PR instead of creating another one, otherwise we'd need to backport 2 PRs. |
We already have positive behavior tests for |
#[repr(Rust)]
and #[repr(C)]
incompatible with one another#[repr(Rust)]
incompatible with other (non-modifier) representations like C
and simd
#[repr(Rust)]
incompatible with other (non-modifier) representations like C
and simd
#[repr(Rust)]
incompatible with other (non-modifier) representation hints like C
and simd
self.tcx.sess.emit_err(errors::TransparentIncompatible { | ||
hint_spans, | ||
target: target.to_string(), | ||
}); | ||
} | ||
if is_explicit_rust && (int_reprs > 0 || is_c || is_simd) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I could also turn the bools into a bitfield and check if the difference between the set bitflags and {Rust, align, packed} is empty to address “but not necessarily limited to” part of
We should ban all other repr(Rust, other) combinations, including, but not necesseraly limited to
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think refactoring this function would be a lot of good, as the current code seems to be error-prone and confusing. But obv this refactoring can come as a follow-up, which does not need a backport. (cc me if you'll do it please)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One of the things that would be nice is to default to disallowing, so that no changes can accidentally allow new combinations.
@bors r+ |
Rollup of 7 pull requests Successful merges: - rust-lang#116663 (Don't ICE when encountering unresolved regions in `fully_resolve`) - rust-lang#116761 (Fix podman detection in CI scripts) - rust-lang#116795 (Add `#[track_caller]` to `Option::unwrap_or_else`) - rust-lang#116829 (Make `#[repr(Rust)]` incompatible with other (non-modifier) representation hints like `C` and `simd`) - rust-lang#116883 (Change my name in mailmap) - rust-lang#116908 (Tweak wording of type errors involving type params) - rust-lang#116912 (Some renaming nits for `rustc_type_ir`) r? `@ghost` `@rustbot` modify labels: rollup
Rollup merge of rust-lang#116829 - fmease:rust-aint-c, r=compiler-errors Make `#[repr(Rust)]` incompatible with other (non-modifier) representation hints like `C` and `simd` Read more about this change here: rust-lang#116829 (comment). Fixes [after backport] rust-lang#116825.
[beta] backports and stage0 bump - Bump stage0 to released stable compiler - Hide host effect params from docs rust-lang#116670 - Fix a performance regression in obligation deduplication. rust-lang#116826 - Make `#[repr(Rust)]` and `#[repr(C)]` incompatible with one another rust-lang#116829 - Update to LLVM 17.0.3 rust-lang#116840 - Disable effects in libcore again rust-lang#116856 - revert rust-lang#114586 rust-lang#116879 r? cuviper
Read more about this change here: #116829 (comment).
Fixes [after backport] #116825.