Re: lfind(3) $3 type should be const

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Gabriel,

On Thu, Nov 14, 2024 at 05:24:36PM GMT, Gabriel Ravier wrote:
> On 11/14/24 3:38 PM, Alejandro Colomar wrote:
> > Hi!
> > 
> > lfind(3) does not modify its third argument, *nmemb.
> > 
> > It's already suspicious that it takes a pointer, but I guess it's due to
> > historic reasons, and that's already set in stone.
> > 
> > However, I don't see why we should not make it 'const'.  The function
> > doesn't use it as an output pointer.  Should I sent a patch for
> > constifying it?
> 
> 
> I believe the reason is that it aims to mirror lsearch, and to be able to be
> used with it interchangeably as a function with the same type - doesn't
> `const` make the pointer types distinct and incompatible ?

Hmmm.  That makes sense.

Thanks!
Alex

> 
> I'd imagine it's not even used much at all elsewhere given how simple it is
> and how cumbersome it is to use compared to an directly inlined
> implementation. That is, I think making it non-const might just happen to
> break a majority of uses of it.
> 
> The only way to plausibly rectify this, I think, would be to make the
> compatibility implicit in the standard for any similar function (in the same
> way one might like to make it standard to e.g. pass a pointer to a pointer
> to const char to strtol).

-- 
<https://www.alejandro-colomar.es/>

Attachment: signature.asc
Description: PGP signature


[Index of Archives]     [Kernel Documentation]     [Netdev]     [Linux Ethernet Bridging]     [Linux Wireless]     [Kernel Newbies]     [Security]     [Linux for Hams]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux Admin]     [Samba]

  Powered by Linux