Re: [IDEA+RFC] Possible solution for min()/max() war

From: Alexander Viro (viro@math.psu.edu)
Date: Fri Aug 24 2001 - 19:13:44 EST


On Fri, 24 Aug 2001, Brad Chapman wrote:

> - make everyone use the new macros (some people are thinking :P)
>
> - make everyone use #ifdef blocks with a config option (you think it's :P)
>
> - make min()/max() typeof() wrappers for a switch-style stack of comparison
> functions which work on the various types, i.e:
>
> __u8 minimum = min(one, two) -> __u8 minimum = __u8_min(one, two)
>
> (this may be too complex and is probably :P)

>
> - make min()/max() inline functions, cast things to void, and use memcmp()
> (this might almost be reasonable, but is probably also :P)
>
> - stay with the old-style macros (:P, :P, :P)
>
> What do you think, sir?

        Use different inline functions for signed and unsigned.
Explicitly.

        Any scheme trying to imitate polymorphism with use of cpp/
GNU extensions/whatever is missing the point. There is _no_ common
operation to extend on several types. Choice between signed and
unsigned max should be explicit - they are different operations.

        Trying to hide that is C++itis of the worst kind - false
polymorphism that hides only one thing: subtle bugs.

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/



This archive was generated by hypermail 2b29 : Fri Aug 31 2001 - 21:00:15 EST