Why does opDispatch not forward to operators?
John Colvin
john.loughran.colvin at gmail.com
Wed Aug 7 14:11:09 PDT 2013
On Wednesday, 7 August 2013 at 21:08:24 UTC, Tobias Pankrath
wrote:
> import std.stdio;
>
> struct ArrayTypeA {
> int[12] data;
> size_t length() { return 12; }
> auto opSlice(size_t s, size_t e) { return data[s .. e];
> }
> }
>
> struct ArrayTypeB {
> int[24] data;
>
> auto opSlice(size_t s, size_t e) { return data[s.. e];
> }
> size_t length() { return 24; }
> }
>
> struct Array
> {
> union {
> ArrayTypeA a = ArrayTypeA.init;
> ArrayTypeB b;
> }
> bool isA = true;
> auto opDispatch(string s, T...)(T args)
> {
> if(isA)
> return __traits(getMember, a, s)(args);
> else
> return __traits(getMember, b, s)(args);
> }
> }
>
> void main() {
>
> Array ar;
> writeln(ar.length); // compiles
>
> writeln(ar[3 .. 5]); // does not
> // /tmp/test.d(37): Error: Array cannot be sliced with
> []
> }
>
> I'd say, if something rewrites to MyType.opSlice than it's a
> case for opDispatch, too.
I wish it did too, but apparently there is a reason why not. I
can't remember what I was told off the top of my head, but I
remember not being 100% convinced.
It would greatly simplify writing some wrapper types.
More information about the Digitalmars-d-learn
mailing list