freeradius-server-2.1.10 compiles on HP-UX 11.31 with errors.
Jeffrey Hutzelman
jhutz at cmu.edu
Tue Nov 23 17:39:48 CET 2010
--On Tuesday, November 23, 2010 04:53:38 PM +0100 Alan DeKok
<aland at deployingradius.com> wrote:
> Jeffrey Hutzelman wrote:
>> You should be -- if the compiler accepts it at all, it changes the
>> semantics. Casting void * to int is not strictly legal and won't work
>> on platforms where void * is larger than int. That said, the existing
>> code is not that great, either -- ptrdiff_t is not guaranteed to fit in
>> an int; in fact, I just found a bug last night in another piece of
>> software caused by ptrdiff_t being long.
>
> Hmmm... ugh.
My thoughts exactly.
>> Of course, the OP hasn't reported what the original error was, so I
>> can't really suggest a better fix, but I'll bet it involves changing the
>> return type of eap_handler_ptr_cmp().
>
> Or:
>
> if (a < b) return -1;
> if (a > b) return +1;
> return 0;
>
> The values don't matter, only the sign, and the fact that the
> calculation is transitive across more than 2 pointers.
Oh; this is a comparator for a btree. Yeah, this seems like the sanest
thing to do.
-- Jeff
More information about the Freeradius-Devel
mailing list