On Mon, Sep 29, 2025 at 03:59:32PM +0200, Miguel Ojeda wrote: > On Sat, Sep 20, 2025 at 8:23 PM Joel Fernandes <[email protected]> wrote: > > > > The bitfield macro's setter currently uses the From trait for type > > conversion, which is overly restrictive and prevents use cases such as > > narrowing conversions (e.g., u32 storage size to u8 field size) which > > aren't supported by From. > > Being restrictive is a good thing -- it would be nice to know more > context about this change, like Alexandre points out. > > In particular, the line: > > .set_nibble(0x12345678_u32) // truncated to 0x8 > > sounds fairly alarming, and not what we usually want. Why cannot the > caller cast on their side, if they really want that?
It was my suggestion to relax the type requirement. The reasoning is as follows. Consider a bitfield bf with bits 5:3 described as field1. The storage for bf is u8, but the type is u32. This is OK, because storage and representation are simply different matters. And no matter how you declare the field inside the bitfield, you can't prevent overflow followed by silent truncation by just syntax measures. I suggested to relax the requirement that field representation must match (not exceed in fact) storage type, and instead bring explicit check in the setter. With the check, if user tries to overflow the field, we either throw a warning, or panic if hardening is enabled, or do nothing in performance-critical builds. As far as I can say, Joel scheduled this in v5. Thanks, Yury
