Isn't using find with retro awkward?
spir
denis.spir at gmail.com
Wed Feb 16 10:43:57 PST 2011
On 02/16/2011 05:24 PM, Steven Schveighoffer wrote:
> On Wed, 16 Feb 2011 11:14:27 -0500, Andrej Mitrovic
> <andrej.mitrovich at gmail.com> wrote:
>
>> On 2/16/11, spir <denis.spir at gmail.com> wrote:
>>>
>>> for any reason, I would prefere
>>> findBack(haystack, needle);
>>> :-)
>>
>> Or maybe find should have an extra parameter that decides if the
>> search begins from the beginning or the end of the range.
>
> I just realized, this isn't possible in the general case. That is, given your
> original range [5, 1, 2, 3, 4, 5, 1], the only way to get [5, 1] is to use
> popFront.
>
> Think about this. What are the basic operations of a bidirectional range?
> popFront and popBack. There is no way to search from the back, and then use
> that as the front end of the resulting range.
>
> Essentially, the range API does not allow what you want unless you have a
> random-access range, and I don't even know if that can be generalized. The
> operation you are looking for is very different from what find does.
Agreed.
On the other hand, it is a basic operation very often provided by APIs for
collections --together with several other operations having a right- or -last
or version. And it's not like a trivial one-liner one would occasionnally
re-implement on occasion. This is ypically, I guess, the kind of service
std.algorithm is supposed to deliver. And we shouldn't find it elsewhere since
this module is precisely supposed to provide general purpose algorithms.
Thus, don't we face a contradiction, due to the fact that std.algorithm is
mainly range-oriented? How to reconciliate this with the broader "range" of
operations one would expect to find there?
In this case, couldn't we still have the extra parameter, and check the
collection allows random-access? Or have a variant with this extra param beeing
non-optional and a stricter template constraint allowing only random-access
ranges/collections?
Denis
--
_________________
vita es estrany
spir.wikidot.com
More information about the Digitalmars-d-learn
mailing list