On Monday, 5 September 2016 at 06:45:07 UTC, data pulverizer
wrote:
On Sunday, 4 September 2016 at 14:49:30 UTC, Lodovico Giaretta
wrote:
Your getCol(i) could become getCol!T(i) and return an instance
of GenericVector!T directly, after checking that the required
column has in fact that type:
GenericVector!T getCol!T(size_t i)
{
if(typeid(cols[i]) == typeid(GenericVector!T))
return cast(GenericVector!T)cols[i];
else
// assert(0) or throw exception
}
I just realized that typeid only gives the class and not the
actual type, so the object will still need to be cast as you
mentioned above, however your above function will not infer T,
so the user will have to provide it. I wonder if there is a way
to dispatch the right type by a dynamic cast or I fear that
ZombineDev may be correct and the types will have to be
limited, which I definitely want to avoid!
ZombineDev is definitely correct, in that one thing is the static
type, and another thing is the dynamic type. The type of a
variable, or the return type of a method are based on the static
type, computed at compile time. The "true" dynamic type is only
available at runtime.
That's why I was showing you the use of tuples. If your code does
not have branches that assign different column types, having the
types statically determined as template parameters is the best
choice.
If you really need dynamic types, then there's no alternative:
the user must explicitly cast things to the correct dynamic type
(my version of getCol is just a nice wrapper to do that). In
fact, idiomatic D code tries to avoid dynamic types when
possible, preferring templates.