On Saturday, 14 January 2017 at 03:20:24 UTC, Ignacious wrote:
When doing common functionality for a switch, is there any way to optimize:

switch(x)
{
    case X:
         q.X = e;
         break;
    case Y:
         q.Y = e;
         break
    etc...
}

e is basically a value that, depending on the what kind(x), we assign it to a field in q. The name of the field and the case label are identical(in fact, it wouldn't hurt to do it either automatically(if x's enum name, if exists, matches a field, auto assign) or create the field in the class q automatically if the label matches a certain range or set).

Basically the idea is to avoid duplicating a lot of code.

I imagine one could write a string mixin that generates the cases and assignments but I'm hoping for a more elegant solution.

if `q` is the only data structure that you are wanting to do this for
(or a 1:1 mapping for enum and type) then you can make
the enumeration values of x equal to the offsetof of q.
e.g. where typeof(q) == Q

enum XX
{
    X = Q.X.offsetof,
    Y = Q.Y.offsetof
    //ect.
}

and then

*(cast(void*)(this) + x) = e; //if inside struct/class

or
*(cast(void*)(q) + x) = e; // if outside

Unfortunately this loses you `@safe`ty, but as long as you trust
the value of x then it should be safe to `@trusted` that code.

If you are trying to avoid code duplication the enum declaration of X
could also be done with a string mixin.

Reply via email to