Skip to content

Conversation

@madsmtm
Copy link
Contributor

@madsmtm madsmtm commented Apr 21, 2025

Add #[repr(_, open)] on field-less (C-style) enums to allow the enum to contain unknown variants, which enables using the enum directly in FFI.

Enums with the open modifier cannot be matched on exhaustively without the use of a wildcard arm. This feature is similar but distinct from the #[non_exhaustive] attribute, since it works on an ABI level and applies in the defining module as well.

Example:

#[repr(u8, open)] // ABI stable and allowed in FFI
pub enum Version {
    Http0_9,
    Http1_0,
    Http1_1,
    Http2_0,
    Http3_0,
}

match version {
    Version::Http0_9 | Version::Http1_0 | Version::Http1_1 => println!("good old"),
    Version::Http2_0 | Version::Http3_0 => println!("ooh, fancy!"),
    // Fallback arm is required, even in the same crate.
    _ => println!("from the future!"),
}

Based on @thomcc's initial work on a similar RFC. This kind of functionality has also been discussed in the past on the internals forum, in bindgen, more recently on Zulip and possibly many more times before that.

Please try to create inline comments for discussions to keep this RFC manageable for me.

Rendered.

@rustbot rustbot added the T-lang Relevant to the language team, which will review and decide on the RFC. label Apr 21, 2025
madsmtm added a commit to madsmtm/wgpu that referenced this pull request Apr 25, 2025
The `metal` crate is currently unsound regarding unknown/future enum
variants, see gfx-rs/metal-rs#209 and
rust-lang/rfcs#3803.

`objc2-metal` fixes this by emitting C enums as a newtype + constants
for each variant, but that prevents us from importing the
variants/constants. So this commit converts to a pattern that works with
that in preparation for the migration.
cwfitzgerald pushed a commit to gfx-rs/wgpu that referenced this pull request Apr 25, 2025
The `metal` crate is currently unsound regarding unknown/future enum
variants, see gfx-rs/metal-rs#209 and
rust-lang/rfcs#3803.

`objc2-metal` fixes this by emitting C enums as a newtype + constants
for each variant, but that prevents us from importing the
variants/constants. So this commit converts to a pattern that works with
that in preparation for the migration.
@madsmtm
Copy link
Contributor Author

madsmtm commented May 5, 2025

Thanks for the comments all, and sorry for the delay. I believe I've incorporated your suggestions into the RFC text, but feel free to open a new comment if you disagree!

@madsmtm madsmtm changed the title RFC: Disable niche layout optimization on enum discriminants RFC: Allow making enums usable in FFI May 12, 2025
sinjs pushed a commit to sinjs/wgpu that referenced this pull request Jul 22, 2025
The `metal` crate is currently unsound regarding unknown/future enum
variants, see gfx-rs/metal-rs#209 and
rust-lang/rfcs#3803.

`objc2-metal` fixes this by emitting C enums as a newtype + constants
for each variant, but that prevents us from importing the
variants/constants. So this commit converts to a pattern that works with
that in preparation for the migration.
@dhardy

This comment was marked as resolved.

@dhardy
Copy link
Contributor

dhardy commented Sep 5, 2025

Good changes but I'd like to make one point more strongly:

At the type-theoretic level, enum Triple { A, B, C } has three possible values. In contrast, an "open enum" with the same codes over (say) u8 would have 256 possible values.

Attributes are not typically used to adjust a type at the type-theoretic level (#[non_exhaustive] is barely an exception; it merely prevents exhaustive matches). I therefore think something stronger than an attribute should be required to make an "open enum".

sharmajai pushed a commit to sharmajai/wgpu that referenced this pull request Oct 12, 2025
The `metal` crate is currently unsound regarding unknown/future enum
variants, see gfx-rs/metal-rs#209 and
rust-lang/rfcs#3803.

`objc2-metal` fixes this by emitting C enums as a newtype + constants
for each variant, but that prevents us from importing the
variants/constants. So this commit converts to a pattern that works with
that in preparation for the migration.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

T-lang Relevant to the language team, which will review and decide on the RFC.

Projects

None yet

Development

Successfully merging this pull request may close these issues.