ideas about ranges
Steven Schveighoffer
schveiguy at yahoo.com
Tue May 26 06:25:11 PDT 2009
On Fri, 22 May 2009 22:35:39 -0400, Andrei Alexandrescu
<SeeWebsiteForEmail at erdani.org> wrote:
> Steven Schveighoffer wrote:
> Andrei Alexandrescu wrote:
>> Steven Schveighoffer wrote:
>> OK, I can see you're not going to alter your opinion, so I'll stop
>> debating. I respectfully disagree with your definitions.
>
> I'm using STL's definitions. I'd be glad to depart if there was a solid
> reason. How would you name things?
I reread the chapter on iterators in my C++ book. I was convinced that I
would see something to fuel my beliefs.
I'm now convinced that ranges can stay as is. Here is why:
I was focusing on a stream range as a more basic range than an input
range. However, I wasn't thinking about the whole picture. There are
more than just input streams. There are output streams and input/output
streams. It makes sense to support all of them, not just input streams.
So really, I'm thinking of a different tree of entities, which already
exist: streams! That is, the unification of ranges and streams really
isn't necessary. You can wrap a stream as an input, output, or forward
range, and deal with the shoehorning (and buffer issues) when you really
need it. I don't think viewing streams as ranges is going to be a useful
idiom unless you need to convert from one world to the other. So trying
to find a way to make files be ranges might be simply an overenthusiastic
view of ranges, similar to how people try to make everything object
oriented when they learn how OO design works.
As far as foreach, we still have opApply for streams (or shoehorning if
you need range-ification).
However, out of all this may come one interesting idea: popNext
(specifically the 'bool popNext(ref T val)' form).
Note that there are a couple of advantages to using popNext with foreach:
1. Multiple variables, and easy overloading. i.e. foreach(int idx, T val;
range) would be possible (and much less cumbersome than opApply!).
2. 1 function call per loop instead of 3. This may have a distinct
advantage if you absolutely have to use a virtual method, or your range
must call virtual methods on it's container.
I still don't know how to make ref values work with popNext without using
pointers. It would be nice to have a rebindable ref type.
I thought of this syntax, does this seem appealing at all?
int i = 5, j = 6;
ref int ri = i;
ri = 7;
assert(i == 7);
ri.& = &j;
ri = 8;
assert(j == 8);
type of ref.& is *not* a pointer, the arithmetic operators are not defined
for it, and it can't be assigned to a pointer (although it can be assigned
from a pointer).
You also need to be able to pass the type of ref.& to rebind references
inside a popNext function.
If we could solve these problems, we might have a better case of being
able to get rid of opApply.
-Steve
More information about the Digitalmars-d
mailing list