Message ID | 83962310-aec8-a718-bafb-6e10703693b8@t-online.de |
---|---|
State | New |
Headers |
Return-Path: <newlib-bounces+patchwork=sourceware.org@sourceware.org> X-Original-To: patchwork@sourceware.org Delivered-To: patchwork@sourceware.org Received: from server2.sourceware.org (localhost [IPv6:::1]) by sourceware.org (Postfix) with ESMTP id 1F7B63857C76 for <patchwork@sourceware.org>; Mon, 22 Jan 2024 18:47:16 +0000 (GMT) X-Original-To: newlib@sourceware.org Delivered-To: newlib@sourceware.org Received: from mailout08.t-online.de (mailout08.t-online.de [194.25.134.20]) by sourceware.org (Postfix) with ESMTPS id 9BB6A38582A5 for <newlib@sourceware.org>; Mon, 22 Jan 2024 18:46:57 +0000 (GMT) DMARC-Filter: OpenDMARC Filter v1.4.2 sourceware.org 9BB6A38582A5 Authentication-Results: sourceware.org; dmarc=none (p=none dis=none) header.from=t-online.de Authentication-Results: sourceware.org; spf=pass smtp.mailfrom=t-online.de ARC-Filter: OpenARC Filter v1.0.0 sourceware.org 9BB6A38582A5 Authentication-Results: server2.sourceware.org; arc=none smtp.remote-ip=194.25.134.20 ARC-Seal: i=1; a=rsa-sha256; d=sourceware.org; s=key; t=1705949219; cv=none; b=RxBFSF5lAUq8I/QETBZrpYP9r01pJnvC1cgCCVnvVyw7F80ifV7QNN2gMRMYqfhExtGJ1MjP6mQzfR3BoC3srlfV79/PGUSR6oLFHhQlcz4k/3pp8xuyzJilmR5H3Uaya5StRub04VIGXrpfvhtpgAowYlR+SpChxy1+pa8Jigo= ARC-Message-Signature: i=1; a=rsa-sha256; d=sourceware.org; s=key; t=1705949219; c=relaxed/simple; bh=A5e2wJ4sPMSYlz2dphSsNF+OMtq2kaVfVI050uIBObQ=; h=To:From:Subject:Message-ID:Date:MIME-Version; b=kT689e82otW7DbVS/g2Lw5e5GrQvxqx+OzYkmpxKTiBrfi5FdvWHhqGFDdWB8n+z5hln6VdobGpQ4Z8+eoDo05DtCEcKC/j6cjqM2hF9rlT4FtD9HYG8Im9ADMbOpdicijNU15TT61ztGZDUmidDE+wPvaRkNQbfC4onoPk8ADE= ARC-Authentication-Results: i=1; server2.sourceware.org Received: from fwd76.aul.t-online.de (fwd76.aul.t-online.de [10.223.144.102]) by mailout08.t-online.de (Postfix) with SMTP id 3AC1A1E744 for <newlib@sourceware.org>; Mon, 22 Jan 2024 19:46:35 +0100 (CET) Received: from [192.168.2.104] ([79.230.174.55]) by fwd76.t-online.de with (TLSv1.3:TLS_AES_256_GCM_SHA384 encrypted) esmtp id 1rRzJV-1Zi8Tg0; Mon, 22 Jan 2024 19:46:29 +0100 To: newlib@sourceware.org From: Christian Franke <Christian.Franke@t-online.de> Subject: Hide non-standard itoa/utoa() in stdlib.h or drop these functions? Message-ID: <83962310-aec8-a718-bafb-6e10703693b8@t-online.de> Date: Mon, 22 Jan 2024 19:46:29 +0100 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 SeaMonkey/2.53.16 MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="------------78194DEFC54EB73E6F56E2C3" X-TOI-EXPURGATEID: 150726::1705949189-DB7FD94C-CBE08265/0/0 CLEAN NORMAL X-TOI-MSGID: 67780f19-6f1e-4146-b90e-c42cc550371e X-Spam-Status: No, score=-11.4 required=5.0 tests=BAYES_00, FREEMAIL_FROM, GIT_PATCH_0, KAM_DMARC_STATUS, RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H3, RCVD_IN_MSPIKE_WL, SPF_HELO_NONE, SPF_PASS, TXREP, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on server2.sourceware.org X-BeenThere: newlib@sourceware.org X-Mailman-Version: 2.1.30 Precedence: list List-Id: Newlib mailing list <newlib.sourceware.org> List-Unsubscribe: <https://sourceware.org/mailman/options/newlib>, <mailto:newlib-request@sourceware.org?subject=unsubscribe> List-Archive: <https://sourceware.org/pipermail/newlib/> List-Post: <mailto:newlib@sourceware.org> List-Help: <mailto:newlib-request@sourceware.org?subject=help> List-Subscribe: <https://sourceware.org/mailman/listinfo/newlib>, <mailto:newlib-request@sourceware.org?subject=subscribe> Errors-To: newlib-bounces+patchwork=sourceware.org@sourceware.org |
Series |
Hide non-standard itoa/utoa() in stdlib.h or drop these functions?
|
|
Commit Message
Christian Franke
Jan. 22, 2024, 6:46 p.m. UTC
The functions itoa() and utoa() are non-standard, not exported by Cygwin and also unavailable on FreeBSD and Linux (glibc and musl libc). Busybox for example could not be build OOTB using newlib's stdlib.h because there are conflicts with local functions with same names but different signatures. See the original posts on the Cygwin list for more details: https://sourceware.org/pipermail/cygwin/2024-January/255216.html https://sourceware.org/pipermail/cygwin/2024-January/255217.html Corinna proposed to either drop these functions entirely or hide the prototypes on Cygwin only. I attached a patch for the second alternative.
Comments
On Jan 22 19:46, Christian Franke wrote: > The functions itoa() and utoa() are non-standard, not exported by Cygwin and > also unavailable on FreeBSD and Linux (glibc and musl libc). Busybox for > example could not be build OOTB using newlib's stdlib.h because there are > conflicts with local functions with same names but different signatures. > > See the original posts on the Cygwin list for more details: > https://sourceware.org/pipermail/cygwin/2024-January/255216.html > https://sourceware.org/pipermail/cygwin/2024-January/255217.html > > Corinna proposed to either drop these functions entirely or hide the > prototypes on Cygwin only. I attached a patch for the second alternative. > > -- > Regards, > Christian > > From 5f1c43796c6a125f04c1f2436fc1048783ce3b7a Mon Sep 17 00:00:00 2001 > From: Christian Franke <christian.franke@t-online.de> > Date: Mon, 22 Jan 2024 19:11:20 +0100 > Subject: [PATCH] Hide itoa, utoa, __itoa and __utoa in stdlib.h on Cygwin only > > These functions are non-standard and not exported by Cygwin. > > Signed-off-by: Christian Franke <christian.franke@t-online.de> > --- > newlib/libc/include/stdlib.h | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/newlib/libc/include/stdlib.h b/newlib/libc/include/stdlib.h > index 15b349440..fd89f5ba7 100644 > --- a/newlib/libc/include/stdlib.h > +++ b/newlib/libc/include/stdlib.h > @@ -221,11 +221,13 @@ char * ecvtbuf (double, int, int*, int*, char *); > char * fcvtbuf (double, int, int*, int*, char *); > char * ecvtf (float,int,int *,int *); > #endif > +#ifndef __CYGWIN__ > char * __itoa (int, char *, int); > char * __utoa (unsigned, char *, int); > -#if __MISC_VISIBLE > +# if __MISC_VISIBLE > char * itoa (int, char *, int); > char * utoa (unsigned, char *, int); > +# endif > #endif > #if __POSIX_VISIBLE > int rand_r (unsigned *__seed); > -- > 2.43.0 > In fact, while this patch fixes the namespace pollution for Cygwin, I wonder if we shouldn't remove itoa/utoa entirely. The underscored functions __itoa/__utoa accomplish exactly the same thing. Does anybody actually *need* itoa/utoa as long as we have __itoa/__utoa? Corinna
> > ------------------------------ > *From:* Corinna Vinschen <vinschen@redhat.com> > *Sent:* Tuesday, January 23, 2024 4:03 AM > *To:* Christian Franke <Christian.Franke@t-online.de> > *Cc:* newlib@sourceware.org <newlib@sourceware.org> > *Subject:* Re: Hide non-standard itoa/utoa() in stdlib.h or drop these > functions? > > > On Jan 22 19:46, Christian Franke wrote: > > The functions itoa() and utoa() are non-standard, not exported by Cygwin > and > > also unavailable on FreeBSD and Linux (glibc and musl libc). Busybox for > > example could not be build OOTB using newlib's stdlib.h because there are > > conflicts with local functions with same names but different signatures. > > > > See the original posts on the Cygwin list for more details: > > https://sourceware.org/pipermail/cygwin/2024-January/255216.html > > https://sourceware.org/pipermail/cygwin/2024-January/255217.html > > > > Corinna proposed to either drop these functions entirely or hide the > > prototypes on Cygwin only. I attached a patch for the second alternative. > > > > -- > > Regards, > > Christian > > > > > From 5f1c43796c6a125f04c1f2436fc1048783ce3b7a Mon Sep 17 00:00:00 2001 > > From: Christian Franke <christian.franke@t-online.de> > > Date: Mon, 22 Jan 2024 19:11:20 +0100 > > Subject: [PATCH] Hide itoa, utoa, __itoa and __utoa in stdlib.h on > Cygwin only > > > > These functions are non-standard and not exported by Cygwin. > > > > Signed-off-by: Christian Franke <christian.franke@t-online.de> > > --- > > newlib/libc/include/stdlib.h | 4 +++- > > 1 file changed, 3 insertions(+), 1 deletion(-) > > > > diff --git a/newlib/libc/include/stdlib.h b/newlib/libc/include/stdlib.h > > index 15b349440..fd89f5ba7 100644 > > --- a/newlib/libc/include/stdlib.h > > +++ b/newlib/libc/include/stdlib.h > > @@ -221,11 +221,13 @@ char * ecvtbuf (double, int, int*, int*, char *); > > char * fcvtbuf (double, int, int*, int*, char *); > > char * ecvtf (float,int,int *,int *); > > #endif > > +#ifndef __CYGWIN__ > > char * __itoa (int, char *, int); > > char * __utoa (unsigned, char *, int); > > -#if __MISC_VISIBLE > > +# if __MISC_VISIBLE > > char * itoa (int, char *, int); > > char * utoa (unsigned, char *, int); > > +# endif > > #endif > > #if __POSIX_VISIBLE > > int rand_r (unsigned *__seed); > > -- > > 2.43.0 > > > > In fact, while this patch fixes the namespace pollution for Cygwin, I > wonder if we shouldn't remove itoa/utoa entirely. The underscored > functions __itoa/__utoa accomplish exactly the same thing. > > Does anybody actually *need* itoa/utoa as long as we have __itoa/__utoa? > > > Corinna > > itoa() and utoa() should definitely be deleted. Removing them from the header file is only a half-baked solution for regular Newlib because they are still in the library. With them still in the library you can end up linking to the wrong version and that's worse than the "wrong" prototype being found that clearly blows up compilation. Given the __ versions still being available it allows a simple fix for anyone that does happen to use them. (Perhaps to be most friendly to that we should somehow make sure that a point in the next release notes mentions this. (Won't be bad to find with the __ versions still in stdlib.h, though.)) (In hindsight we probably fell down on the job allowing them to be added as they were. Just the __ versions should have gone in to begin with.) Craig
On 2024-01-23 02:03, Corinna Vinschen wrote: > On Jan 22 19:46, Christian Franke wrote: >> The functions itoa() and utoa() are non-standard, not exported by Cygwin and >> also unavailable on FreeBSD and Linux (glibc and musl libc). Busybox for >> example could not be build OOTB using newlib's stdlib.h because there are >> conflicts with local functions with same names but different signatures. >> >> See the original posts on the Cygwin list for more details: >> https://sourceware.org/pipermail/cygwin/2024-January/255216.html >> https://sourceware.org/pipermail/cygwin/2024-January/255217.html >> >> Corinna proposed to either drop these functions entirely or hide the >> prototypes on Cygwin only. I attached a patch for the second alternative. >> From 5f1c43796c6a125f04c1f2436fc1048783ce3b7a Mon Sep 17 00:00:00 2001 >> From: Christian Franke <christian.franke@t-online.de> >> Date: Mon, 22 Jan 2024 19:11:20 +0100 >> Subject: [PATCH] Hide itoa, utoa, __itoa and __utoa in stdlib.h on Cygwin only >> >> These functions are non-standard and not exported by Cygwin. >> >> Signed-off-by: Christian Franke <christian.franke@t-online.de> >> --- >> newlib/libc/include/stdlib.h | 4 +++- >> 1 file changed, 3 insertions(+), 1 deletion(-) >> >> diff --git a/newlib/libc/include/stdlib.h b/newlib/libc/include/stdlib.h >> index 15b349440..fd89f5ba7 100644 >> --- a/newlib/libc/include/stdlib.h >> +++ b/newlib/libc/include/stdlib.h >> @@ -221,11 +221,13 @@ char * ecvtbuf (double, int, int*, int*, char *); >> char * fcvtbuf (double, int, int*, int*, char *); >> char * ecvtf (float,int,int *,int *); >> #endif >> +#ifndef __CYGWIN__ >> char * __itoa (int, char *, int); >> char * __utoa (unsigned, char *, int); >> -#if __MISC_VISIBLE >> +# if __MISC_VISIBLE >> char * itoa (int, char *, int); >> char * utoa (unsigned, char *, int); >> +# endif >> #endif >> #if __POSIX_VISIBLE >> int rand_r (unsigned *__seed); >> -- >> 2.43.0 > In fact, while this patch fixes the namespace pollution for Cygwin, I > wonder if we shouldn't remove itoa/utoa entirely. The underscored > functions __itoa/__utoa accomplish exactly the same thing. > > Does anybody actually *need* itoa/utoa as long as we have __itoa/__utoa? Unix 1st ed Manual defined itoa as did K&R on p60 (/p64 2ed); at least IBM and QNX and "some compilers" provide itoa and others: https://cplusplus.com/reference/cstdlib/itoa/ other libraries also provide {,u}{,l}ltoa. Newlib provided the function and man pages, which should be updated to reflect the changed situation, as they will have been used, and users will want to know what happened and what to do e.g. use prefixed functions, #define, sprintf(3), etc. Downstream systems should note the change in their lists of supported functions, and in their release notes.
brian.inglis@systematicsw.ab.ca wrote: > On 2024-01-23 02:03, Corinna Vinschen wrote: >> On Jan 22 19:46, Christian Franke wrote: >>> The functions itoa() and utoa() are non-standard, not exported by >>> Cygwin and >>> also unavailable on FreeBSD and Linux (glibc and musl libc). Busybox >>> for >>> example could not be build OOTB using newlib's stdlib.h because >>> there are >>> conflicts with local functions with same names but different >>> signatures. >>> >>> See the original posts on the Cygwin list for more details: >>> https://sourceware.org/pipermail/cygwin/2024-January/255216.html >>> https://sourceware.org/pipermail/cygwin/2024-January/255217.html >>> >>> Corinna proposed to either drop these functions entirely or hide the >>> prototypes on Cygwin only. I attached a patch for the second >>> alternative. > >>> From 5f1c43796c6a125f04c1f2436fc1048783ce3b7a Mon Sep 17 00:00:00 2001 >>> From: Christian Franke <christian.franke@t-online.de> >>> Date: Mon, 22 Jan 2024 19:11:20 +0100 >>> Subject: [PATCH] Hide itoa, utoa, __itoa and __utoa in stdlib.h on >>> Cygwin only >>> >>> These functions are non-standard and not exported by Cygwin. >>> >>> Signed-off-by: Christian Franke <christian.franke@t-online.de> >>> --- >>> newlib/libc/include/stdlib.h | 4 +++- >>> 1 file changed, 3 insertions(+), 1 deletion(-) >>> >>> diff --git a/newlib/libc/include/stdlib.h >>> b/newlib/libc/include/stdlib.h >>> index 15b349440..fd89f5ba7 100644 >>> --- a/newlib/libc/include/stdlib.h >>> +++ b/newlib/libc/include/stdlib.h >>> @@ -221,11 +221,13 @@ char * ecvtbuf (double, int, int*, int*, >>> char *); >>> char * fcvtbuf (double, int, int*, int*, char *); >>> char * ecvtf (float,int,int *,int *); >>> #endif >>> +#ifndef __CYGWIN__ >>> char * __itoa (int, char *, int); >>> char * __utoa (unsigned, char *, int); >>> -#if __MISC_VISIBLE >>> +# if __MISC_VISIBLE >>> char * itoa (int, char *, int); >>> char * utoa (unsigned, char *, int); >>> +# endif >>> #endif >>> #if __POSIX_VISIBLE >>> int rand_r (unsigned *__seed); >>> -- >>> 2.43.0 > >> In fact, while this patch fixes the namespace pollution for Cygwin, I >> wonder if we shouldn't remove itoa/utoa entirely. The underscored >> functions __itoa/__utoa accomplish exactly the same thing. >> >> Does anybody actually *need* itoa/utoa as long as we have __itoa/__utoa? > > Unix 1st ed Manual defined itoa as did K&R on p60 (/p64 2ed); at least > IBM and QNX and "some compilers" provide itoa and others: > > https://cplusplus.com/reference/cstdlib/itoa/ > > other libraries also provide {,u}{,l}ltoa. This page suggests that at least the K&R version was different (no radix parameter): https://en.wikibooks.org/wiki/C_Programming/stdlib.h/itoa > Newlib provided the function and man pages, which should be updated to > reflect the changed situation, as they will have been used, and users > will want to know what happened and what to do e.g. use prefixed > functions, #define, sprintf(3), etc. > > Downstream systems should note the change in their lists of supported > functions, and in their release notes. Newlib should IMO at least provide an easy way to hide the [iu]toa() prototypes without hiding other BSD or GNU extensions. The prototypes should not be visible if for example _GNU_SOURCE is defined and no other _*_SOURCE. This is currently not possible. Such a change would possibly require only minor documentation updates.
On Jan 24 10:42, Christian Franke wrote: > brian.inglis@systematicsw.ab.ca wrote: > > On 2024-01-23 02:03, Corinna Vinschen wrote: > > > On Jan 22 19:46, Christian Franke wrote: > > > > The functions itoa() and utoa() are non-standard, not exported > > > > by Cygwin and > > > > also unavailable on FreeBSD and Linux (glibc and musl libc). > > > > Busybox for > > > > example could not be build OOTB using newlib's stdlib.h because > > > > there are > > > > conflicts with local functions with same names but different > > > > signatures. > > > > [...] > > > Does anybody actually *need* itoa/utoa as long as we have __itoa/__utoa? > > > > Unix 1st ed Manual defined itoa as did K&R on p60 (/p64 2ed); at least > > IBM and QNX and "some compilers" provide itoa and others: > > > > https://cplusplus.com/reference/cstdlib/itoa/ > > > > other libraries also provide {,u}{,l}ltoa. > > This page suggests that at least the K&R version was different (no radix > parameter): > https://en.wikibooks.org/wiki/C_Programming/stdlib.h/itoa Also, the fact that it has been mentioned in K&R was apparently no incentive to standarize it later on. That's why its existence on various systems is a bit erratic. > > Newlib provided the function and man pages, which should be updated to > > reflect the changed situation, as they will have been used, and users > > will want to know what happened and what to do e.g. use prefixed > > functions, #define, sprintf(3), etc. Mind, I never said to remove the underscored functins. So the functionality still exists, it's just called __foo instead of foo. > > Downstream systems should note the change in their lists of supported > > functions, and in their release notes. We don't have any influence on downstream, but if downstream wants the API, it's easy to provide it by aliasing foo to __foo in a downstream header. > Newlib should IMO at least provide an easy way to hide the [iu]toa() > prototypes without hiding other BSD or GNU extensions. The prototypes should > not be visible if for example _GNU_SOURCE is defined and no other _*_SOURCE. > This is currently not possible. Such a change would possibly require only > minor documentation updates. The problem is that _GNU_SOURCE got synonymous for "everything and the kitchen sink", and there's no blessed way around that other than defining another source standard instead. Do we really want to create our own kind of "this is non-standard"-standard? That would be something like __NEWLIB_VISIBLE / _NEWLIB_SOURCE. But, then again, for just two seldom used APIs? Corinna
On 2024-01-24 04:16, Corinna Vinschen wrote: > On Jan 24 10:42, Christian Franke wrote: >> brian.inglis@systematicsw.ab.ca wrote: >>> On 2024-01-23 02:03, Corinna Vinschen wrote: >>>> On Jan 22 19:46, Christian Franke wrote: >>>>> The functions itoa() and utoa() are non-standard, not exported >>>>> by Cygwin and >>>>> also unavailable on FreeBSD and Linux (glibc and musl libc). >>>>> Busybox for >>>>> example could not be build OOTB using newlib's stdlib.h because >>>>> there are >>>>> conflicts with local functions with same names but different >>>>> signatures. >>>>> [...] >>>> Does anybody actually *need* itoa/utoa as long as we have __itoa/__utoa? >>> >>> Unix 1st ed Manual defined itoa as did K&R on p60 (/p64 2ed); at least >>> IBM and QNX and "some compilers" provide itoa and others: >>> >>> https://cplusplus.com/reference/cstdlib/itoa/ >>> >>> other libraries also provide {,u}{,l}ltoa. >> >> This page suggests that at least the K&R version was different (no radix >> parameter): >> https://en.wikibooks.org/wiki/C_Programming/stdlib.h/itoa > > Also, the fact that it has been mentioned in K&R was apparently no > incentive to standarize it later on. That's why its existence on > various systems is a bit erratic. > >>> Newlib provided the function and man pages, which should be updated to >>> reflect the changed situation, as they will have been used, and users >>> will want to know what happened and what to do e.g. use prefixed >>> functions, #define, sprintf(3), etc. > > Mind, I never said to remove the underscored functins. So the > functionality still exists, it's just called __foo instead of foo. > >>> Downstream systems should note the change in their lists of supported >>> functions, and in their release notes. > > We don't have any influence on downstream, but if downstream wants the > API, it's easy to provide it by aliasing foo to __foo in a downstream > header. We do have some - Cygwin, RTEMS - others should note!
Corinna Vinschen wrote: > On Jan 24 10:42, Christian Franke wrote: >> brian.inglis@systematicsw.ab.ca wrote: >>> On 2024-01-23 02:03, Corinna Vinschen wrote: >>>> On Jan 22 19:46, Christian Franke wrote: >>>>> The functions itoa() and utoa() are non-standard, not exported >>>>> by Cygwin and >>>>> also unavailable on FreeBSD and Linux (glibc and musl libc). >>>>> Busybox for >>>>> example could not be build OOTB using newlib's stdlib.h because >>>>> there are >>>>> conflicts with local functions with same names but different >>>>> signatures. >>>>> [...] >>>> Does anybody actually *need* itoa/utoa as long as we have __itoa/__utoa? >>> Unix 1st ed Manual defined itoa as did K&R on p60 (/p64 2ed); at least >>> IBM and QNX and "some compilers" provide itoa and others: >>> >>> https://cplusplus.com/reference/cstdlib/itoa/ >>> >>> other libraries also provide {,u}{,l}ltoa. >> This page suggests that at least the K&R version was different (no radix >> parameter): >> https://en.wikibooks.org/wiki/C_Programming/stdlib.h/itoa > Also, the fact that it has been mentioned in K&R was apparently no > incentive to standarize it later on. That's why its existence on > various systems is a bit erratic. > >>> Newlib provided the function and man pages, which should be updated to >>> reflect the changed situation, as they will have been used, and users >>> will want to know what happened and what to do e.g. use prefixed >>> functions, #define, sprintf(3), etc. > Mind, I never said to remove the underscored functins. So the > functionality still exists, it's just called __foo instead of foo. > >>> Downstream systems should note the change in their lists of supported >>> functions, and in their release notes. > We don't have any influence on downstream, but if downstream wants the > API, it's easy to provide it by aliasing foo to __foo in a downstream > header. > >> Newlib should IMO at least provide an easy way to hide the [iu]toa() >> prototypes without hiding other BSD or GNU extensions. The prototypes should >> not be visible if for example _GNU_SOURCE is defined and no other _*_SOURCE. >> This is currently not possible. Such a change would possibly require only >> minor documentation updates. > The problem is that _GNU_SOURCE got synonymous for "everything and the > kitchen sink", and there's no blessed way around that other than > defining another source standard instead. My interpretation was "everything and the kitchen sink - except everything never provided by glibc or Linux" :-) > Do we really want to create our own kind of "this is > non-standard"-standard? > > That would be something like __NEWLIB_VISIBLE / _NEWLIB_SOURCE. > > But, then again, for just two seldom used APIs? The API is seldom used, possibly not or no longer well known and definitely unavailable in widely used other C libs. This increases the risk of a conflict with local functions with the same name. Busybox is a real world example. If it will be decided to keep this API as is, please consider to accept my patch from the start of this thread. It IMO obviously makes sense because Cygwin does not provide this API. This could at least simplify my patch for the busybox Cygwin package and may increase the probability that it will be accepted by busybox upstream.
On Jan 28 13:52, Christian Franke wrote: > Corinna Vinschen wrote: > > > > > > [...] > > > > > Does anybody actually *need* itoa/utoa as long as we have __itoa/__utoa? > > > > [...] > > The problem is that _GNU_SOURCE got synonymous for "everything and the > > kitchen sink", and there's no blessed way around that other than > > defining another source standard instead. > > My interpretation was "everything and the kitchen sink - except everything > never provided by glibc or Linux" :-) > > > Do we really want to create our own kind of "this is > > non-standard"-standard? > > > > That would be something like __NEWLIB_VISIBLE / _NEWLIB_SOURCE. > > > > But, then again, for just two seldom used APIs? > > The API is seldom used, possibly not or no longer well known and definitely > unavailable in widely used other C libs. This increases the risk of a > conflict with local functions with the same name. Busybox is a real world > example. I never doubted that. My question is NOT how we can keep itoa/utoa alive and striving. I think we have really only two ways of going forward: #if __CYGWIN__'ize itoa/utoa prototypes in stdlib.h, but DO NOT #if __CYGWIN__'ize __itoa/__utoa, because they are living in reserved namespace anyway or drop the definitions of itoa/utoa from itoa.c and utoa.c, drop the prototypes from stdlib.h, but NEITHER drop __itoa/__utoa from the source files NOR drop their prototypes. I favor the second approach, but if we can't get this sorted out within the next two days, we'll go ahead with the first approach. Corinna
Corinna Vinschen wrote: > On Jan 28 13:52, Christian Franke wrote: >> Corinna Vinschen wrote: >>>>>>> [...] >>>>>> Does anybody actually *need* itoa/utoa as long as we have __itoa/__utoa? >>>>> [...] >>> The problem is that _GNU_SOURCE got synonymous for "everything and the >>> kitchen sink", and there's no blessed way around that other than >>> defining another source standard instead. >> My interpretation was "everything and the kitchen sink - except everything >> never provided by glibc or Linux" :-) >> >>> Do we really want to create our own kind of "this is >>> non-standard"-standard? >>> >>> That would be something like __NEWLIB_VISIBLE / _NEWLIB_SOURCE. >>> >>> But, then again, for just two seldom used APIs? >> The API is seldom used, possibly not or no longer well known and definitely >> unavailable in widely used other C libs. This increases the risk of a >> conflict with local functions with the same name. Busybox is a real world >> example. > I never doubted that. My question is NOT how we can keep itoa/utoa > alive and striving. I think we have really only two ways of going > forward: > > #if __CYGWIN__'ize itoa/utoa prototypes in stdlib.h, but DO NOT > #if __CYGWIN__'ize __itoa/__utoa, because they are living in > reserved namespace anyway The DO NOT branch would only make real sense if Cygwin would provide the __*() functions, As this is not the case, my patch disables also these prototypes. ... > or > > drop the definitions of itoa/utoa from itoa.c and utoa.c, drop the > prototypes from stdlib.h, but NEITHER drop __itoa/__utoa from > the source files NOR drop their prototypes. > > I favor the second approach, but if we can't get this sorted out > within the next two days, we'll go ahead with the first approach. > > > Corinna >
On Jan 29 15:17, Christian Franke wrote: > Corinna Vinschen wrote: > > On Jan 28 13:52, Christian Franke wrote: > > > Corinna Vinschen wrote: > > > > > > > > [...] > > > > > > > Does anybody actually *need* itoa/utoa as long as we have __itoa/__utoa? > > > > > > [...] > > > > The problem is that _GNU_SOURCE got synonymous for "everything and the > > > > kitchen sink", and there's no blessed way around that other than > > > > defining another source standard instead. > > > My interpretation was "everything and the kitchen sink - except everything > > > never provided by glibc or Linux" :-) > > > > > > > Do we really want to create our own kind of "this is > > > > non-standard"-standard? > > > > > > > > That would be something like __NEWLIB_VISIBLE / _NEWLIB_SOURCE. > > > > > > > > But, then again, for just two seldom used APIs? > > > The API is seldom used, possibly not or no longer well known and definitely > > > unavailable in widely used other C libs. This increases the risk of a > > > conflict with local functions with the same name. Busybox is a real world > > > example. > > I never doubted that. My question is NOT how we can keep itoa/utoa > > alive and striving. I think we have really only two ways of going > > forward: > > > > #if __CYGWIN__'ize itoa/utoa prototypes in stdlib.h, but DO NOT > > #if __CYGWIN__'ize __itoa/__utoa, because they are living in > > reserved namespace anyway > > The DO NOT branch would only make real sense if Cygwin would provide the > __*() functions, As this is not the case, my patch disables also these > prototypes. > ... Good point. Corinna
On Jan 22 19:46, Christian Franke wrote: > The functions itoa() and utoa() are non-standard, not exported by Cygwin and > also unavailable on FreeBSD and Linux (glibc and musl libc). Busybox for > example could not be build OOTB using newlib's stdlib.h because there are > conflicts with local functions with same names but different signatures. > > See the original posts on the Cygwin list for more details: > https://sourceware.org/pipermail/cygwin/2024-January/255216.html > https://sourceware.org/pipermail/cygwin/2024-January/255217.html > > Corinna proposed to either drop these functions entirely or hide the > prototypes on Cygwin only. I attached a patch for the second alternative. > > -- > Regards, > Christian > > From 5f1c43796c6a125f04c1f2436fc1048783ce3b7a Mon Sep 17 00:00:00 2001 > From: Christian Franke <christian.franke@t-online.de> > Date: Mon, 22 Jan 2024 19:11:20 +0100 > Subject: [PATCH] Hide itoa, utoa, __itoa and __utoa in stdlib.h on Cygwin only > > These functions are non-standard and not exported by Cygwin. > > Signed-off-by: Christian Franke <christian.franke@t-online.de> > --- > newlib/libc/include/stdlib.h | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) Pushed. Thanks, Corinna
diff --git a/newlib/libc/include/stdlib.h b/newlib/libc/include/stdlib.h index 15b349440..fd89f5ba7 100644 --- a/newlib/libc/include/stdlib.h +++ b/newlib/libc/include/stdlib.h @@ -221,11 +221,13 @@ char * ecvtbuf (double, int, int*, int*, char *); char * fcvtbuf (double, int, int*, int*, char *); char * ecvtf (float,int,int *,int *); #endif +#ifndef __CYGWIN__ char * __itoa (int, char *, int); char * __utoa (unsigned, char *, int); -#if __MISC_VISIBLE +# if __MISC_VISIBLE char * itoa (int, char *, int); char * utoa (unsigned, char *, int); +# endif #endif #if __POSIX_VISIBLE int rand_r (unsigned *__seed);