You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I would like to propose that the compiler generates an automatic implementation of TryFrom<{Integer}> and Into<{Integer}> for C-style enums. Now I don`t know if they are actually called C-style enums by the community, but I am referring to these types of enums.
One cool thing about C-style enums is that you can convert them to any integer type (u8,u16, etc.) using as syntax:
asssert_eq!(CStyleEnum::Variant10asu8,100);//this works
However, C-style enums do not auto implement the Into<{Integer}> and TryFrom<{Integer}> traits like other Integers do (i16, u16, etc.), but I think they should. Since C-Style enums are just a subset of all Integers, I think all the common methods of converting them to Integers and converting Integers to C-Style enums except converting Integers to C-Style Enums with the as keyword(example below) should be supported by the compiler.
assert_eq!(100asCStyleEnum,CStyleEnum::Variant10);//This should NOT work, let n1:isize = -100;// Even Though this doeslet n2:usize = 100;assert_eq!(n2 asisize, n1);
Into<{Integer}>
//an automatic implementation of Into<{Integer}> would reuse all the logic defined for the lines below//impl of Into for C style enumslet into_num = CStyleEnum::Variant2asu8;let into_num = CStyleEnum::Variant2asu16;let into_num = CStyleEnum::Variant2asu32;let into_num = CStyleEnum::Variant2asu64;let into_num = CStyleEnum::Variant2asi8;let into_num = CStyleEnum::Variant2asi16;let into_num = CStyleEnum::Variant2asi32;let into_num = CStyleEnum::Variant2asi64;let into_num = CStyleEnum::Variant2asusize;let into_num = CStyleEnum::Variant2asisize;//look at all those automatic conversion implementations, made by the compiler, it would be//really nice if it went the other way with Into and TryFromlet variant = CStyleEnum::Variant1;let into:u8 = variant.into();assert_eq!(into,1u8);// I would like for this to work since its logically equal to the above lines using the `as` syntax
I think The auto-impl of Into<{Itegers}> would make sense since the C-style enum explicitly states that you want states to map to some sort of number. Anyways, the most important part of my proposal in the TryFrom<{Integer}> auto-implementation.
TryFrom<{Integer}>
//it would be very, very nice to have an automatic implementation of TryFrom for this typelet try_from = CStyleEnum::try_from(100)assert_eq!(Ok(CStyleEnum::Variant10), try_from);//this is much less boilerplate than the following:implTryFrom<{u8}>forCStyleEnum{typeErr = ();fntry_from(value:u8) -> Result<Self,Self::Err>{match value {10 => Ok(CStyleEnum::Variant1),20 => Ok(CStyleEnum::Variant2),100 => Ok(CStyleEnum::Variant10),
_ => Err(())//idk what sort of useful error you can put for this operation since there is only one point of failure}}}
Imagine If this CStyleEnum that I`ve been reusing for these code examples has more than 3 variants, or if I had made multiple C-style enums in my codebase, it would be a real eyesore to look at all those manual TryFrom implementations, and a waste of time to write a macro for something so trivial, and probably unnecessary to bring in an external crate with a macro to implement the TryFrom for me like Strum, since the compiler already logically does this for conversions between numbers, e.g. this is What a TryFrom would look like for u8:
//logically, this boilerplate is very similar//im sure the std does this some different way, but this is probably one of the ways it couldimplTryFrom<i8>foru8{typeError = ();fntry_from(value:i8) -> Result<Self,Self::Error>{match value {
value if value > 0 => Ok(transmute(value))//some sort of bitshifting to turn the i8`s internal//bits into the bits of a u8
_otherwise => Err(())}}}
The drawbacks of this would be if for some reason, the developer would want a different TryFrom implementation for their C-Style enum, but maybe the rust compiler could let the developer implement it themselves, like an ovveride, or instead the developer could opt-in to the compilers implementation via a #[derive(TryFrom)] for their C-Style Enum.
Conclusion
Anyways, this is just a small Quality Of Life change for Rust, which abstracts a bit of boilerplate away from the developers (us), therefore making our experience better, I think the magnitude of this change is similar to adding a (#[derive(Default)] for enums)[https://github.com//pull/3107]
The text was updated successfully, but these errors were encountered:
dk if I should turn this into an RFC or not, I was working with C-Style Enums for a DNS project and found converting from and to bytes with C-Style Enums to be far too much boilerplate for the complexity of the logic defined by them.
well, for one, those dedicated traits are already proposed in other RFCs 🙃 (AsRepr, FromRepr @ rust-lang/rust#86772 ← #3040, #3046, not yet implemented)
I would like to propose that the compiler generates an automatic implementation of TryFrom<{Integer}> and Into<{Integer}> for C-style enums. Now I don`t know if they are actually called C-style enums by the community, but I am referring to these types of enums.
One cool thing about C-style enums is that you can convert them to any integer type (u8,u16, etc.) using
as
syntax:However, C-style enums do not auto implement the Into<{Integer}> and TryFrom<{Integer}> traits like other Integers do (i16, u16, etc.), but I think they should. Since C-Style enums are just a subset of all Integers, I think all the common methods of converting them to Integers and converting Integers to C-Style enums except converting Integers to C-Style Enums with the
as
keyword(example below) should be supported by the compiler.Into<{Integer}>
I think The auto-impl of Into<{Itegers}> would make sense since the C-style enum explicitly states that you want states to map to some sort of number. Anyways, the most important part of my proposal in the TryFrom<{Integer}> auto-implementation.
TryFrom<{Integer}>
Imagine If this CStyleEnum that I`ve been reusing for these code examples has more than 3 variants, or if I had made multiple C-style enums in my codebase, it would be a real eyesore to look at all those manual TryFrom implementations, and a waste of time to write a macro for something so trivial, and probably unnecessary to bring in an external crate with a macro to implement the TryFrom for me like Strum, since the compiler already logically does this for conversions between numbers, e.g. this is What a TryFrom would look like for u8:
The drawbacks of this would be if for some reason, the developer would want a different TryFrom implementation for their C-Style enum, but maybe the rust compiler could let the developer implement it themselves, like an ovveride, or instead the developer could opt-in to the compilers implementation via a
#[derive(TryFrom)]
for their C-Style Enum.Conclusion
Anyways, this is just a small Quality Of Life change for Rust, which abstracts a bit of boilerplate away from the developers (us), therefore making our experience better, I think the magnitude of this change is similar to adding a (#[derive(Default)] for enums)[https://github.com//pull/3107]
The text was updated successfully, but these errors were encountered: