alx-0008 - Standardize strtoi(3) and strtou(3) from NetBSD

Paul Eggert eggert at cs.ucla.edu
Wed Mar 19 20:39:00 UTC 2025


On 2025-03-19 13:05, Alejandro Colomar wrote:
> Please comment on the subthread where Bruno mentioned a number of places
> in gnulib and gettext where you use strtoul(3).  I found there a few
> bugs, plus some ways to just simplify with strtou(3).

I looked at the Gnulib commentary in 
<https://lore.kernel.org/liba2i/jx4664ishtl34eg2npdrv5fkfdiczqnlq3vjuacjrupjvh377x@gddcftzgwmfq/>, 
as I assume that's what you're talking about. (I don't hack on gettext 
and will leave Bruno to comment on that.)

For Gnulib, I didn't see any bugs in the three areas mentioned.

The patch suggested to lib/getaddrinfo.c doesn't fix any bugs that I can 
see, and needs an additional wrapper to work anyway, which is 
introducing complexity.

The patch suggested to lib/nproc.c is merely a minor clarity / 
performance improvement (it removes three instructions), and does not 
fix any bugs. Likewise for the patch to lib/omp-init.c. And these 
improvements (where the code mistakenly worried about endptr == NULL) 
fix a mistake that one could make with the proposed strtoi API, so I 
don't see strtoi helping there.

But thanks for the clarity / speedup idea; I installed a patch into 
Gnulib here:

https://git.savannah.gnu.org/cgit/gnulib.git/commit/?id=2835ca01722fcd41761383ef289d19797b13b2e8




>> > In particular, use a functional style, with
>> > no side effects (no pointers-to-results). Just return the result you want,
>> > as a struct, and keep the struct simple. Two struct components should
>> > suffice: the scanned numeric value and a success/error indicator.
> 
> That's going to complicate usage significantly.

Please try it and see. You might be surprised at how clean and efficient 
functional programming can be, if done right. Admittedly C doesn't 
always make it easy.


More information about the libbsd mailing list