On Thursday, 28 February 2013 at 15:31:21 UTC, Andrei Alexandrescu wrote:
On 2/28/13 5:54 AM, Walter Bright wrote:
On 2/27/2013 11:55 PM, Jonathan M Davis wrote:
Again, please see how lexer.c works. I assure you, there is no double copying going on, nor is there a double test for the terminating 0.

I know what the lexer does, and remember that it _doesn't_ operate on
ranges,
and there are subtle differences between being able to just use char* and
trying to handle generic ranges.

Hence the need to invent SentinelInputRange.

I don't think the sentinel input range is a blocker for redoing the parser (with ranges) in D. This discussion has probably run its course. The right thing to do at this point is port the lexer and figure what primitives are necessary from its input.

Andrei

An actual sentinel range is trivial to implement, and the algorithms that can *actually* truly exploit it are rare.

While I'm not against having such ranges in phobos, I'd just be weary to provide too many traits for them, or trying to have phobos exploit them either. Ranges have enough primitives as it is.

Just provide it with a disclaimer than it will only ever be useful for a select class of algorithms (parser), but that the optimization opportunity will be ignored by the rest of phobos.

Reply via email to