On 5/13/15 10:58 PM, rcorre wrote:
Actually, this doesn't even seem to work with a custom range:

import std.range;
import std.stdio;
import std.algorithm;

     struct MyContainer {
       @nogc auto opSlice() {
         struct Range {
           @property bool empty() { return true; }
           @property int front() { return 9; }
           void popFront() { }
         }

         return Range();
       }
     }

     /// Return a slice of aa[key], or an empty slice if not found
     @nogc auto maybeGetRange(MyContainer[string] aa, string key) {
       alias RangeType = typeof(MyContainer.init[]);
       auto val = key in aa;
       return (val is null) ? takeNone!RangeType :
(*val)[].take(size_t.max);
     }

Is there any way to create an empty MyContainer.Range() without creating
a new container?

It depends on the guts of MyContainer.Range.

I'm assuming MyContainer.Range has SOME sort of references (i.e. pointers) to the data in the container, so why not just have:

bool empty() { return someRef == null || yourCurrentTest; }

-Steve

Reply via email to