Maybe we don't need foreach ;-)

Lionello Lunesu lio at lunesu.remove.com
Tue Oct 31 02:47:55 PST 2006


Frits van Bommel wrote:
> Lionello Lunesu wrote:
>> I got so used to foreach in D, I've just ported it to C ;)
>>
>> namespace D {
>> template <typename T, int S>
>> inline size_t length( T (&a)[S] ) { return S; }
>> // Add overloads for your own containers
>> }
>>
>> #define foreach(ELEMENT,ARRAY) \
>>   for(size_t __L=D::length(ARRAY),__B=0,__I=0; !__B && __I<__L; 
>> assert(__L==D::length(ARRAY)), ++__I ) \
>>     if (__B = 1) \
>>       for(ELEMENT = ARRAY[__I]; __B; __B=0) // a break must make the 
>> main loop stop
> 
> I think you have a dangling-else bug here:
> 
>     if (whatever)
>         foreach(elt, arr) { something(); }
>     else
>         somethingelse();
> 
> What happens in this code? It looks like somethingelse() will be 
> executed if whatever evaluates to false, but IIRC the 'else' clause will 
> bind to the 'if' you have in your macro. Since that one never evaluates 
> to false, somethingelse() will never be called here.
> 
> I haven't tried it though, this was just from looking at it.
> Also, this won't manifest itself if you always use braces after 'if's so 
> this may be hard to spot the one time you forget :).

Good one, easily solvable though, by inverting __B and using "if () {} 
else for...".. Thanks!

L.



More information about the Digitalmars-d mailing list