[Issue 24540] Add order/index to enum member to return its position
    d-bugmail at puremagic.com 
    d-bugmail at puremagic.com
       
    Mon May  6 15:59:18 UTC 2024
    
    
  
https://issues.dlang.org/show_bug.cgi?id=24540
Nick Treleaven <nick at geany.org> changed:
           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |nick at geany.org
--- Comment #2 from Nick Treleaven <nick at geany.org> ---
(In reply to apham from comment #0)
>   void set(Foo e)
>   {
>      v |= 1 << e.order;
>   }
>   
>   bool isSet(Foo e)
>   {
>     return (v & (1 << e.order)) != 0;
>   }
It's not possible to take a runtime enum value and produce its index in an enum
without some runtime overhead.
Another issue is that `e.order` is already valid code, meaning call `order(e)`.
--
    
    
More information about the Digitalmars-d-bugs
mailing list